# TWENTIETHANNUAI

estConX

#### March 3 - 6, 2019

Hilton Phoenix / Mesa Hotel Mesa, Arizona

Archive

# **COPYRIGHT NOTICE**

The presentation(s)/poster(s) in this publication comprise the proceedings of the 2019 TestConX workshop. The content reflects the opinion of the authors and their respective companies. They are reproduced here as they were presented at the 2019 TestConX workshop. This version of the presentation or poster may differ from the version that was distributed in hardcopy & softcopy form at the 2019 TestConX workshop. The inclusion of the presentations/posters in this publication does not constitute an endorsement by TestConX or the workshop's sponsors.

There is NO copyright protection claimed on the presentation/poster content by TestConX. However, each presentation/poster is the work of the authors and their respective companies: as such, it is strongly encouraged that any use reflect proper acknowledgement to the appropriate source. Any questions regarding the use of any materials presented should be directed to the author(s) or their companies.

"TestConX" and the TestConX logo are trademarks of TestConX. All rights reserved.

Session 1B Presentation 2

#### TestConX 2019

On the Bus - Advanced bus protocols for validation

# MIPI Tiny SneakPeek: An Optimized Debug Protocol for efficient Platform Debug

#### Rolf Kühnis Intel Corporation





TestConX Workshop

www.testconx.org

March 3-6, 2019

On the Bus - Advanced bus protocols for validation

#### **Disclaimer**

Intel technologies' features and benefits depend on system configuration and may require enabled hardware, software or service activation. Performance varies depending on system configuration. No computer system can be absolutely secure. Check with your system manufacturer or retailer or learn more at <u>www.intel.com</u>.

Intel, the Intel logo are trademarks of Intel Corporation or its subsidiaries in the U.S. and/or other countries.

\*Other names and brands may be claimed as the property of others



MIPI Tiny SneakPeek: An Optimized Debug Protocol for efficient Platform Debug



TestConX Workshop

On the Bus - Advanced bus protocols for validation

#### Agenda

- What is MIPI<sup>®</sup> Sneak Peek Protocol (SPP<sup>™</sup>)
- Usage model of MIPI<sup>®</sup> SPP™
- Conclusions and call to action



MIPI Tiny SneakPeek: An Optimized Debug Protocol for efficient Platform Debug



TestConX Workshop

On the Bus - Advanced bus protocols for validation

#### SneakPeek Protocol: A "Container"



Source: Wikipedia.de Containertransport; CC BY-SA 3.0



Source: Wikimedia 40 foot container double semi truck; CC BY 3.0

Test**ConX**®



Source: Wikipedia Intermodal container; CC BY-SA 2.0

MIPI Tiny SneakPeek: An Optimized Debug Protocol for efficient Platform Debug





Source: Wikipedia Containerization; CC BY 2.0

On the Bus - Advanced bus protocols for validation

#### SneakPeek Protocol (SPP™) Overview

• Packet based protocol

Test**ConX** 

- Simple enough to be implemented in dedicated HW modules
- Command/ Response protocol driven by the debug tooling (DTS)
- Focus on system and debug peripheral memory access
- Network latency tolerant for higher throughput while maintaining error feedback through command/ response





On the Bus - Advanced bus protocols for validation

#### **MIPI<sup>®</sup>: SneakPeek**

- No dedicated port needed
- Stability depends on network/ PHY
- Debug solution might be impacted by power states

Test**ConX**®



MIPI Tiny SneakPeek: An Optimized Debug Protocol for efficient Platform Debug

6

On the Bus - Advanced bus protocols for validation



TestConX Workshop

On the Bus - Advanced bus protocols for validation

#### SPP Command/ Response Opcodes

Commands

(issued by the DTS):

- Pad
- Nop
- InitializeSPEngine
- UnblockSPEngine
- ReadSPConfig
- WriteSPConfig
- ReadSystem
- WriteSystem
- WriteReadSystem
- LoopTrigSystem

Responses (sent by the TS):

- Pad
- Nop
- AckInitalizeSPEngine
- AckUnblockSPEngine
- ReadSPConfigData
- WriteSPConfigResult
- ReadSystemData
- WriteSystemResult
- WriteReadSystemData
- LoopTrigSystemResult











On the Bus - Advanced bus protocols for validation

#### **SneakPeek Protocol (SPP)**

- Pairing Command/Response
- FullSPP can bundle several command/responses into a single SP Transfer Block (SPTB)
  - Optimized for high bandwidth interfaces
- TS does not generate spontaneous traffic

Test**ConX**\*

MIPI Tiny SneakPeek: An Optimized Debug Protocol for efficient Platform Debug



TestConX Workshop

On the Bus - Advanced bus protocols for validation

#### One Size fits all?

- Depending on application, the SPP overhead is significant
  - Minimal header size is 16 Bytes
- The TinySPP flavor was introduced to better cope with low bandwidth I/Fs
  - Minimal header size is 4 Bytes
  - Short addressing capabilities
  - Introduction of actions in commands and events in responses



Source: Wikipedia.de Containertransport; Public Domain





On the Bus - Advanced bus protocols for validation

#### **SneakPeek Protocol Flavors**

