# SmartFusion2 and IGLOO2 SmartDebug Hardware Design Debug Tools - Libero SoC v11.6

TU0530 Tutorial





## **Table of Contents**

| SmartFusion2 and IGLOO2 SmartDebug Hardware Design Debug Tools                                                           | 3  |
|--------------------------------------------------------------------------------------------------------------------------|----|
| Introduction                                                                                                             | 3  |
| Design Requirements                                                                                                      | 3  |
| Project Files                                                                                                            | 4  |
| Design Overview                                                                                                          | 4  |
| Programming the Device                                                                                                   | 6  |
| Launching SmartDebug                                                                                                     | 9  |
| Debugging the Design                                                                                                     |    |
| View Device Status                                                                                                       |    |
| View Flash Memory (eNVM) Content                                                                                         |    |
| Debug FPGA Array                                                                                                         |    |
| Writing to Fabric SRAM Blocks     Probe Insertion                                                                        |    |
| SERDES Debug                                                                                                             |    |
| Far-End Loop Back Support                                                                                                |    |
| Tcl Support                                                                                                              |    |
| Executing SERDES Debug from SmartDebug Tcl                                                                               | 35 |
| Conclusion                                                                                                               |    |
|                                                                                                                          |    |
| Appendix                                                                                                                 |    |
| Tcl Script Examples                                                                                                      |    |
| Example 1: Change M/N/F registers for Lane1 and Lane2 of SERDESIF_0                                                      |    |
| Example 2: Change RX LEQ registers Lane2 of SERDESIF_0<br>Example 3: Change TX De-emphasis registers Lane2 of SERDESIF 0 |    |
|                                                                                                                          |    |
| List of Changes                                                                                                          |    |
| Product Support                                                                                                          |    |
| Customer Service                                                                                                         |    |
| Customer Technical Support Center                                                                                        |    |
| Technical Support                                                                                                        |    |
| Website                                                                                                                  |    |
| Contacting the Customer Technical Support Center                                                                         |    |
| Email                                                                                                                    |    |
| Outside the U.S.                                                                                                         |    |
| ITAR Technical Support                                                                                                   |    |
|                                                                                                                          |    |
|                                                                                                                          |    |
|                                                                                                                          |    |
|                                                                                                                          |    |



## Introduction

Design debug is a critical phase of the FPGA design flow. Microsemi<sup>®</sup> multiple design debug tools and features complement design simulations by allowing verification and troubleshooting at the hardware level. Microsemi SmartDebug tools help the designer to analyze the key elements of a flash design, such as the embedded non-volatile memory (eNVM) data, SRAM data, and probes capabilities. Microsemi SmartFusion<sup>®</sup>2 system-on-chip (SoC) field programmable gate array (FPGA) and IGLOO<sup>®</sup>2 FPGA devices have built-in probe points that greatly enhance the ability to debug logic elements within the device. The enhanced debug features implemented in the SmartFusion2 and IGLOO2 devices give access to any logic element through Live Probe and Active Probe features, which enable designers to check the state of inputs and outputs in real-time, without any re-layout of the design.

The following topics are described in this tutorial:

- Launching SmartDebug: Accessing SmartDebug from Libero<sup>®</sup> System-on-Chip (SoC)
- View Device Status: Checking the device status
- View Flash Memory (eNVM) Content: Checking the flash memory (eNVM) content
- Debug FPGA Array: Debugging FPGA array (setting Live Probes, Active Probes, and reading and modifying fabric SRAM content)
- Probe Insertion: Post-Layout Probe Insertion
- SERDES Debug: Debugging SERDES blocks

## **Design Requirements**

Table 1 • Design Requirements

| Design Requirements                                                                                            | Description                                                 |
|----------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------|
| Hardware Requirements                                                                                          | •                                                           |
| SMA Male-to-SMA Male Precision Cables, such as Pasternack<br>Industries part number PE39429-12 (or equivalent) | Optionally recommended for evaluation board SERDES testing. |
| IGLOO2 Evaluation Kit<br>or<br>SmartFusion2 Security Evaluation Kit (M2S090TS-FGG484)                          | Rev D or later                                              |
| Software Requirements                                                                                          |                                                             |
| Libero SoC software                                                                                            | v11.6                                                       |
| FlashPro4                                                                                                      | v11.6                                                       |



## **Project Files**

Extract the http://soc.microsemi.com/download/rsc/?f=m2s\_m2gl\_tu0530\_liberov11p6\_df

Libero SoC project along with the Readme.txt file and programming (.stp) file to a folder on the PC (for example: C:\*Microsemiprj*). Confirm that the following design files are extracted from the downloaded folder:

- m2gl\_SmartDebug\_Tutorial For IGLOO2 Evaluation Kit (M2GL010T)
- m2s\_SmartDebug\_Tutorial For SmartFusion2 Security Evaluation Kit (M2S090TS)

## **Design Overview**

The design consists of two main blocks: the SERDES debug block (SERDES\_Debug) and the fabric debug block (Fabric\_Debug), as shown in Figure 1.

The SERDES\_Debug block is used to demonstrate the SmartDebug capabilities that can be used to perform SERDES real-time signal integrity testing and debugging. The design consists of a System Builder block (SD\_DEMO) and an instance of SERDES Interface block (SERDES\_IF), as shown in Figure 2 on page 5. Within the System Builder, a Data Storage client is stored in the flash memory (eNVM). SmartDebug provides the capabilities to view the eNVM content by reading the content in real-time from the device.

The Fabric\_Debug block demonstrates the way to use SmartDebug to perform FPGA array debugging. To demonstrate this, the Fabric\_Debug uses a counter to load a counting pattern into the LSRAM instance (DPSRAM). The data stored is the same as the address. On the read side of the LSRAM, there is a count checker (count\_chk) to ensure that the count progresses as expected. If there is an error, the output (error) is latched high, as shown in Figure 3 on page 5. This Fabric\_Debug block design is used to demonstrate the different silicon built-in capabilities, such as setting Live Probes to monitor an internal user-selected point on the device in real-time.

In addition, you can set Active Probes, which provide the capabilities for dynamic asynchronous read and write to a flip-flop or probe point. This enables you to quickly observe the output of the logic internally or to quickly experiment on how the logic is affected by writing to a probe point. Finally, the Fabric\_Debug design block is used to demonstrate the SmartDebug capabilities, where you can read and modify the fabric SRAM content in real-time.



Figure 1 • SmartDebug Top-Level Blocks



Figure 2 • SERDES\_Debug Overall Design Blocks (IGLOO2 Design Block)



Figure 3 • Fabric\_Debug Overall Design Blocks (IGLOO2 Design Block)

A\_WEN is used to pause the write operation to the SRAM while demonstrating the SmartDebug write to the SRAM capability. It is assigned to SW2 on the board. When SW2 is pressed, the write operation from the counter pauses and does not overwrite the SmartDebug write into the SRAM.



## **Programming the Device**

The following steps describe how to program the IGLOO2 or SmartFusion2 Security Evaluation Kit board:

- 1. Connect the **FlashPro4 programmer** to the **J5** connector on the IGLOO2 or SmartFusion2 Security Evaluation Kit.
- 2. Connect the power supply to the **J6** connector.
- 3. Switch **ON** the power supply (**SW7**). For more information, refer to the IGLOO2 FPGA Evaluation Kit Board or SmartFusion2 Security Evaluation Kit Board.
- 4. Launch Libero SoC v11.6.
- 5. From the Project menu, select Open Project.
- 6. Browse to the folder where the design files are extracted and open the appropriate design file (IGLOO2 or SmartFusion2). For more information, refer to the "Project Files" section on page 4.
- 7. Based on the location where the project files are extracted, update the paths in the eNVM data clients as follows:
  - a. On the **Design Flow** window, double-click **Update eNVM Memory Content** as shown in Figure 4.



Figure 4 • Update eNVM Memory Content in Design Flow Window

The eNVM Update Tool window is displayed, as shown in Figure 5.

| b. Double-click the <b>sram_envm</b> client. |
|----------------------------------------------|
|----------------------------------------------|

| NVM Update Tool               |                               |                        |                                                             |                                                              | ? ×        |  |
|-------------------------------|-------------------------------|------------------------|-------------------------------------------------------------|--------------------------------------------------------------|------------|--|
| Available Client types        |                               | Us                     | er Clients in eN                                            | VM                                                           |            |  |
| Data Storage<br>Serialization | Client Type                   | Client Name            | DepthxWidth                                                 | Start Address(Hex)                                           | Page Start |  |
|                               | 1 Data Storage                | sram_envm              | 64 x 8                                                      | 2000                                                         | 64         |  |
| Add to System                 | 2 🔒 Data Storage              | Start_prog             | 500 × 32                                                    | 0                                                            | 0          |  |
| -                             | You can disable programming f | or a client by editing | II<br>the client and selecting<br>this client can be re-ena | the 'No Content' option.<br>abled by selecting the preserved | content.   |  |
| Used Space                    |                               |                        |                                                             |                                                              |            |  |

#### Figure 5 • eNVM Update Tool Window

c. In the **Modify Data Storage Client** window, browse to the location of the sram\_envm.mem file located in the eNVM\_files folder included in the project as shown in Figure 6.

| Modify Data Storage Client                                                                                                                                                                                                                                                                                                                                                             |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Client name: sram_envm<br>eNVM<br>Content:<br>Memory file: 2s_martDebug_Tutorial/eNVM_files/sram_envm.mem<br>Format: Microsemi-Binary<br>Use absolute addressing<br>Content filed with 0s<br>Content filed with 0s<br>No Content (Client is a placeholder and will not be programmed)<br>Start address: 0x 2000<br>Size of word: 8 Bits<br>Number of Words: 64 (Decimal)<br>Use as ROM |
| Use Content for Simulation Help Ok Cancel                                                                                                                                                                                                                                                                                                                                              |

Figure 6 • Modify Data Storage Client Window



d. If the SmartFusion2 Security Evaluation Kit is used, double-click the **Start\_prog** client (see Figure 5). In the **Modify Data Storage Client** window, browse to the location of the <code>Start\_prog.hex</code> file located in the eNVM\_files folder included in the project as shown in Figure 7.

| Content:     |                                                                |
|--------------|----------------------------------------------------------------|
| Mer          | ory file: n2s_SmartDebug_Tutorial/eNVM_files/Start_prog.hex    |
|              | Format: Intel-Hex                                              |
|              | Use absolute addressing                                        |
| 🔘 Cor        | tent filled with 0s                                            |
| 🔘 No         | iontent ( Client is a placeholder and will not be programmed ) |
| Start addre  | s: 0× 0 🚔                                                      |
| Size of word | : 32 - Bits                                                    |
| Number of V  | Vords: 500 (Decimal)                                           |
| 🔲 Use as F   | ом 🚯                                                           |
| 🔲 Use Conte  | nt for Simulation                                              |
|              |                                                                |

Figure 7 • Modify Data Storage Client Window - Specifying Start\_prog.hex File

5

Note: The . hex file is a simple user boot code loop program that is programmed into address zero (eNVM address 0x60000000). This is to ensure that there is a valid user boot code for the ARM<sup>®</sup> Cortex<sup>®</sup>-M3 to execute on power-up or at power-on reset. For more information, refer to http://soc.microsemi.com/kb/article.aspx?id=SL5636



8. In the **Design Flow** window, select **Run PROGRAM Action**, as shown in Figure 8. This programs the design into the device.

| ign Flow         |      | ē ×                                         |
|------------------|------|---------------------------------------------|
| nartDebu         | ug_t | op 🖸 🖸 🖬 🖗                                  |
| Тоо              | ы    |                                             |
| ⊳                | •    | Create Design                               |
| $\triangleright$ | ►    | Create Constraints                          |
| $\triangleright$ | •    | Implement Design                            |
| $\triangleright$ | •    | Edit Design Hardware Configuration          |
| $\triangleright$ | ►    | Configure Security and Programming Options  |
| / 4              | •    | Program Design                              |
| /                |      | 🕮 Generate Bitstream                        |
|                  |      | 🚆 Run PROGRAM Action                        |
|                  | ₽    | Debug Design                                |
|                  |      |                                             |
| esign F          |      | Design Hierar Stimulus Hierar Catalog Files |
|                  |      |                                             |

#### Figure 8 • Programming the Device

## Launching SmartDebug

On the **Design Flow** window, double-click **SmartDebug Design**, as shown in Figure 9.



Figure 9 • Launching SmartDebug Design Tools



The SmartDebug window is displayed, as shown in Figure 10.