| Feature                                       | TinySPP                                                                                                                                                          | FullSPP          |  |  |
|-----------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|--|--|
| # of Access Spaces                            | 8 (3-bit field)                                                                                                                                                  | 32 (5-bit field) |  |  |
| Sequence Number                               | <ul> <li>N/A. Additional requirements to network:</li> <li>Messages stay in order</li> <li>Guaranteed Delivery</li> <li>DTS/TS has to do book-keeping</li> </ul> | Present          |  |  |
| Standard Size Field                           | Chosen by TS                                                                                                                                                     | Different option |  |  |
| Size of Transaction Byte<br>Count (TBC) Field | 7 bits                                                                                                                                                           | 16 bits          |  |  |
| Short Addressing                              | 6-bit address replacement supported. Short addressing is required in TinySPP                                                                                     | N/A              |  |  |
| Packet Alignment                              | Byte aligned                                                                                                                                                     | 16-Byte aligned  |  |  |
| Shortest Packet Length                        | 4 Bytes                                                                                                                                                          | 16 Bytes         |  |  |
| Test <b>ConX</b> ®                            | MIPI Tiny SneakPeek: An Optimized Debug Protocol for efficient Platform D                                                                                        | rebug 13         |  |  |



TestConX Workshop

# TinySPP

- Optimized for low bandwidth interfaces. Primary target is MIPI I3C
- Focus on 32-bit systems
  - Use SP register to go beyond 32-bit
- "Short addressing" to optimize local accesses
- Use:
  - Action and event to reduce latency

| Event                                | Action                              |  |  |  |  |
|--------------------------------------|-------------------------------------|--|--|--|--|
| No Event to Report                   | No Action to be Performed           |  |  |  |  |
| Execution State Changed to Start     | Change Execution State to Start     |  |  |  |  |
| Execution State Changed to Stop      | Change Execution State to Stop      |  |  |  |  |
| Trace Activity Changed (Start/ Stop) | Change Trace Activity (Start/ Stop) |  |  |  |  |
| Reset Occurred                       | Reset                               |  |  |  |  |
| Trigger                              | Trigger                             |  |  |  |  |
| Trace Attention Needed               | Reserved                            |  |  |  |  |
| Communication (RX) Data Ready        | Communication (TX) Data Ready       |  |  |  |  |
| Vendor defined Event 1               | Vendor defined Action 1             |  |  |  |  |
| Vendor defined Event 2               | Vendor defined Action 2             |  |  |  |  |

# TestConX





|                                                                                 | E                                                                                     | xample: SPP                                                                                                                                                                                       | Data For                                                                                                                                                                                    | mat               |                    |    |             |
|---------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|--------------------|----|-------------|
|                                                                                 | TinySPP           31         30         29         28           Addr[7:2] o         0 | 27     26     25     24     23     22     21     20     19     18     17     16       r Res     SPCONF_ADDR S     Transaction Byte Count or<br>Reserved     Transaction Byte Count or<br>Reserved | 15         14         13         12         11         10         9         8         7           Action         LCP         SRI         COF         AccessSpace<br>or Rsvd         or Rsvd | 7 6 5 4<br>Opcode | 3 2 1 0<br>Version |    |             |
|                                                                                 | LCP I<br>SRI S<br>COF (<br>S I<br>FullSPP                                             | ast Command Packet<br>Send Response Immediately<br>Continue on Fault<br>Jse Short Address                                                                                                         | ý<br>Sizo or Bayd Associacione or Bayd                                                                                                                                                      | Oracda            | Varias             |    |             |
|                                                                                 | LCP SRI COF Ac                                                                        | tion Reserved                                                                                                                                                                                     | Transaction Byte Cou                                                                                                                                                                        | int or Reserved   | d                  |    |             |
| AddressLow or SignatureLow or Reserved AddressHigh or SignatureHigh or Reserved |                                                                                       |                                                                                                                                                                                                   |                                                                                                                                                                                             |                   |                    |    |             |
| Test                                                                            | Con                                                                                   | MIPI Tiny SneakPeek: An C                                                                                                                                                                         | ptimized Debug Protocol for e                                                                                                                                                               | fficient Platfo   | orm Debug          | 16 | R . 20. THE |



On the Bus - Advanced bus protocols for validation

#### Conclusions

- MIPI Sneak Peek Protocol provides a scalable debug/ test solution
  - Meets the high and low bandwidth link requirements
  - Can be implemented in Software or Hardware
  - Reusable solution across different product segments





On the Bus - Advanced bus protocols for validation

#### **Call to Action**

- Adopt and implement the flexible MIPI Debug Solution
- Join the MIPI Debug WG
  - Currently participants are SoC, IP, Tools vendors
  - Requires MIPI Contributor membership
  - Telcos every other Tuesday at 9am pacific time
    - 90-120 minutes depending on the agenda
  - Three F2F sessions with all MIPI WGs
    - Generally meet for 4 days



MIPI Tiny SneakPeek: An Optimized Debug Protocol for efficient Platform Debug



TestConX Workshop

On the Bus - Advanced bus protocols for validation

#### **Further Information**

- MIPI Debug WG Public Page
- MIPI Architecture Overview for Debug
- MIPI Debug on Wikipedia



MIPI Tiny SneakPeek: An Optimized Debug Protocol for efficient Platform Debug



TestConX Workshop

On the Bus - Advanced bus protocols for validation



MIPI Tiny SneakPeek: An Optimized Debug Protocol for efficient Platform Debug



TestConX Workshop