| SmartDel<br><u>F</u> ile <u>V</u> iew |                                                 |                                  |     |
|---------------------------------------|-------------------------------------------------|----------------------------------|-----|
|                                       | 25090T (M25090T)   e read from device 1F8071CF  | Programmer: 75705 (usb75705)     | •   |
| [                                     | View Device Status<br>View Flash Memory Content | Debug FPGA Array<br>Debug SERDES |     |
|                                       | ges 🔀 Errors 🗼 Warnings 🁔 Info                  |                                  | ex  |
| E Messa                               | ges 🐼 criors 🔒 warnings 🕕 Inio                  | 2                                |     |
|                                       |                                                 |                                  | .41 |

#### Figure 10 • SmartDebug Window Debug Options

SmartDebug tools provide the following features and capabilities:

- Live Probes: Two dedicated probes can be configured to observe a probe point, which is any output of a register. After selecting the probe points, the probe data can be sent to two dedicated pins (PROBE\_A and PROBE\_B). PROBE\_A and PROBE\_B are two dedicated pins on the device. You can connect an oscilloscope to the probe pins and monitor the signals status.
- Active Probes: Active probes allow dynamic asynchronous read and write to a flip-flop or probe point. This enables you to quickly observe the output of the logic internally, or to quickly experiment on how the logic is affected by writing to a probe point.
- SRAM and eNVM Debug Capabilities: SmartDebug includes test capabilities that can access SRAM and eNVM to assist with checking the flash memory (eNVM) content and reading and modifying the fabric SRAM content.
- **Probe Insertion**: Probe insertion is a post-layout process that enables you to insert probes into the design and brings signals out to the FPGA package pins to evaluate and debug the design.



**SERDES Debug Capabilities**: SERDES debug capabilities makes debugging high-speed serial designs simple. The SmartDebug JTAG interface extends access to configure, control, and observe SERDES operations and is accessible in every SERDES design. The designs are implemented using the Libero System Builder to incorporate the SERDESIF block enabling SERDES access from the SmartDebug toolset. The SERDES Debug window displays real-time system and lane status information. SERDES configurations are supported with Tcl scripting, allowing access to the entire SERDES register map for real-time customized tuning.

## **Debugging the Design**

## **View Device Status**

The View Device Status option provides the device status report. It summarizes the device information, programmer information, user information, factory serial number, and security information, if any are set. Figure 11 shows a sample of the device status information.

| Device: M2S0901 | T (M2S090T) Programmer: 75705 (usb75705) | Save     | Print |
|-----------------|------------------------------------------|----------|-------|
| Device Status:  | IDCode (read from the device) (HEX):     | 1f8071cf |       |
| Help            |                                          |          | Close |

#### Figure 11 • Device Status Report Sample

## View Flash Memory (eNVM) Content

The View Flash Memory Content can be accessed from the **SmartDebug** window, as shown in Figure 10 on page 10. This option provides the capabilities to retrieve the eNVM content from the device using the Memories pages of the System Builder under the SERDES\_Debug block. To demonstrate how to retrieve the content of the eNVM, the data to be programmed into the eNVM is defined first. One way to perform this is by defining an eNVM data storage client using the eNVM configurator. The client can be stored into any page of the eNVM. eNVM Page 64 is used here for demonstration purposes. Figure 12 shows an excerpt of the data storage client content that was defined in the eNVM.

| sram_envm.mem    |
|------------------|
| 1 01010011       |
| 2 1111111        |
| 3 01010101       |
| 4 11100010       |
| 5 10101010       |
| 6 11110000       |
| 7 01010011       |
| 8 1111111        |
| 9 01010011       |
| 10 1111111       |
| 11 01010101      |
| 12 11100010      |
| 13 10101010      |
| 14 11110000      |
| 15 01010011      |
| 16 1111111       |
| 17 01010011      |
| 18 1111111       |
| 19 01010101      |
| 20 11100010 -    |
| Dos\Win ANSI INS |

#### Figure 12 • Memory File Content Saved into the eNVM

The content of eNVM is retrieved from the device, displayed, and is equivalent to what is shown in Figure 12.



The following steps describe how the eNVM content can be read in real-time from the device:

- 1. On the **SmartDebug** window, click **View Flash Memory Content** (see Figure 10). The **Flash Memory** window is displayed, as shown in Figure 13.
- 2. Enter the Start Page and End Page as 64. Page 64 is used here for demonstration purpose.
- 3. Click Read from Device. The content related to page 64 is displayed.

| ] Flash Me<br>Retrieve Fla |                                                              |                           |                           | from F                          |                                 |                           |                           |                           |                     |                           |                      |                |                            |                           |                                        |                                  | 2                          | X |
|----------------------------|--------------------------------------------------------------|---------------------------|---------------------------|---------------------------------|---------------------------------|---------------------------|---------------------------|---------------------------|---------------------|---------------------------|----------------------|----------------|----------------------------|---------------------------|----------------------------------------|----------------------------------|----------------------------|---|
| From block                 |                                                              |                           | ntent                     | Trom L                          | evice                           |                           |                           |                           |                     |                           |                      |                |                            |                           |                                        |                                  |                            |   |
|                            | Page Rang                                                    |                           |                           | ſ                               | a) Rea                          | d from                    | Device <sup>1</sup>       | *                         |                     |                           |                      |                |                            |                           |                                        |                                  |                            |   |
|                            |                                                              |                           |                           | E.                              | NCC                             |                           |                           |                           |                     |                           |                      |                |                            |                           |                                        |                                  |                            |   |
|                            | Start Page:                                                  | _                         |                           |                                 |                                 |                           | ess 0x20                  | -                         |                     |                           |                      |                |                            |                           |                                        |                                  |                            |   |
| E                          | End Page:                                                    | 64                        |                           |                                 |                                 | (. pag                    | ge, 128                   | bytes)                    |                     |                           |                      |                |                            |                           |                                        |                                  |                            |   |
|                            |                                                              |                           |                           |                                 |                                 |                           |                           |                           |                     |                           |                      |                |                            |                           |                                        |                                  |                            |   |
| Latest Cont                | ent Retri                                                    | eved f                    | from [                    | )evice:                         |                                 |                           |                           |                           |                     |                           |                      |                |                            | Sun                       | Oct 12                                 | 13:42:3                          | 4 2014                     |   |
|                            |                                                              |                           |                           |                                 |                                 |                           |                           |                           |                     |                           |                      |                |                            |                           |                                        |                                  |                            |   |
|                            |                                                              | _                         |                           |                                 |                                 | -                         |                           |                           |                     |                           |                      |                |                            |                           |                                        |                                  |                            |   |
| Retrieved Co               | ntent: at P                                                  | age 6                     | 4, 128                    | bytes s                         | starting                        | from a                    | ddress 0                  | )x2000                    |                     |                           |                      |                |                            |                           |                                        |                                  |                            |   |
| Retrieved Co               | ntent: at P                                                  | age 6                     | 4, 128                    | bytes s                         | starting                        | from a                    | ddress 0                  | )x2000                    |                     |                           |                      |                |                            |                           | View D                                 | etailed                          | Status                     | ) |
| Retrieved Co               | ntent: at F                                                  | age 6                     | <b>4</b> , 128            | bytes s                         | starting                        | from a                    | ddress 0                  | )x2000                    |                     |                           |                      |                |                            |                           | View D                                 | etailed                          | Status                     | ] |
|                            |                                                              | age 6                     | <b>i4</b> , 128           | bytes s                         | starting                        | from a                    | ddress 0                  | )x2000                    |                     |                           |                      |                |                            |                           | View D                                 | etailed                          | Status                     | ] |
| Go to Addres               |                                                              | age 6                     | <b>4</b> , 128            | bytes s                         | tarting                         | from a                    | ddress 0                  | )x2000                    |                     |                           | 2                    |                |                            |                           | View D                                 | etailed                          | Status                     | ) |
|                            | ss (hex):                                                    |                           | <b>4</b> , 128            |                                 |                                 |                           |                           | *                         | Cont                |                           |                      |                |                            |                           | *                                      |                                  |                            | ] |
| Go to Addres               | ss (hex):                                                    | 0                         | 1                         | 2                               | 3                               | 4                         | 5                         | 6                         | 7                   | 8                         | 9                    |                | В                          | C                         | D                                      | E                                | F                          |   |
| Go to Addres               | ss (hex):<br>r   Address<br>02000                            | 0                         | 1<br>FF                   | 2                               | 3<br>E2                         | 4<br>AA                   | 5<br>F0                   | 6<br>53                   | 7<br>FF             | 8<br>53                   | FF                   | A<br>55        | E2                         | C AA                      | D<br>F0                                | E<br>53                          | FF                         |   |
| Go to Addres               | ss (hex):                                                    | 0                         | 1                         | 2                               | 3                               | 4                         | 5                         | 6                         | 7                   | 8                         | _                    | A<br>55<br>55  | -                          | C                         | D                                      | E                                | F                          |   |
| Go to Addres               | ss (hex):<br>r   Address<br>02000<br>02010                   | 0<br>53<br>53             | 1<br>FF                   | 2                               | 3<br>E2                         | 4<br>AA                   | 5<br>F0                   | 6<br>53                   | 7<br>FF             | 8<br>53                   | FF                   |                | E2                         | C AA                      | D<br>F0                                | E<br>53                          | FF                         |   |
| Go to Addres               | r   Address<br>02000<br>02010                                | 0<br>53<br>53<br>53       | 1<br>FF<br>FF             | 2<br>55<br>55                   | 3<br>E2<br>E2                   | 4<br>AA<br>AA             | 5<br>F0<br>F0             | 6<br>53<br>53             | 7<br>FF<br>FF       | 8<br>53<br>53             | FF<br>FF             | 55             | E2<br>E2                   | C AA AA                   | D<br>F0<br>F0                          | E<br>53<br>53                    | F<br>FF<br>FF              |   |
| Go to Addres               | ss (hex):<br>r   Address<br>02000<br>02010<br>02020          | 0<br>53<br>53<br>53<br>53 | 1<br>FF<br>FF             | 2<br>55<br>55<br>55             | 3<br>E2<br>E2<br>E2             | 4<br>AA<br>AA<br>AA       | 5<br>F0<br>F0             | 6<br>53<br>53<br>53       | 7<br>FF<br>FF<br>FF | 8<br>53<br>53<br>53       | FF<br>FF<br>FF       | 55<br>55       | E2<br>E2<br>E2             | C<br>AA<br>AA<br>AA       | D<br>F0<br>F0<br>F0                    | <mark>Е</mark><br>53<br>53<br>53 | FF<br>FF<br>FF             |   |
| Go to Addres               | ss (hex):<br>r   Address<br>02000<br>02010<br>02020<br>02030 | 0<br>53<br>53<br>53<br>53 | 1<br>FF<br>FF<br>FF<br>FF | 2<br>55<br>55<br>55<br>55<br>55 | 3<br>E2<br>E2<br>E2<br>E2<br>E2 | 4<br>AA<br>AA<br>AA<br>AA | 5<br>F0<br>F0<br>F0<br>F0 | 6<br>53<br>53<br>53<br>53 | 7<br>FF<br>FF<br>FF | 8<br>53<br>53<br>53<br>53 | FF<br>FF<br>FF<br>FF | 55<br>55<br>55 | E2<br>E2<br>E2<br>E2<br>E2 | С<br>АА<br>АА<br>АА<br>АА | <b>D</b><br>F0<br>F0<br>F0<br>F0<br>F0 | Е<br>53<br>53<br>53<br>53<br>53  | FF<br>FF<br>FF<br>FF<br>00 |   |
| Go to Addres               | ss (hex):<br>r   Address<br>02000<br>02010<br>02020<br>02030 | 0<br>53<br>53<br>53<br>53 | 1<br>FF<br>FF<br>FF<br>FF | 2<br>55<br>55<br>55<br>55<br>55 | 3<br>E2<br>E2<br>E2<br>E2<br>E2 | 4<br>AA<br>AA<br>AA<br>AA | 5<br>F0<br>F0<br>F0<br>F0 | 6<br>53<br>53<br>53<br>53 | 7<br>FF<br>FF<br>FF | 8<br>53<br>53<br>53<br>53 | FF<br>FF<br>FF<br>FF | 55<br>55<br>55 | E2<br>E2<br>E2<br>E2<br>E2 | С<br>АА<br>АА<br>АА<br>АА | <b>D</b><br>F0<br>F0<br>F0<br>F0<br>F0 | Е<br>53<br>53<br>53<br>53<br>53  | FF<br>FF<br>FF<br>00<br>00 |   |

Figure 13 • Flash Memory (eNVM) Content Read from the Device



## Debug FPGA Array

The SmartFusion2 and IGLOO2 devices have built-in probe points that enhance the ability to debug the logic within the device using the Live Probes and Active Probes features. The enhanced debug features implemented in the devices give access to any logic element and enable you to check the state of inputs and outputs in real-time, without re-layout of the design.

In addition to the ability to specify probe points, SmartDebug also provides the capability to read, modify, and write into the fabric SRAM block. This section demonstrates the abilities of setting Live Probes, Active Probes, and reading/writing from/to the fabric SRAM.

The Debug FPGA Array can be accessed from the SmartDebug window, as shown in Figure 10 on page 10. On the **SmartDebug** window, click **Debug FPGA Array** to display the **Debug FPGA Array** window, as shown below in Figure 14.

| GA Array deb | pug data                                                                          |
|--------------|-----------------------------------------------------------------------------------|
| Live Probes  | Active Probes Memory Blocks Probe Insertion                                       |
| Filter:      | Search                                                                            |
|              | Name Type                                                                         |
| :Fabric_Debu | ug_0/DPSRAM_0/Fabric_Debug_DPSRAM_0_DPSRAM_R0C0/INST_RAM1K18_IP:A_DOUT[0] SRAM    |
| :Fabric_Debu | ug_0/DPSRAM_0/Fabric_Debug_DPSRAM_0_DPSRAM_R0C0/INST_RAM1K18_IP;A_DOUT[10] SRAM   |
| :Fabric_Debu | ug_0/DPSRAM_0/Fabric_Debug_DPSRAM_0_DPSRAM_R0C0/INST_RAM1K18_IP;A_DOUT[11] SRAM + |
|              | ChannelA -> Set                                                                   |

Figure 14 • Debug FPAG Array Window

Libero SoC generates the debug file, <projectName>\_debug.txt, during Place-and-Route and stores the file into the <project path>\designer folder. The debug file contains information used by SmartDebug for mapping the user design names to their respective physical addresses on the device. It also contains other information used during the debug process.



The following steps describe how to use the Live Probes, Active Probes, and the Memory Block debugging features:

### 1. Specifying Live Probe Points

With Live Probe, two dedicated probes can be configured to observe a probe point, which is any output of a register. The probe data can be sent to the two dedicated probe pins (PROBE\_A and PROBE\_B). You can connect an oscilloscope to the probe pins and monitor the signals status. The probe points location can be changed without recompiling or reprogramming the design. The probes can capture data at a speed of up to 100 MHz.

The PROBE\_A and PROBE\_B pins are dedicated dual-purpose pins. These pins are regular I/Os, if not used by the Live Probes channels. These pins can be reserved for probing by selecting **Reserve Pins** for **Probes** in the **Project Settings** window, as shown in Figure 15.



#### Figure 15 • Reserving Probe Pin for Probes

In addition, the probe pin on your package can be identified from the pin description document for that particular package. Another option is to check the Function column in the Package Pins tab of the **I/O Editor** in the Libero SoC software, as shown in Figure 16.

Y10 and W10 are the two dedicated probe pins in M2GL010T and M2S090T in the 484 FBGA package, which can be used for probing, as shown in Figure 16.

| Port | ts Package Pir | ns Package Vi | ewer       |                    |        |   |
|------|----------------|---------------|------------|--------------------|--------|---|
|      | Pin Number 💌   | Port Name 💌   | Macro Cell | Function           | Locked | - |
| 381  | AA10           | Unassigned    |            | MSIO122PB4         |        |   |
| 382  | AB10           | Unassigned    |            | MSIO122NB4         |        |   |
| 383  | W10            |               |            | MSIO121PB4/PROBE_A |        | - |
| 384  | Y10            |               |            | MSIO121NB4/PROBE_B |        | - |
| 385  | W9             | Unassigned    |            | MSIO120PB4         |        | - |

#### Figure 16 • Identifying Probe Pins using Package Viewer Inside I/O Editor

Note: The probe pins, PROBE\_A/PROBE\_B, are not exposed and not accessible on the IGLOO2 Evaluation Kit Rev C board. These pins are accessible on the IGLOO2 Evaluation Kit board Rev D and SmartFusion2 M2S090TS Security Evaluation Kit Rev D on J29 and J30 jumpers.

Figure 17 shows an example of setting two probe points: coutA[23]:Q and coutA[24]:Q to be probed on ChannelA and ChannelB respectively. The Live Probes tab shows the probe point name and pin type (SRAM, Logic, or I/O). When a probe point is selected, it can be assigned to either ChannelA (PROBE\_A) or ChannelB (PROBE\_B) as follows:

- 1. Select the point to be probed, as shown in Figure 17.
- 2. Select the channel on which the selected point needs to be probed.
- 3. Select Set.

A message is displayed in the Log window of Libero SoC, showing the signals that are assigned to be probed, as follows:

Live probe has been set:

#### PROBE\_A:

Channel A: Fabric\_Debug\_0/count\_0/coutA[23]:Fabric\_Debug\_0/count\_0/coutA[23]:Q

PROBE\_B:

Channel B: LED1\_c:Fabric\_Debug\_0/count\_0/coutA[24]:Q.

After setting the channels, SmartDebug configures the ChannelA and ChannelB I/Os to monitor the desired probe points. On the SmartFusion and IGLOO2 Evaluation Kit Rev D boards, the PROBE\_A and PROBE\_B pins are exposed on the J29 and J30 connectors. An oscilloscope can be connected to these probe points to monitor the signals that are assigned to be probed. The maximum number of simultaneous probes is two internal signals. A filter box is provided to filter out the Net Names.

Note: The Active Probes WRITE overwrites the settings of the Live Probe channels, if any.

| -       | y Debug Data       | pebag_ar (aesigner (sin | artDebug_top\Smart | .Debug_top_debug | i.txt Browse. |  |
|---------|--------------------|-------------------------|--------------------|------------------|---------------|--|
| Live Pr | bes Active Pro     | bes Memory Block        | s Probe Insertio   | n                |               |  |
| Filter  | couta[24]          |                         |                    |                  | Search        |  |
|         |                    |                         | _ Name             |                  |               |  |
| LED1_   | ::Fabric_Debug_0/o | count_0/coutA[24]:Q     |                    |                  |               |  |
|         |                    |                         | C                  |                  |               |  |
| •       |                    |                         |                    |                  | 4             |  |
|         | Cha                | nnelA -> _0/co          | unt_0/coutA[23]:Q  | Set              |               |  |
|         | Cha                | nnelB -> _0/co          | unt_0/coutA[24]:Q  | Set              |               |  |
|         |                    |                         |                    |                  |               |  |

Figure 17 • Live Probes Channels Assignments



### 2. Active Probes

Active Probe allows dynamic asynchronous read and write to a flip-flop or probe point. It enables you to observe the output of the logic internally or to experiment on how the logic is affected by writing to a probe point. The following steps describe how to select a specific set of probe pins by reading the current value and then writing different values.

#### Selecting Active Probes

- 1. On the **Debug FPGA Array** window, click the **Active Probes** tab.
- 2. Click Add/Remove Active Probes to select the internal points to monitor, as shown in Figure 18.

| e Probes Active Probes | Memory Blocks Probe Insertion |      | $\square$ |
|------------------------|-------------------------------|------|-----------|
|                        | Name                          | Туре | Value     |
| Read Active Probes     |                               | 0    |           |
| Write Active Probes    |                               |      |           |

Figure 18 • Selecting Active Probes From the Design

A window that shows all the available probe points in the design opens. In this tutorial, the following points are monitored:

• Three bits of the counter output coutA.

The monitoring signal error, which is also connected to the LED (H5) on the board. If the LED is ON, it indicates that the RAM count and the expected value mismatch.

To find these points in the list of available probe points, use the Filter control, as shown in Figure 19 on page 17.

Note: As Active Probe only deals with individual signals, the coutA bus segment is broken up into three separate probe lines.



3. Select the desired points and click **Add** to move to the **Selected Probe Points** window and click **OK**, as shown in Figure 19.

| Available probe points                                          |       |               | Selected probe points                      |        |
|-----------------------------------------------------------------|-------|---------------|--------------------------------------------|--------|
| Filter: cout Search                                             | .1    |               | Filter:                                    | Search |
| Name                                                            | Τ) ^  |               | Name                                       | Тур    |
| Fabric_Debug_0/coutB_net_0[4]:Fabric_Debug_0/count_0/coutB[4]:Q | Lo    |               | LED1_c:Fabric_Debug_0/count_0/coutA[24]:Q  | Logi   |
| Fabric_Debug_0/coutB_net_0[5]:Fabric_Debug_0/count_0/coutB[5]:Q | Lo    | Add All ->    | LED2_c:Fabric_Debug_0/count_0/coutA[25]:Q  | Logi   |
| Fabric_Debug_0/cout8_net_0[6]:Fabric_Debug_0/count_0/cout8[6]:Q | Lc    | Add ->        | LED3_c:Fabric_Debug_0/count_0/coutA[26]:Q  | Logi   |
| Fabric_Debug_0/coutB_net_0[7]:Fabric_Debug_0/count_0/coutB[7]:Q | Lo    | <- Remove     | error_c:Fabric_Debug_0/count_chk_0/error:Q | Logi   |
| LED1_c:Fabric_Debug_0/count_0/coutA[24]:Q                       | Lo    | <- Remove All |                                            |        |
| LED2_c:Fabric_Debug_0/count_0/coutA[25];Q                       | Le    |               |                                            |        |
| LED3_c:Fabric_Debug_0/count_0/coutA[26]:Q                       | Logic | ]             |                                            |        |
| < III                                                           | •     |               | <                                          | ,      |

Figure 19 • Selecting Desired Points to Read

#### **Reading Active Probes**

After specifying all the points to probe, click **Read Active Probes** to get the current values of the internal signals. Figure 20 shows the results of a first read of the design.

| PGA Array debug data Live Probes Active Probes | Memory Blocks Probe Insertion              |       |           |
|------------------------------------------------|--------------------------------------------|-------|-----------|
|                                                | Name                                       | Туре  | Value     |
| Add/Remove Active Probes.                      | LED1_c:Fabric_Debug_0/count_0/coutA[24]:Q  | Logic | High 🔿 ้ไ |
|                                                | LED2_c:Fabric_Debug_0/count_0/coutA[25]:Q  | Logic | Low O T   |
| Read Active Probes                             | LED3_c:Fabric_Debug_0/count_0/coutA[26]:Q  | Logic | Low O T   |
| Write Active Probes                            | error_c:Fabric_Debug_0/count_chk_0/error:Q | Logic | High 🗘 ้ไ |
|                                                |                                            |       |           |

#### Figure 20 • Active Probe Readings

Note: To toggle the states between High and Low, click  $^{\odot}$  , and to reset the value, click  $^{\uparrow}$  .



The coutA bus counts constantly, therefore, the value that you read may be different from the value shown in Figure 20.

Also, the error signal must be **High (LED H5 is OFF)**, indicating that there are no errors in the counting pattern.

#### 3. Fabric SRAM Memory Debug

To view the content of the Large SRAM in this design, click the **Memory Blocks** tab, as shown in Figure 21.

|           |                     | SmartDebug_Tutorial\m | 12s_SmartDebug_df\de | signer\SmartDebug_top\ | SmartDebug_top_debug.txt |       |
|-----------|---------------------|-----------------------|----------------------|------------------------|--------------------------|-------|
| Live Prob | es Active Probes    | Memory Blocks         | Probe Insertion      |                        |                          |       |
|           | ebug_0/DPSRAM_0/Fal | pric_Debug_DPSRAM_0   | _DPSRAM_R0C0/INST_   | RAM1K18_IP             | Read Block Write B       | Block |
|           |                     |                       |                      | .0                     |                          |       |
|           |                     |                       |                      |                        |                          |       |
| Help      |                     |                       |                      |                        |                          | Close |

Figure 21 • Memory Blocks Tab

18

3

This design contains a single Large SRAM, named DPSRAM\_0, and it is the only one available in the drop-down list. Select the RAM block and click **Read Block**.



The contents of the DPSRAM\_0 is displayed, as shown in Figure 22. See the counting pattern that is loaded into the RAM.



Figure 22 • DPSRAM\_0 Contents

## Writing to Fabric SRAM Blocks

The design reads the contents of the DPSRAM and compares it with a synchronized counter in the checker, which looks for errors. If the content of the DPSRAM is modified, it breaks the count pattern and causes an error in the checker.

The following steps describe how to modify the RAM content and force an error:

- 1. Read the memory content, as shown in Figure 22.
- 2. Select an entry and double-click. Each entry is 9-bits wide.
- 3. Modify the value from the current value to break the count pattern. An example is shown in Figure 23.
- Note: The counter writes to the SRAM constantly. To prevent the overwrite of the changes that are forced into the SRAM, the writing is stopped by forcing A\_WEN LOW through Switch2 (SW2). This drives a SELECT of a mux that selects between High and Low inputs. When SW2 is pressed, A\_WEN becomes low, which prevents any write from the counter to the SRAM block.
  - 4. Press and hold SW2 and click **Write Block** to write the modified value to the SRAM.
    - The error LED(H5) light turns ON, indicating an error in the counting pattern.
  - 5. Release SW2 to resume the write operation from the counter to the SRAM.



This overwrites the error that was injected into the SRAM. The content of the SRAM can be rechecked by clicking **Read Block**.



Figure 23 • Modifying DPSRAM Contents

### **Probe Insertion**

Probe insertion is a post-layout process that enables you to insert probes into the design and bring signals out to the FPGA package pins to evaluate and debug the design. Probe insertion enables you to select internal nets anywhere in the design, connect those nets to unused pins, and then run layout incrementally to manage the physical connection to the pin. Nets are selected and assigned using the SmartDebug Probe Insertion feature. For more information, refer to the *FPGA On-Chip Debug Tools*.



The following steps describe how to probe a net:

1. On the **Debug FPGA Array** window, click the **Probe Insertion** tab and click **Add Probe**, as shown in Figure 24.

| Debug FPGA Ar<br>Debug File: Smar<br>FPGA Array Debu | tDebug_df\designer\SmartDeb | ug_top\\$martDebug_top_det   | bug.txt Browse |
|------------------------------------------------------|-----------------------------|------------------------------|----------------|
| Live Probes                                          | Active Probes Memory B      | ocks Probe Insertion         |                |
| Probes                                               | Add Probe                   | Edit Probe Delete            | Delete All     |
|                                                      | Net                         | Driver                       | Packag         |
| •                                                    | III<br>Insert F             | Probe(s) and Program the dev | ice Run        |
| Help                                                 |                             |                              | Close          |

Figure 24 • Probe Insertion Tab and Add Probe Option

In the Net Name field, enter the \*couta\* signal, as shown in Figure 25. Select signal Fabric\_Debug\_0/count\_0/coutA\_s[24]. The goal is to add a probe by routing the counter bit 24 signal out into the E1 LED and check if it toggles.

| lter net(s) by:                                         | Sele | ct a Net(s) for the Probe            |                             |
|---------------------------------------------------------|------|--------------------------------------|-----------------------------|
| Name Instances                                          |      | Net                                  | Driver                      |
|                                                         | 43   | Fabric_Debug_0/count_0/coutA_s[20]   | Fabric_Debug_0/count_0/cout |
| Enter below a regular expression that name should match | 44   | Fabric_Debug_0/count_0/coutA[21]     | Fabric_Debug_0/count_0/cout |
| Enter below a regular expression that name should match | 45   | Fabric_Debug_0/count_0/coutA_s[21]   | Fabric_Debug_0/count_0/cout |
|                                                         | 46   | Fabric_Debug_0/count_0/coutA[22]     | Fabric_Debug_0/count_0/cout |
| Net nam:: *couta*                                       | 47   | Fabric_Debug_0/count_0/coutA_s[22]   | Fabric_Debug_0/count_0/cout |
|                                                         | 48   | Fabric_Debug_0/count_0/coutA[23]     | Fabric_Debug_0/count_0/cout |
|                                                         | 40   | Fabric_Debug_0/count_0/cout4_s[23]   | Eabric_Debug_0/count_0/cout |
|                                                         | 50   | Fabric_Debug_0/count_0/coutA_s[24]   | Fabric_Debug_0/count_0/cout |
|                                                         | 51   | Fabric_Debug_0/count_0/coutA_s[25]   | Fabric_Debug_0/count_0/cout |
|                                                         | 52   | Fabric_Debug_0/count_0/coutA_s[26]   | Fabric_Debug_0/count_0/cout |
|                                                         | 53   | Fabric_Debug_0/count_0/coutA_qxu[1]  | Fabric_Debug_0/count_0/cout |
|                                                         | 54   | Fabric_Debug_0/count_0/coutA_fast[0] | Fabric_Debug_0/count_0/cout |

Figure 25 • Adding a Net to Probe



- 3. Click OK.
- 4. In the Probe Insertion window, assign Package Pin E1, as shown in Figure 26.

| Live Probes  | Active Probes      | Memory Blocks  | Probe Insertion           | Edit Probe  | Delete Delete All |
|--------------|--------------------|----------------|---------------------------|-------------|-------------------|
| Probes       | Net                |                | Driver                    | Package Pin | Delete Delete All |
| Fabric_Debug | _0/count_0/coutA_s | [24] Fabric_De | bug_0/count_0/coutA_cry[: | 2. E1 🔻     | Probe_Insert0     |
|              |                    |                |                           |             | Ø                 |

Figure 26 • Assigning Package Pin and Running the Flow

5. Click Run.

The place and route tool is run incrementally in the background re-routing the coutA\_s[24] signal to package pin E1, which is the LED on the board. The LED E1 on the board starts toggling when the incremental place and route is completed, which indicates that the counter output bit[24] is routed to the E1 package pin.

6. Click Close to exit the Debug FPGA Array window.



## SERDES Debug

This SmartDebug SERDES tutorial helps the FPGA and board designers to perform SERDES real-time signal integrity testing and tuning in a system that:

- · Provides real-time access to SERDESIF block control and status registers
- Provides testing functions with pseudo-random binary sequence (PRBS) or constant pattern generators and checkers
- Runs link tests with various loop back options
- Provides overview for tuning many combinations of physical medium attachment (PMA) analog settings to find the optimal set for a SERDES channel

The following steps describe how to perform SERDES debug:

1. On the SmartDebug window, click Debug SERDES, as shown in Figure 27.

| 😵 SmartDebug                                                         |                                       | - • ×        |  |
|----------------------------------------------------------------------|---------------------------------------|--------------|--|
| <u>File V</u> iew <u>H</u> elp                                       |                                       |              |  |
| Device: M2S090T (M2S090T)                                            | <ul> <li>Programmer: 75705</li> </ul> | (usb75705)   |  |
| ID code read from device 1F80710                                     | F                                     | $\mathbf{O}$ |  |
| View Device Status                                                   | Debug                                 | g FPGA Array |  |
| View Flash Memory Content                                            | Deb                                   | ug SERDES    |  |
|                                                                      | 6                                     |              |  |
| og                                                                   |                                       | ₽×           |  |
| 🔳 Messages 😣 Errors 🗼 Warnings                                       | 🕕 Info                                |              |  |
| The Execute Script command succe<br>spn flashpro, run programming ac | eded.                                 | <b>^</b>     |  |
| The 'prbi' command succeeded.<br>The Execute Script command succe    | eded.                                 | -            |  |
|                                                                      |                                       |              |  |

Figure 27 • Debug SERDES Operation Selection





The Configuration tab is displayed as shown in Figure 28. The **Configuration** tab auto-identifies and populates SERDESIF and the lanes used in the design. The status of each lane and the programmed lane mode are displayed. This example demonstrates the use of SERDESIF\_0 block and the lock status of TxPLL and RxCDR.

2. Click **Refresh Report**, to update the data.

| Debug SERDES                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | ? 💌            |
|----------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| Debug SERDES<br>Configuration<br>Tests<br>PRBS Test<br>Loopback Test | SERDES Block: SERDESIF_0  Configuration Report: Serdes Block SERDESIF_0 : Lane 00 : Lane mode : EPCS (custom) PMA Ready : True TXPLL status : Locked Lane 1: Lane mode : EPCS (custom) PMA Ready : True TXPLL status : Locked RxCDR status : Locked Lane 2: Lane mode : EPCS (custom) PMA Ready : True TXPLL status : Locked Lane 3: Lane mode : EPCS (custom) PMA Ready : True TXPLL status : Locked Lane 3: Lane mode : EPCS (custom) PMA Ready : True TXPLL status : Locked Lane 3: Lane mode : EPCS (custom) PMA Ready : True TXPLL status : Locked RxCDR status : Locked Lane 3: Lane mode : EPCS (custom) PMA Ready : True TXPLL status : Locked RxCDR status : Locked | Refresh Report |
|                                                                      | SERDES Register Read or Write:<br>Script:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Execute        |
| Help                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Close          |

Figure 28 • SERDES Configuration Tab

5



3. The **PRBS Test** tab provides several capabilities for each lane of the SERDES block. Based on the selected SERDES lane, information is provided for each channel. For example, select **Lane 0**, **Near-end Serial Loopback**, **PRBS7**, and click **Start**, as shown in Figure 29.

This test generates and checks PRBS7 data without going off-chip. The green LEDs indicate the lock status of TxPLL and RxCDR for the selected lane.

| Ø Debug SERDES                |                                                                          | ? ×   |
|-------------------------------|--------------------------------------------------------------------------|-------|
|                               | SERDES Block: SERDESIF_0                                                 |       |
| Debug SERDES                  | SERDES Lanes: 💿 Lane 0 🔘 Lane 1 🔘 Lane 2 🔘 Lane 3                        | _     |
| Configuration Tests PRBS Test | Lane 0 status: RxCDR TxPLL                                               |       |
| Loopback Test                 | Near End Serial Loopback (On-Die)     Serial Data (Off-Die)     Pattern: | Start |
|                               | PRBS7     PRBS11     PRBS11                                              | Stop  |
|                               | <ul> <li>PRBS 23</li> <li>PRBS 31</li> </ul>                             |       |
| 4 III >                       | Error Count:<br>0 Reset                                                  |       |
| -                             |                                                                          | Close |
| Help                          |                                                                          | Liose |

#### Figure 29 • SERDES Test Tab

In this example setup, the data stream is expected to have zero errors as the datapath does not go off-chip while using the Near-end Serial Loopback as shown in Figure 30.

| ĺ | Debug SERDES                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | ? ×           |
|---|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| C | SERDES Block:       SERDESIF_0          Debug SERDES       SERDES Lanes:       Iane 0       Lane 1       Lane 2       Lane 3         Configuration       Iane 0 status:       RxCDR       TxPLL       Image: Tests         PRBS Test       Image: | Start<br>Stop |
|   | <pre>Error Count:</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Close         |

#### Figure 30 • SERDES Link Status

Note: Lane 0 is the PCIe<sup>®</sup> lane. This lane is connected to the PCIe edge fingers of the Evaluation board.



4. Click **Stop** and select **Serial Data (Off-Die)**. Click **Start** and observe the Lane 0 error counter, as shown in Figure 31. The error count increments up to 255, as the data is no longer looping between Tx and Rx and Lane 0 is not looped together on the PCB.

|                            | SERDES Block: SERDESIF_0 V                                  |       |
|----------------------------|-------------------------------------------------------------|-------|
| ebug SERDES                | SERDES Lanes:                                               |       |
| Configuration              | Lane 0 status: RxCDR 🔵 🛛 TxPLL 🔵                            |       |
| Tests                      | Test Type:                                                  |       |
| PRBS Test<br>Loopback Test | Near End Serial Loopback (On-Die)     Serial Data (Off-Die) |       |
| coopback lest              | Pattern:                                                    |       |
|                            |                                                             | Start |
|                            | PRBS7                                                       |       |
|                            | PRBS11                                                      | Stop  |
|                            | PRBS 23                                                     |       |
|                            | PRBS 31                                                     |       |
|                            |                                                             |       |
|                            | Error Count:                                                |       |
|                            | 255 Reset                                                   |       |
|                            |                                                             |       |
|                            |                                                             |       |

#### Figure 31 • Sending Serial Tx Data Off-Die

- 5. The Evaluation Kit board connects Lane 1 on the PCB to loop back Tx and Rx. This loopback demonstrates a complete path with data transmitted and received. For example, select Lane 1, Serial Data (Off-Die), PRBS7, and click Start, as shown in Figure 32.
  - This test generates and checks PRBS7 data going off-chip and folded back on the PCB to the receiver.

| Debug SERDES                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | ? ×           |
|----------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| Debug SERDES<br>Configuration<br>Tests<br>PRBS Test<br>Loopback Test | SERDES Block: SERDESIF_0   SERDES Lanes: Lane 0 Lane 1 Lane 2 Lane 3 Lane 1 status: RxCDR TXPLL   Test Type: Near End Serial Loopback (On-Die) Serial Data (Off-Die) Pattern: PRBS7 PRBS11 PRBS 23 PRBS 31 Error Count: Cou | Start<br>Stop |
| Help                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Close         |

Figure 32 • Lane 1 Transmitting Data Through On-Board Loopback



6. The Tx and Rx channels of Lane 2 can be interconnected in a loopback configuration using coaxial cables. In this example, as shown in Figure 33 and Figure 34, after connecting a pair of high-quality 50 Ω SMA cables to the SMA connections on the Evaluation Kit board, SERDES debug can be used to send data off-board and check for errors. Select Lane 2, Serial Data (Off-Die), PRBS7, and click Start.

| SERDES Block:       SERDES Lanes:         Lane 2 status:       RxCDR         Test       PRBS Test         Loopback Test       Near End Serial Loopback (On-Die)         PRBS 11       PRBS 13         PRBS 31       Forr Count:         Image: Test Cable Loopback       Cone                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Debug SERDES      |                            | ? ×   |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|----------------------------|-------|
| Configuration   Tests   PRBS Test   Loopback Test     Near End Serial Loopback (On-Die)     PRBS 7   PRBS 11   PRBS 31        Error Count:     Immediate     Tople     Help     Configuration                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                   | SERDES Block: SERDESIF_0 V |       |
| Configuration   Tests   PRBS Test   Loopback Test     Near End Serial Loopback (On-Die)     PRBS 7   PRBS 11   PRBS 31        Error Count:     Immediate     Tople     Help     Configuration                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                   |                            |       |
| <pre>     Tests     PRBS Test     Loopback Test     PRBS7     PRBS11     PRBS 23     PRBS 31     Error Count:</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                   |                            |       |
| Image: Near End Serial Loopback (On-Die)     Pattern:     Image: Image |                   |                            |       |
| Pattern:   Image: PRBS7   PRBS11   PRBS 23   PRBS 31                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                   |                            |       |
| Image: start     Image: start   Image: start   Image: start   Image: start   Image: start   Image: start   Image: start   Image: start   Image: start   Image: start   Image: start   Image: start   Image: start   Image: start   Image: start   Image: start   Image: start   Image: start   Image: start                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | LOODDACK lest     |                            |       |
| PRBS/<br>PRBS11<br>PRBS 23<br>PRBS 31<br>Error Count:<br>Reset<br>Help<br>Close                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                   |                            | Start |
| PRBS 23<br>PRBS 31<br>Error Count:<br>0 Reset<br>Help<br>Close                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                   |                            |       |
| PRBS 31<br>Error Count:<br>D Reset<br>Help<br>Close                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                   |                            | Stop  |
| Error Count:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                   |                            |       |
| Help Close                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                   | O PRUS SI                  |       |
| Help Close                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                   |                            |       |
| Help Close                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                   | 0 Reset                    |       |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                   |                            |       |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Halp              |                            | Class |
| ternal Cable Loopback                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | пер               |                            | Close |
| kternal Cable Loopback                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                   |                            |       |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | ternal Cable Loop | back                       |       |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | ternal Cable Loop | back                       |       |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | ternal Cable Loop | back                       |       |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | ternal Cable Loop | Jback                      |       |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | ternal Cable Loop | back                       |       |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                   | back                       |       |





Figure 34 • Evaluation Kit Board with External Coax Loopback Setup



- 7. The Lane 2 SMA test connections can be used for interconnecting with high-speed coaxial cables to test equipment or other test fixtures like test backplanes. In the example shown in Figure 35, when the Lane 2 test is started without any means to connect the Tx and Rx together, the Error Count increments as the link is broken between the pattern generator and the checker. This setup sends a data pattern of the board for analysis on the test equipment.
- Note: SMA Male-to-SMA Male Precision Cables, such as Pasternack Industries part number PE39429-12 (or equivalent), are recommended.

|                                              | SERDES Block: SERDESIF_0 -                                                           |
|----------------------------------------------|--------------------------------------------------------------------------------------|
| Debug SERDES                                 | SERDES Lanes: C Lane 0 Lane 1 C Lane 2 Lane 3                                        |
| Configuration                                | Lane 2 status: RxCDR  TxPLL                                                          |
| <ul> <li>Tests</li> <li>PRBS Test</li> </ul> | Test Type:                                                                           |
| Loopback Test                                | <ul> <li>Near End Serial Loopback (On-Die)</li> <li>Serial Data (Off-Die)</li> </ul> |
|                                              | Pattern:                                                                             |
|                                              | PRBS7                                                                                |
|                                              | O PRBS11 Stop                                                                        |
|                                              | O PRBS 23                                                                            |
|                                              | © PRBS 31                                                                            |
|                                              |                                                                                      |
|                                              | Error Count:                                                                         |
|                                              | 255 Reset                                                                            |
| 4 III +                                      |                                                                                      |
|                                              |                                                                                      |

Figure 35 • Lane 2 Transmitting Data Off-Board

3





Figure 36 • Connecting Lane 2 to the Test Equipment

Several test patterns are available from the test pattern generator. PRBS7 is a very typical pattern for testing signal integrity in communication applications.

Bit error rate (BER) is the count of the number of errors over time to provide a level of confidence for a high-speed link. For a 2.5 Gbps test, it takes about three minutes with zero errors to achieve a BER of 10e-12. The SmartDebug SERDES provides an error counter that can be used for BER test.

An online calculator can determine how long to run a pattern test based on the target BER.

## Far-End Loop Back Support

Far-end loopback is supported from the **Loopback Test** tab. From this tab, you can receive data from a far-end source and fold the received data (Rx) back out of the transmitter (Tx).

In the example shown in Figure 37 on page 31 and Figure 38 on page 32, by using the Evaluation Kit board, data is received from a far-end transmit source, such as a device or test equipment. It is received into Lane 2 and looped back out of the transmitter.

This is performed by selecting SERDES Lane 2, PCS Far End PMS Rx to Tx Loopback Test Type, and clicking Start.

Data entering the SMA connectors on Lane 2 of the Evaluation Kit board is observed coming off the board on the Tx SMA connectors.

Note: In this test, the IGLOO2 Evaluation board or SmartFusion2 Evaluation Kit board must use the same SERDES reference clock as the far-end. The datapath through the SERDEIF goes through the CDR and reclocks the data to the local REFCLK. This requires 0 ppm difference between the farend clock source and the Evaluation Kit clock source. For this, use the SMA inputs (designators J17 and J21) of the board as the input for the SERDES REFCLK.



Figure 37 • PCS Far-End Rx to Tx Loopback





## **Tcl Support**

The SERDES Debug tool set permits execution of Tcl scripts. This allows customized writes and reads of the entire SERDES register base. Tcl can be used to update or check status of the SERDES system, PCle system, and SERDES lane registers.

#### Tcl command syntax is:

read\_register -addr <RegisterAddress >
write register -addr <RegisterAddress> -value <RegisterValue>

where RegisterAddress is 8 hex character (with optional 0x prefix) example: 0x4002200C

RegisterValue is 1-8 hex character (with optional 0x prefix) example: 0x1, 0x1F

#### Example:

```
read_register -addr 0x4002200C
write register -addr 0x4002E008 -value 0x3
```

#### Address for the SERDES blocks are as follows:

| SERDESIF 0 | 0x40028000 - 0x4002A3FF                |
|------------|----------------------------------------|
| SERDESIF_1 | 0x4002C000 - 0x4002E3FF                |
| SERDESIF_2 | 0x40030000 - 0x400323FF                |
| serdesif_3 | 0x40034000 - 0x400 <mark>36</mark> 3FF |

Within each SERDES block, the memory map is as follows:

Name – Offset from the base address (example, for SERDESIF 0 the base address is 0x40028000).

| PCIe Core register map | PCle | Core | register | map |
|------------------------|------|------|----------|-----|
|------------------------|------|------|----------|-----|

- Lane 0 registers
- Lane 1 registers
- Lane 2 registers
- Lane 3 registers
- Lane 5 registers

SERDESIF system register map

0x1000 – 0x13FF 0x1400 – 0x17FF 0x1800 – 0x18FF 0x1C00 – 0x1FFF 0x2000 – 0x23FF

 $0 \times 0000 - 0 \times 0FFF$ 

#### Example Tcl applications:

- To access the Tx Impedance Ratio register for lane 2 in SERDESIF\_1, the address is 0x4002C000 (SERDESIF\_1 base) + 0x1800 (lane 2 offset) + 0x0C (register offset) = 0x4002D80C
- 2. To access the PRBS Control register for lane 0 in SERDESIF\_0, the address is 0x40028000 (SERDESIF\_0 base) + 0x1000 (lane 0 offset) + 0x190 (register offset) = 0x40029190

For register map details, refer to the UG0447: IGLOO2 and SmartFusion2 High Speed Serial Interfaces User Guide.

Read only the lanes that are programmed by the design. Also, read the PCIe registers only if any of the lanes have PCIe protocol.

#### Example:

The Tcl script below is used to alter the TX\_PST (Transmit Post Emphasis) setting of Lane 0 of SERDESIF 0.

```
# Serdes block 0
# Set the config_phy_mode_1 value by separately running the following Tcl command "" in
separate script and write the value without '0x' prefix
set config_phy_mode_1 80f
# set config_phy_mode_1
scan $config_phy_mode_1 %x phyModelVal
```

```
# set CONFIG_REG_LANE_SEL for this lane
```



```
set lane0PhyMode [expr { ($phyModelVal & 255) | 256 }]
scan [format %x $lane0PhyMode] %s lane0PhyMode
write_register -addr 0x4002a028 -val $lane0PhyMode
puts "Serdes lane0 registers"
write_register -addr 0x40029028 -val 0x1a
puts "TX_PST_RATIO"
read_register -addr 0x40029028
#Reset the config_phy_mode_1 value to original value
```

#Reset the config\_phy\_mode\_1 value to original value write\_register -addr 0x4002a028 -val \$config\_phy\_mode\_1

The value of the CONFIG\_PHY\_MODE\_1 register must be known in the example shown above. This register contains the value of the CONFIG\_REG\_LANE\_SEL, which defines the lanes accessed in the design. In this example, reading the CONFIG\_PHY\_MODE\_1 register and passing its value and the associated offset targets the correct lane.

Note: Some SERDES PMA register settings are updated only after the assertion of a PHY\_RESET or writing to the UPDATE\_SETTINGS register.

Tcl commands and syntax are found in the SmartFusion2 and IGLOO2 FPGAs Tcl for SoC – Tcl Documentation.

From the **Debug SERDES Configuration** tab, an executable Tcl script can be imported. Browse to the Tcl script file and click **Execute**, as shown in Figure 39. The script contains commands to write or read registers using a flattened top for most address mapping.

|                           | SERDES Block SERDESIF_0                        |                                    |
|---------------------------|------------------------------------------------|------------------------------------|
|                           |                                                |                                    |
| -                         |                                                |                                    |
|                           | Configuration Report:                          |                                    |
| Debug SERDES              |                                                |                                    |
| Configuration             |                                                | <ul> <li>Refresh Report</li> </ul> |
| <ul> <li>Tests</li> </ul> | Serdes Block SERDESIF_0 :<br>Lane 0 :          |                                    |
| PRBS Test                 | Lane mode : EPCS (2.5 GHz)                     |                                    |
| Loopback Test             | PMA Ready : True                               |                                    |
|                           | TxPLL status : Locked                          | =                                  |
|                           | RxCDR status : Locked                          |                                    |
|                           | Lane 1:                                        |                                    |
|                           | Lane mode : EPCS (2.5 GHz)<br>PMA Ready : True |                                    |
|                           | TxPLL status : Locked                          |                                    |
|                           | RxCDR status : Locked                          |                                    |
|                           | Lane 2 :                                       |                                    |
|                           | Lane mode : EPCS (2.5 GHz)                     |                                    |
|                           | PMA Ready : True                               |                                    |
|                           | TxPLL status : Locked<br>RxCDR status : Locked | +                                  |
|                           | RXCDR STATUS : LOCKED                          |                                    |
|                           |                                                |                                    |
|                           | SERDES Register Read or Write:                 |                                    |
|                           |                                                |                                    |
|                           | Script: C:/Work/serdes0_config.tcl             | Execute                            |
|                           |                                                |                                    |
|                           |                                                |                                    |
|                           |                                                |                                    |
| -                         |                                                |                                    |
| Help                      |                                                | Close                              |
| HelD                      |                                                | Close                              |

Figure 39 • Tcl Script Execution User Interface



After execution of the Tcl SERDES access, the log of the access is displayed in the SmartDebug Console Log pane, as shown in Figure 40.



#### Figure 40 • SERDES Access Log

Refer to "Appendix" on page 38 for more Tcl examples.

## Executing SERDES Debug from SmartDebug Tcl

#### PRBS:

User-level command: Used in PRBS test to start, stop, reset the error counter, and read the error counter value.

prbs\_test [-deviceName <device\_name>] -start -serdes <num> -lane <num> [-near] -pattern
<PatternType> [-value <PatternValue>]
prbs test [-deviceName <device name>] -stop -serdes <num> -lane <num>

prbs\_test [-deviceName <device\_name>] -reset\_counter -serdes <num> -lane <num>

prbs\_test [-deviceName <device\_name>] -read\_counter -serdes <num> -lane <num>

-deviceName <device\_name>: Parameter is optional, if only one device is available in the current configuration or set for debug (see the SmartDebug User Guide, for details).

-start: To start PRBS test.

-stop: To stop PRBS test.

-reset\_counter: To reset the PRBS error count value to 0.

-read\_counter: To read and print the error count value.

-serdes <num>: SERDES block number. Must be between 0 and 4 and varies between dies.

-lane <num>: SERDES lane number. Must be between 0 and 4.



-near: Corresponds to near-end (on-die) option for PRBS test. Not specifying this option implies off-die.

-pattern <PatternType>: The pattern sequence to be used for the PRBS test. It can be one of the following:

- 1. prbs7 or prbs11 or prbs23 or prbs31
- 2. custom
- 3. user

-value <*PatternValue*>: Specifies the pattern type value for cases other than PRBS\* sequences. It can be one of the following:

- If custom is selected above, then it must be one of all\_zeros, all\_ones, alternated, or dual\_alternated.
- 2. If user is selected above, then it must be 20 hexadecimal characters.

#### Example:

```
prbs_test -start -serdes 1 -lane 0 -near -pattern prbs11
prbs_test -start -serdes 2 -lane 2 -pattern custom -value all_zeros
prbs_test -start -serdes 0 -lane 1 -near -pattern user value 0x0123456789ABCDEF0123
```

#### Loopback:

User level command: Used to start and stop the loopback tests.

```
loopback_test [-deviceName <device_name>] -start -serdes <num> -lane <num> -type
<LoopbackType>
```

loopback\_test [-deviceName <device\_name>] -stop -serdes <num> -lane <num>

- deviceName < device\_name>: Parameter is optional, if only one device is available in the current configuration or set for debug (see the SmartDebug User Guide, for details).
- start: To start loopback test.
- stop: To stop loopback test.
- serdes < num>: SERDES block number. Must be between 0 and 4 and varies between dies.
- **lane** <*num*>: SERDES lane number. Must be between 0 and 4.
- type <LoopbackType>: Specifies the loopback test type. Must be one of the following:
- 1. plesio (PCS Far End PMA Rx to Tx Loopback)
- 2. parallel
- 3. meso (PCS Far End PMA Rx to Tx Loopback)

#### Example:

```
loopback_test -start -serdes 1 -lane 1 -type meso
loopback_test -start -serdes 0 -lane 0 -type plesio
loopback_test -start -serdes 1 -lane 2 -type parallel
loopback_test -stop -serdes 1 -lane 2
```

Tcl scripting for SERDES SmartDebug can be used in batch mode without launching SmartDebug. The following is an example batch script:

```
open_project -project {D:/my_serdes_design/my_serdes.pro}
set_debug_device -name {M2S/M2GL050(T|S|TS)}
read_id_code
set_programming_file -name {M2S/M2GL050(T|S|TS)} -file
{./SERDES1_REFCLK1_EPCS_MODE_SF2_DEV_KIT/SERDES1_REFCLK1_EPCS_MODE/designer/SERDES_LOO
PBACK_top/export/SERDES_LOOPBACK_top.stp}
run_selected_actions
set_debug_device -name {M2S/M2GL050(T|S|TS)}
//Place serdes tcl commands after here
```

## Conclusion

This tutorial demonstrated the capabilities of SmartDebug. SmartDebug provides the capabilities to observe and analyze many embedded device features. LiveProbe gives real-time access to device test points and internal logic states can be easily accessed using ActiveProbes. The SmartDebug SERDES utility assists FPGA and board designers to validate signal integrity of high-speed serial links in a system and improve board bring-up time. This is completed in real-time without any design modifications. Adjustments and tuning the PMA analog settings for optimal link performance is easily accomplished to match the design to the system. Using the SmartDebug utility with the Evaluation Kit board provides designers a good understanding of its features and capabilities.



## Appendix

## **Tcl Script Examples**

# Example 1: Change M/N/F registers for Lane1 and Lane2 of SERDESIF 0

# set CONFIG REG LANE SEL write\_register -addr 0x4002a028 -val 20F read register -addr 0x4002a028 write\_register -addr 0x40029410 -val 0x0 puts "PLL F PCLK RATIO Lane1" write register -addr 0x40029414 -val 0x13 puts "PLL M N Lane1" write\_register -addr 0x40029600 -val 0x1 puts "UPDATE\_SETTINGS\_Lane1" puts "Serdes lane1 registers" # set CONFIG REG LANE SEL write register -addr 0x4002a028 -val 40F write register -addr 0x40029810 -val 0x0 puts "PLL F PCLK RATIO Lane2" write register -addr 0x40029814 -val 0x13 puts "PLL M N Lane2" write\_register -addr 0x40029a00 -val 0x1 puts "UPDATE SETTINGS Lane2" puts "Serdes lane2 registers" Example 2: Change RX LEQ registers Lane2 of SERDESIF 0 # set CONFIG REG LANE SEL write register -addr 0x4002a028 -val 40F write register -addr 0x4002981c -val 0x00 puts "RE AMP RATIO Lane2" write\_register -addr 0x40029820 -val 0x00 puts "RE\_CUT\_RATIO\_Lane2" write register -addr 0x40029a00 -val 0x1

puts "UPDATE SETTINGS Lane2"

38

# Example 3: Change TX De-emphasis registers Lane2 of SERDESIF\_0

# set CONFIG\_REG\_LANE\_SEL
write\_register -addr 0x4002a028 -val 40F

write\_register -addr 0x40029828 -val 0xa
puts "TX\_PST\_RATIO\_Lane2"

write\_register -addr 0x4002982c -val 0x0
puts "TX\_PRE\_RATIO\_Lane2"

write\_register -addr 0x40029a00 -val 0x1
puts "UPDATE\_SETTINGS\_Lane2"



# A – List of Changes

3

The following table shows the important changes made in this document for each revision:

| Date                         | Version                                                                    | Page |
|------------------------------|----------------------------------------------------------------------------|------|
| Revision 7<br>(October 2015) | Updated the document for Libero v11.6 software release (SAR 68374).        | NA   |
| Revision 6<br>(January 2015) | Updated the document for Libero v11.5 software release (SAR 62936).        | NA   |
| Revision 5<br>(October 2014) | Updated the document for SERDES core change (SAR 61612).                   | NA   |
| Revision 4                   | Updated the document for Libero v11.4 software release (SAR 59069).        | NA   |
| (September 2014)             | Updated the document for M2S025 Evaluation Kit board details (SAR 59069).  | NA   |
|                              | Updated the document for M2GL010 Evaluation Kit board details (SAR 59069). | NA   |
| Revision 3<br>(April 2014)   | Added Note in "1. Specifying Live Probe Points" section(SAR 56593).        | 14   |
| Revision 2                   | Updated the software version from 11.2 SP1 to 11.3 (SAR 56012).            | NA   |
| (March 2014)                 | Updated design files using the latest 11.3 SERDES core (SAR 56012).        | NA   |
| Revision 1<br>(January 2014) | Initial release.                                                           | NA   |



## **B** – **Product Support**

Microsemi SoC Products Group backs its products with various support services, including Customer Service, Customer Technical Support Center, a website, electronic mail, and worldwide sales offices. This appendix contains information about contacting Microsemi SoC Products Group and using these support services.

## **Customer Service**

Contact Customer Service for non-technical product support, such as product pricing, product upgrades, update information, order status, and authorization.

From North America, call 800.262.1060 From the rest of the world, call 650.318.4460 Fax, from anywhere in the world, 408.643.6913

## **Customer Technical Support Center**

Microsemi SoC Products Group staffs its Customer Technical Support Center with highly skilled engineers who can help answer your hardware, software, and design questions about Microsemi SoC Products. The Customer Technical Support Center spends a great deal of time creating application notes, answers to common design cycle questions, documentation of known issues, and various FAQs. So, before you contact us, please visit our online resources. It is very likely we have already answered your questions.

## **Technical Support**

For Microsemi SoC Products Support, visit http://www.microsemi.com/products/fpga-soc/design-support/fpga-soc-support.

## Website

You can browse a variety of technical and non-technical information on the Microsemi SoC Products Group home page, at http://www.microsemi.com/products/fpga-soc/fpga-and-soc.

## **Contacting the Customer Technical Support Center**

Highly skilled engineers staff the Technical Support Center. The Technical Support Center can be contacted by email or through the Microsemi SoC Products Group website.

## Email

You can communicate your technical questions to our email address and receive answers back by email, fax, or phone. Also, if you have design problems, you can email your design files to receive assistance. We constantly monitor the email account throughout the day. When sending your request to us, please be sure to include your full name, company name, and your contact information for efficient processing of your request.

The technical support email address is soc\_tech@microsemi.com.



## My Cases

Microsemi SoC Products Group customers may submit and track technical cases online by going to My Cases.

### Outside the U.S.

Customers needing assistance outside the US time zones can either contact technical support via email (soc\_tech@microsemi.com) or contact a local sales office. Visit About Us for sales office listings and corporate contacts.

## **ITAR Technical Support**

For technical support on RH and RT FPGAs that are regulated by International Traffic in Arms Regulations (ITAR), contact us via soc\_tech@microsemi.com. Alternatively, within My Cases, select **Yes** in the ITAR drop-down list. For a complete list of ITAR-regulated Microsemi FPGAs, visit the ITAR web page.



Microsemi Corporate Headquarters One Enterprise, Aliso Viejo, CA 92656 USA

Within the USA: +1 (800) 713-4113 Outside the USA: +1 (949) 380-6100 Sales: +1 (949) 380-6136 Fax: +1 (949) 215-4996

E-mail: sales.support@microsemi.com

© 2015 Microsemi Corporation. All rights reserved. Microsemi and the Microsemi logo are trademarks of Microsemi Corporation. All other trademarks and service marks are the property of their respective owners.

Microsemi Corporation (Nasdaq: MSCC) offers a comprehensive portfolio of semiconductor and system solutions for communications, defense & security, aerospace and industrial markets. Products include high-performance and radiation-hardened analog mixed-signal integrated circuits, FPGAs, SoCs and ASICs; power management products; timing and synchronization devices and precise time solutions, setting the world's standard for time; voice processing devices; RF solutions; discrete components; security technologies and scalable anti-tamper products; Ethernet Solutions; Power-over-Ethernet ICs and midspans; as well as custom design capabilities and services. Microsemi is headquartered in Aliso Viejo, Calif., and has approximately 3,600 employees globally. Learn more at **www.microsemi.com**.

Microsemi makes no warranty, representation, or guarantee regarding the information contained herein or the suitability of its products and services for any particular purpose, nor does Microsemi assume any liability whatsoever arising out of the application or use of any product or circuit. The products sold hereunder and any other products sold by Microsemi have been subject to limited testing and should not be used in conjunction with mission-critical equipment or applications. Any performance specifications are believed to be reliable but are not verified, and Buyer must conduct and complete all performance and other testing of the products, alone and together with, or installed in, any end-products. Buyer shall not rely on any data and performance specifications or parameters provided by Microsemi. It is the Buyer's responsibility to independently determine suitability of any products and to test and verify the same. The information provided by Microsemi hereunder is provided "as is, where is" and with all faults, and the entire risk associated with such information is entirely with the Buyer. Microsemi does not grant, explicitly or implicitly, to any party any patent rights, licenses, or any other IP rights, whether with regard to such information itself or anything described by such information. Information provided in this document is proprietary to Microsemi, and Microsemi reserves the right to make any changes to the information in this document or to any products and services at any time without notice.