Libero SoC Tutorial



## **Table of Contents**

|   | Introduction Associated Project Files                                                                                         |          |
|---|-------------------------------------------------------------------------------------------------------------------------------|----------|
| 1 | Design Overview                                                                                                               | 5        |
| 2 | Programming the Device                                                                                                        |          |
|   | Launching SmartDebug                                                                                                          |          |
|   | View Device Status                                                                                                            |          |
|   | View Flash Memory (eNVM) Content                                                                                              |          |
|   | 1. Specifying Live Probe Points                                                                                               | 14       |
|   | 2. Active Probes                                                                                                              |          |
|   | Forcing a Design Modification                                                                                                 | 19       |
|   | SERDES Debug                                                                                                                  | 21       |
|   | Far-End Loop Back Support                                                                                                     |          |
|   | Executing SERDES Debug from SmartDebug Tcl                                                                                    | 33       |
|   | Conclusion                                                                                                                    | 35       |
| Α | Appendix                                                                                                                      | 37       |
|   | TCL Script Examples                                                                                                           |          |
|   | Example 1: Change M/N/F registers for Lane1 and Lane2 of SERDESIF_0<br>Example 2: Change RX LEQ registers Lane2 of SERDESIF 0 |          |
|   | Example 3: Change TX De-emphasis registers Lane2 of SERDESIF_0                                                                | 38       |
| В | List of Changes                                                                                                               | 39       |
| С | Product Support                                                                                                               | 41       |
|   | Customer Service                                                                                                              |          |
|   | Customer Technical Support Center                                                                                             |          |
|   | Technical Support                                                                                                             |          |
|   | Website                                                                                                                       |          |
|   | Contacting the Customer Technical Support Center                                                                              | 41<br>41 |
|   | My Cases                                                                                                                      | 42       |
|   | Outside the U.S.                                                                                                              |          |
|   | ITAR Technical Support                                                                                                        | 42       |



## Introduction

Design debug is a critical phase of the FPGA design flow. Microsemi's multiple design debug tools and features compliment design simulations by allowing verification and troubleshooting at the hardware level. Having successfully passed functional and post-layout simulations, Microsemi's design debug tools can help provide the designer with a pre-system level implementation early warning of other design issues. Microsemi's design debug tools can provide the peace of mind, that intended design goals and functionality are maintained by performing various analysis in the actual programmed FPGA. Microsemi design debug focuses the designer on analysis of 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 and IGLOO<sup>®</sup>2 field programmable gate array (FPGA) devices have built-in probe points that greatly enhance the ability to debug logic elements within the device. The enhanced debug features implemented into the SmartFusion2 and IGLOO2 devices give access to any logic element and enable designers to check the state of inputs and outputs in real-time, without any re-layout of the design through Live Probe and Active Probe features:

- 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 then be sent to two dedicated pins (PROBE\_A and PROBE\_B), then to an oscilloscope, or even redirected back to the FPGA fabric to drive a software logic analyzer.
- Active Probe allows dynamic asynchronous read and write to a flip-flop or probe point. This will
  enable a user to quickly observe the output of the logic internally, or to quickly experiment on how
  the logic will be affected by writing to a probe point.
- SmartDebug includes SERDES control and test capabilities that can also access SRAM and eNVM to assist with debugging high speed serial designs, with no extra steps. The SmartDebug JTAG interface extends access to configure, control, and observe SERDES operations and is accessible in every SERDES design. Users simply implement their design with the Libero<sup>®</sup> System Builder to incorporate the SERDESIF block enabling SERDES access from the SmartDebug toolset.

This quickly enables designers to explore configuration options without going through FPGA recompilation or making changes to the board. The SERDES Debug GUI 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.

Upon completing this tutorial you will be familiar with the following:

- Accessing SmartDebug from Libero SoC on a design
- Checking the device status
- · Checking the flash memory (eNVM) content
- Debugging FPGA array (setting Live Probes, Active Probes, and reading/modifying fabric SRAM content)
- Debugging SERDES designs

#### Table 1 • Reference Design Requirements and Details

| Reference Design Requirements and Details                                                                      | 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                                                                                          | Rev C or later                                              |
| Software Requirements                                                                                          |                                                             |
| Libero <sup>®</sup> System-on-Chip (SoC)                                                                       | v11.3                                                       |
| FlashPro programming software                                                                                  | v11.3                                                       |
| Host PC Drivers (provided along with the design files)                                                         | -                                                           |



## **Associated Project Files**

Extract the SmartDebug\_Tutorial Libero SoC project along with the ReadMe and programming (.stp) file to a folder on the HDD of your PC (for example: C:\Microsemiprj). Confirm that a folder named *SmartDebug\_Tutorial* containing the Libero SoC project was extracted.

Note: Extract the design files to a root directory.



## 1 – 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-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 1-2 on page 6.

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 real-time from the device.

The Fabric\_Debug block demonstrates the way to use SmartDebug to do 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 is progressing as expected. If there is an error, the output (error) is latched high, as shown in Figure 1-3 on page 6. This Fabric\_Debug block design is used to demonstrate the different silicon built-in capabilities, such as setting Live Probes to monitor in real-time an internal user-selected point on the device. In addition, users can set Active Probes which provides the capabilities for dynamic asynchronous read and write to a flip-flop or probe point. This will enable users to quickly observe the output of the logic internally or to quickly experiment on how the logic will be affected by writing to a probe point. Finally, the Fabric\_Debug design block will be used to demonstrate the SmartDebug capabilities where users can read and modify in real-time the fabric SRAM content.



Figure 1-1 • SmartDebug Top Level Blocks







Figure 1-3 • Fabric\_Debug Overall Design Blocks



## 2 – Programming the Device

## **Programming the IGLOO2 Board**

- 1. Connect the FlashPro4 programmer to the J5 connector on the IGLOO2 FPGA Evaluation Kit.
- 2. Connect the power supply to the J6 connector
- 3. Switch the power supply (SW7) to the ON position. Refer to the IGLOO2 FPGA Evaluation Kit Board for more details.
- 4. Launch Libero SoC v11.3.
- From the Project menu, select Open Project. Browse to the folder where the design files were extracted. Refer to the "Associated Project Files" section on page 4. Select the Libero SoC project inside the "SmartDebug\_Tutorial" folder then select Open.
- 6. In the **Design Flow** window, select **Run PROGRAM Action**. This will program the design into the device, as shown in Figure 2-1.

|    |                  | bug_ | _top 🗉 🖸 🚺 🖗                               |
|----|------------------|------|--------------------------------------------|
|    | Тос              | ol   |                                            |
|    | ⊳                | •    | Create Design                              |
|    | $\triangleright$ |      | Create Constraints                         |
|    | $\triangleright$ | ►    | Implement Design                           |
|    | $\triangleright$ | ►    | Edit Design Hardware Configuration         |
|    | $\triangleright$ | ►    | Configure Security and Programming Options |
| // | ⊿                | ►    | Program Design                             |
| /  |                  |      | Generate Programming Data                  |
|    |                  |      | Run PROGRAM Action                         |
|    | 2                | 2    | Debug Design                               |
|    | Þ                | ×    | Handoff Design for Production              |
|    | ⊳                |      | Develop Firmware                           |
|    |                  |      | •                                          |
|    |                  |      |                                            |
|    |                  |      |                                            |
|    |                  |      |                                            |
| De | sig              | 1    | Design Hier Stimulus Hie Catalog File      |
|    |                  |      |                                            |

Figure 2-1 • Programming the Device



## Launching SmartDebug

Launch SmartDebug by selecting the **SmartDebug Design** option from the **Design Flow** window, as shown in Figure 2-2.



Figure 2-2 • Launching SmartDebug Design Tools

3



This will open the SmartDebug window, as shown in Figure 2-3.

| Device: M2GL01 | LOT (M2GL010T)            | Programmer: | 87570 (usb87570) | •     |
|----------------|---------------------------|-------------|------------------|-------|
| ID code read   | d from device: F8031CF    |             |                  |       |
|                |                           |             |                  |       |
|                |                           |             |                  |       |
|                |                           |             |                  |       |
|                | View Device Status        |             | Debug FPGA Array |       |
|                | View Elseh Memory Content |             | Debug SEDDES     |       |
|                | View Flash Memory Content |             | Debug SERDES     |       |
|                |                           |             |                  |       |
| Help           |                           |             |                  | Close |
| Theip          |                           |             |                  | Close |

## **View Device Status**

The View Device Status option provides the device status report. It is a summary of your device information, programmer information, user information, factory serial number, and security information if any are set. Figure 2-4 shows a sample of the device status information.

| Device Status Report                                     | 8 X        |
|----------------------------------------------------------|------------|
| Device: M2GL010T (M2GL010T) Programmer: 87570 (usb87570) | Save Print |
| Device Status:<br>IDCode (read from the device) (HEX):   | 0f8031cf   |
| Help                                                     | Close      |

#### Figure 2-4 • Device Status Report Sample



## View Flash Memory (eNVM) Content

The View Flash Memory Content can be accessed from the **SmartDebug** window, as previously shown in Figure 2-3 on page 9. 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 read back the content of the eNVM, the data to be programmed into the eNVM was defined first. One way to do this is by defining an eNVM data storage client using the eNVM configurator. The client can be stored into any page of the eNVM. Page 4 was used here for demonstration purposes. Figure 2-5 shows an excerpt of the data storage client content that was defined in the eNVM.



Figure 2-5 • 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 2-5.



The eNVM content can be read in real-time from the device as follows:

- 1. Using the SmartDebug window, select the **View Flash Memory Content** option. The Flash Memory window opens, as shown in Figure 2-6.
- 2. Since the data storage client is stored into page four, specify the **Start Page** and **End Page** as page number **4**.
- 2 X Flash Memory **Retrieve Flash Memory Content from Device:** From block 0 - <no efc> 💌 Select <Page Range> 💌 Read from Device \* Start Page: 4 (address 0x200) End Page: 4 (1 page, 128 bytes) Latest Content Retrieved from Device: Mon Dec 16 10:19:48 2013 Retrieved Content: at Page 4, 128 bytes starting from address 0x200 View Detailed Status Go to Address (hex): Content Page Number | Address 0 1 2 3 4 5 6 7 8 9 Α В C D E F 00200 53 FF 55 E2 F0 53 FF 55 E2 F0 53 FF AA 53 AA 4 00210 53 AA 53 FF 53 FF 55 FF FF 55 E2 F0 E2 AA F0 53 4 00220 53 FF E2 AA F0 53 FF 53 FF 55 E2 AA F0 53 FF 55 4 00230 53 FF 55 E2 AA F0 53 FF 53 FF 55 E2 AA FO 53 00 4 00240 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 4 Help Close
- 3. Select the **Read from Device** option.

Figure 2-6 • Flash Memory (eNVM) Content Read from the Device



## **Debug FPGA Array**

SmartFusion2 and IGLOO2 devices have built-in probe points that greatly enhance the ability to debug logic elements within the device through the Live Probes and Active Probes features. The enhanced debug features implemented into the devices give access to any logic element and enable users 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 step 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 previously shown in Figure 2-3 on page 9. Selecting the Debug FPGA Array option opens the **Debug FPGA Array** window, as shown below in Figure 2-7.



#### Figure 2-7 • Debug FPAG Array Window

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

Before starting the FPGA Array Debug, the Debug File must be specified.

Select the **Browse** button and then select the **SmartDebug\_top\_debug.txt** file: *Debug File* = <*project root*>/*designer*/S*martDebug\_top\_debug.txt*.



Once the file has been selected, the window will populate the **Live Probes** tab with the available debug points, as shown in Figure 2-8.

| PGA Array Deb | Active Probes Memory Blocks                      |        |
|---------------|--------------------------------------------------|--------|
| Filter        |                                                  | Search |
|               | Name                                             | Туре   |
| :Fabric_Debu  | g_0/DPSRAM_0/Fabric_Debug_DPSRAM_0_DPSRAM_R0C0/I | SRAM   |
| •             | III                                              | •      |
|               | ChannelA -><br>ChannelB ->                       | Set    |

Figure 2-8 • Specify Debug File Location

S

In the next few steps, this tutorial demonstrates 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 then be sent to the two dedicated probe pins (PROBE\_A and PROBE\_B), then to the oscilloscope or even redirected back to the FPGA fabric. The probe points location can be changed without having to recompile or reprogram the design. The probes can capture data at a speed of up to 100MHz.

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. The pins can be reserved for probing by selecting the option **Reserve Pins for Probes** in the **Project Settings** window, as shown in Figure 2-9.



#### Figure 2-9 • Reserving Probe Pin for Probes

Furthermore, you can identify the probe pin on your package by looking at the pin description document for that particular package. Another option is to check the Function column in the Package Viewer of the **I/O Editor** in the Libero SoC software, as shown in Figure 2-10.

For the purpose of this tutorial, M2GL010T with 484 FBGA is used. As such, pin numbers Y10 and W10 are the two dedicated pins that can be used for probing, as shown in Figure 2-10.

| 1 |   | VO Editor S                  | martDebug_top          |                          |        | x |
|---|---|------------------------------|------------------------|--------------------------|--------|---|
|   | _ |                              |                        |                          |        |   |
|   |   | ile <u>E</u> dit <u>V</u> ie |                        | The last                 |        |   |
|   |   | 6 2 4                        |                        | 71 🛃                     |        |   |
|   |   | I/O Editor                   |                        |                          |        |   |
|   |   | Pin Number                   | PortName               | Function 🔺               | Locked |   |
|   |   | Y9                           | Unassigned             | MSIO102NB4/CCC_NE1_CLKI0 |        |   |
|   |   | W9                           | Unassigned             | MSIO 102PB4              |        |   |
|   |   | Y10                          | Unassigned             | MSIO103NB4/PROBE_B       |        |   |
|   |   | W10                          | Unassigned             | MSIO103PB4/PROBE_A       |        |   |
|   |   | W11                          | Unassigned             | MSIO104NB4/GB7           |        | - |
|   |   | •                            |                        |                          | +      |   |
|   | 1 | Ports Pack                   | age Pins / Package Vie | wer /                    |        |   |

Figure 2-10 • 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. These pins will be accessible on the next revision of the IGLOO2 board.



The Live Probes tab (Figure 2-11) shows the probe point name and pin type (SRAM, Logic, or I/O). Once a point is selected it can be assigned to either ChannelA or ChannelB as follows:

- 1. Select the **point** that you want to probe
- 2. Select the channel on which you want to probe the selected point
- 3. Select Set

Figure 2-11 shows an example of setting two probe points: A\_DOUT[0] and A\_DOUT[13] to be probed on ChannelA and ChannelB respectively.

A message will be printed in the Log window of the Libero SoC indicating which signals were assigned to be probed—as follows:

Live probe has been set:

#### ChannelA:

Fabric\_Debug\_0/DPSRAM\_0/Fabric\_Debug\_DPSRAM\_0\_DPSRAM\_R0C0/INST\_RAM1K18\_IP:A\_DO UT[0]

#### ChannelB:

Fabric\_Debug\_0/DPSRAM\_0/Fabric\_Debug\_DPSRAM\_0\_DPSRAM\_R0C0/INST\_RAM1K18\_IP:A\_DO UT[13].

After the channels have been set, SmartDebug configures the ChannelA and ChannelB I/Os to monitor the desired probe points. The maximum number of simultaneous probes is two internal signals. There is also a Filter box to filter through the Net Names. As you begin typing in the Filter box, the Net Name table only shows results for the queried names.

Note: The Active Probes WRITE will overwrite the settings of the Live Probe channels (if any).

| Live Probes Active Probes Memory Blocks                                            |        |
|------------------------------------------------------------------------------------|--------|
| Filter                                                                             | Search |
| Name                                                                               | Туре   |
| _Debug_DPSRAM_0_DPSRAM_R0C0/INST_RAM1K18_IP:A_DOUT[0]                              | SRAM   |
| _Debug_DPSRAM_0_DPSRAM_R0C0/INST_RAM1K18_IP:A_DOUT[10]                             | SRAM   |
| Debug_DPSRAM_0_DPSRAM_R0C0/INST_RAM1K18_IP:A_DOUT[11]                              | SRAM   |
| Debug_DPSRAM_0_DPSRAM_R0C0/INST_RAM1K18_IP:A_DOUT[12]                              | SRAM   |
| Debug_DPSRAM_0_DPSRAM_R0C0/INST_RAM1K18_IP:A_DOUT[13]                              | SRAM   |
|                                                                                    |        |
| ChannelA -> AM_R0C0/INST_RAM1K18_IP:A_D<br>ChannelB -> M_R0C0/INST_RAM1K18_IP:A_D0 | Set    |

#### Figure 2-11 • Live Probes Channels Assignments



## 2. Active Probes

Active Probe allows dynamic asynchronous read and write to a flip-flop or probe point. This will enable a user to quickly observe the output of the logic internally or to quickly experiment on how the logic will be affected by writing to a probe point. The following steps will demonstrate how to select a specific set of probe pins reading the current value and then writing different values.

#### Selecting Active Probes

- 1. Select the Active Probes tab from the Debug FPGA Array window.
- 2. Once inside the Active Probes tab, click on the **Select Active Probes** button to define the internal points to monitor, as shown in Figure 2-12.



#### Figure 2-12 • Selecting Active Probes From the Design

- 3. Select Active Probes opens a window that shows all the available probe points in the design. For this tutorial we are going to monitor the following points:
- Three bits of the counter output CountA (countA[0], countA[1], and countA[2])
- The monitoring signal "error"
- An internal register "sync"

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

Note: Since Active Probe only deals with individual signals, the cout[7:0] bus segment will be broken up into three separate probe lines.



4. Select the desired points and click on **Add** to move to the **Selected Probe Points** window and click **OK**, as shown in Figure 2-13.

| Available Probe Points                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                        |               | Selected Probe Points                        |         |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------|---------------|----------------------------------------------|---------|
| Filter coutA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Search                                 |               | Filter                                       | Search  |
| Nar                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | me 🔺                                   |               | Name                                         | Туре    |
| Fabric_Debug_0/count_0_coutA[0]:F                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | abric_Debug_0/cc                       | Add All ->    | _0_coutA[0]:Fabric_Debug_0/count_0/coutA[0]: | Q Logic |
| Fabric_Debug_0/count_0_coutA[1]:Fabric_Debug_0/count_0_coutA[1]:Fabric_Debug_0/count_0_coutA[1]:Fabric_Debug_0/count_0_coutA[1]:Fabric_Debug_0/count_0_coutA[1]:Fabric_Debug_0/count_0_coutA[1]:Fabric_Debug_0/count_0_coutA[1]:Fabric_Debug_0/count_0_coutA[1]:Fabric_Debug_0/count_0_coutA[1]:Fabric_Debug_0/count_0_coutA[1]:Fabric_Debug_0/count_0_coutA[1]:Fabric_Debug_0/count_0_coutA[1]:Fabric_Debug_0/count_0_coutA[1]:Fabric_Debug_0/count_0_coutA[1]:Fabric_Debug_0/count_0_coutA[1]:Fabric_Debug_0/count_0_coutA[1]:Fabric_Debug_0/count_0_coutA[1]:Fabric_Debug_0/count_0_coutA[1]:Fabric_Debug_0/count_0_coutA[1]:Fabric_Debug_0/count_0_coutA[1]:Fabric_Debug_0/count_0_coutA[1]:Fabric_Debug_0/count_0_coutA[1]:Fabric_Debug_0/count_0_coutA[1]:Fabric_Debug_0/count_0_coutA[1]:Fabric_Debug_0/count_0_coutA[1]:Fabric_Debug_0/count_0_coutA[1]:Fabric_Debug_0/count_0_coutA[1]:Fabric_Debug_0/count_0_coutA[1]:Fabric_Debug_0/count_0_coutA[1]:Fabric_Debug_0/count_0_coutA[1]:Fabric_Debug_0/count_0_coutA[1]:Fabric_Debug_0/count_0_coutA[1]:Fabric_Debug_0/count_0_coutA[1]:Fabric_Debug_0/count_0_coutA[1]:Fabric_Debug_0/count_0_coutA[1]:Fabric_Debug_0/count_0_coutA[1]:Fabric_Debug_0/count_0_coutA[1]:Fabric_Debug_0/count_0_coutA[1]:Fabric_Debug_0/count_0_coutA[1]:Fabric_Debug_0/count_0_coutA[1]:Fabric_Debug_0/count_0_coutA[1]:Fabric_Debug_0/count_0_coutA[1]:Fabric_Debug_0/count_0_coutA[1]:Fabric_Debug_0/count_0_coutA[1]:Fabric_Debug_0/count_0_coutA[1]:Fabric_Debug_0/count_0_coutA[1]:Fabric_Debug_0/count_0_coutA[1]:Fabric_Debug_0/count_0_coutA[1]:Fabric_Debug_0/count_0_coutA[1]:Fabric_Debug_0/count_0_coutA[1]:Fabric_Debug_0/count_0_coutA[1]:Fabric_Debug_0/count_0_coutA[1]:Fabric_Debug_0/count_0_coutA[1]:Fabric_Debug_0/count_0_coutA[1]:Fabric_Debug_0/count_0_coutA[1]:Fabric_Debug_0/count_0_coutA[1]:Fabric_Debug_0/count_0_coutA[1]:Fabric_Debug_0/count_0[1]:Fabric_Debug_0/count_0[1]:Fabric_Debug_0/count_0[1]:Fabric_Debug_0/count_0[1]:Fabric_Debug_0/count_0[1]:Fabric_Debug_0/count_0[1]:Fabric_Debug_0/count_0[1]:Fabric_Debug_0/count_0[1]:Fabric_Debug_0 | abric_Debug_0/cc                       | Add Ail ->    | _0_coutA[1]:Fabric_Debug_0/count_0/coutA[1]: | Q Logic |
| Fabric_Debug_0/count_0_coutA[2]:Fabric_Debug_0/count_0_coutA[2]:Fabric_Debug_0/count_0_coutA[2]:Fabric_Debug_0/count_0_coutA[2]:Fabric_Debug_0/count_0_coutA[2]:Fabric_Debug_0/count_0_coutA[2]:Fabric_Debug_0/count_0_coutA[2]:Fabric_Debug_0/count_0_coutA[2]:Fabric_Debug_0/count_0_coutA[2]:Fabric_Debug_0/count_0_coutA[2]:Fabric_Debug_0/count_0_coutA[2]:Fabric_Debug_0/count_0_coutA[2]:Fabric_Debug_0/count_0_coutA[2]:Fabric_Debug_0/count_0_coutA[2]:Fabric_Debug_0/count_0_coutA[2]:Fabric_Debug_0/count_0_coutA[2]:Fabric_Debug_0/count_0_coutA[2]:Fabric_Debug_0/count_0_coutA[2]:Fabric_Debug_0/count_0_coutA[2]:Fabric_Debug_0/count_0_coutA[2]:Fabric_Debug_0/count_0_coutA[2]:Fabric_Debug_0/count_0_coutA[2]:Fabric_Debug_0/count_0_coutA[2]:Fabric_Debug_0/count_0_coutA[2]:Fabric_Debug_0/count_0_coutA[2]:Fabric_Debug_0/count_0_coutA[2]:Fabric_Debug_0/count_0_coutA[2]:Fabric_Debug_0/count_0_coutA[2]:Fabric_Debug_0/count_0_coutA[2]:Fabric_Debug_0/count_0_coutA[2]:Fabric_Debug_0/count_0_coutA[2]:Fabric_Debug_0/count_0_coutA[2]:Fabric_Debug_0/count_0_coutA[2]:Fabric_Debug_0/count_0_coutA[2]:Fabric_Debug_0/count_0_coutA[2]:Fabric_Debug_0/count_0_coutA[2]:Fabric_Debug_0/count_0_coutA[2]:Fabric_Debug_0/count_0_coutA[2]:Fabric_Debug_0/count_0_coutA[2]:Fabric_Debug_0/count_0_coutA[2]:Fabric_Debug_0/count_0_coutA[2]:Fabric_Debug_0/count_0_coutA[2]:Fabric_Debug_0/count_0_coutA[2]:Fabric_Debug_0/count_0_coutA[2]:Fabric_Debug_0/count_0_coutA[2]:Fabric_Debug_0/count_0_coutA[2]:Fabric_Debug_0/count_0_coutA[2]:Fabric_Debug_0/count_0_coutA[2]:Fabric_Debug_0/count_0_coutA[2]:Fabric_Debug_0/count_0_coutA[2]:Fabric_Debug_0/count_0_coutA[2]:Fabric_Debug_0/count_0_coutA[2]:Fabric_Debug_0/count_0_coutA[2]:Fabric_Debug_0/count_0_coutA[2]:Fabric_Debug_0/count_0_coutA[2]:Fabric_Debug_0/count_0_coutA[2]:Fabric_Debug_0/count_0_coutA[2]:Fabric_Debug_0/count_0_coutA[2]:Fabric_Debug_0/count_0_coutA[2]:Fabric_Debug_0/count_0[coutA[2]:Fabric_Debug_0/count_0[coutA[2]:Fabric_Debug_0/count_0[coutA[2]:Fabric_Debug_0/count_0[coutA[2]:Fabric_Debug_0/count_0[coutA[2 | abric_Debug_0/cc                       | <- Remove     | _0_coutA[2]:Fabric_Debug_0/count_0/coutA[2]: | Q Logic |
| Fabric_Debug_0/count_0_coutA[3]:Fabric_Debug_0/count_0_coutA[3]:Fabric_Debug_0/count_0_coutA[3]:Fabric_Debug_0/count_0_coutA[3]:Fabric_Debug_0/count_0_coutA[3]:Fabric_Debug_0/count_0_coutA[3]:Fabric_Debug_0/count_0_coutA[3]:Fabric_Debug_0/count_0_coutA[3]:Fabric_Debug_0/count_0_coutA[3]:Fabric_Debug_0/count_0_coutA[3]:Fabric_Debug_0/count_0_coutA[3]:Fabric_Debug_0/count_0_coutA[3]:Fabric_Debug_0/count_0_coutA[3]:Fabric_Debug_0/count_0_coutA[3]:Fabric_Debug_0/count_0_coutA[3]:Fabric_Debug_0/count_0_coutA[3]:Fabric_Debug_0/count_0_coutA[3]:Fabric_Debug_0/count_0_coutA[3]:Fabric_Debug_0/count_0_coutA[3]:Fabric_Debug_0/count_0_coutA[3]:Fabric_Debug_0/count_0_coutA[3]:Fabric_Debug_0/count_0_coutA[3]:Fabric_Debug_0/count_0_coutA[3]:Fabric_Debug_0/count_0_coutA[3]:Fabric_Debug_0/count_0_coutA[3]:Fabric_Debug_0/count_0_coutA[3]:Fabric_Debug_0/count_0_coutA[3]:Fabric_Debug_0/count_0_coutA[3]:Fabric_Debug_0/count_0_coutA[3]:Fabric_Debug_0/count_0_coutA[3]:Fabric_Debug_0/count_0_coutA[3]:Fabric_Debug_0/count_0_coutA[3]:Fabric_Debug_0/count_0_coutA[3]:Fabric_Debug_0/count_0_coutA[3]:Fabric_Debug_0/count_0_coutA[3]:Fabric_Debug_0/count_0_coutA[3]:Fabric_Debug_0/count_0_coutA[3]:Fabric_Debug_0/count_0_coutA[3]:Fabric_Debug_0/count_0_coutA[3]:Fabric_Debug_0/count_0_coutA[3]:Fabric_Debug_0/count_0_coutA[3]:Fabric_Debug_0/count_0_coutA[3]:Fabric_Debug_0/count_0_coutA[3]:Fabric_Debug_0/count_0_coutA[3]:Fabric_Debug_0/count_0_coutA[3]:Fabric_Debug_0/count_0_coutA[3]:Fabric_Debug_0/count_0_coutA[3]:Fabric_Debug_0/count_0_coutA[3]:Fabric_Debug_0/count_0_coutA[3]:Fabric_Debug_0/count_0_coutA[3]:Fabric_Debug_0/count_0_coutA[3]:Fabric_Debug_0/count_0_coutA[3]:Fabric_Debug_0/count_0_coutA[3]:Fabric_Debug_0/count_0_coutA[3]:Fabric_Debug_0/count_0_coutA[3]:Fabric_Debug_0/count_0_coutA[3]:Fabric_Debug_0/count_0_coutA[3]:Fabric_Debug_0/count_0_coutA[3]:Fabric_Debug_0/count_0_coutA[3]:Fabric_Debug_0/count_0_coutA[3]:Fabric_Debug_0/count_0_coutA[3]:Fabric_Debug_0/count_0[coutA[3]:Fabric_Debug_0/count_0[coutA[3]:Fabric_Debug_0/count_0[coutA[3 | abric_Debug_0/cc                       | <- Remove All | _chk_0/sync:Fabric_Debug_0/count_chk_0/sync  | Q Logic |
| Fabric_Debug_0/count_0_coutA[4]:Fabric_Debug_0/count_0_coutA[4]:Fabric_Debug_0/count_0_coutA[4]:Fabric_Debug_0/count_0_coutA[4]:Fabric_Debug_0/count_0_coutA[4]:Fabric_Debug_0/count_0_coutA[4]:Fabric_Debug_0/count_0_coutA[4]:Fabric_Debug_0/count_0_coutA[4]:Fabric_Debug_0/count_0_coutA[4]:Fabric_Debug_0/count_0_coutA[4]:Fabric_Debug_0/count_0_coutA[4]:Fabric_Debug_0/count_0_coutA[4]:Fabric_Debug_0/count_0_coutA[4]:Fabric_Debug_0/count_0_coutA[4]:Fabric_Debug_0/count_0_coutA[4]:Fabric_Debug_0/count_0_coutA[4]:Fabric_Debug_0/count_0_coutA[4]:Fabric_Debug_0/count_0_coutA[4]:Fabric_Debug_0/count_0_coutA[4]:Fabric_Debug_0/count_0_coutA[4]:Fabric_Debug_0/count_0_coutA[4]:Fabric_Debug_0/count_0_coutA[4]:Fabric_Debug_0/count_0_coutA[4]:Fabric_Debug_0/count_0_coutA[4]:Fabric_Debug_0/count_0_coutA[4]:Fabric_Debug_0/count_0_coutA[4]:Fabric_Debug_0/count_0_coutA[4]:Fabric_Debug_0/count_0_coutA[4]:Fabric_Debug_0/count_0_coutA[4]:Fabric_Debug_0/count_0_coutA[4]:Fabric_Debug_0/count_0_coutA[4]:Fabric_Debug_0/count_0_coutA[4]:Fabric_Debug_0/count_0_coutA[4]:Fabric_Debug_0/count_0_coutA[4]:Fabric_Debug_0/count_0_coutA[4]:Fabric_Debug_0/count_0_coutA[4]:Fabric_Debug_0/count_0_coutA[4]:Fabric_Debug_0/count_0_coutA[4]:Fabric_Debug_0/count_0_coutA[4]:Fabric_Debug_0/count_0_coutA[4]:Fabric_Debug_0/count_0_coutA[4]:Fabric_Debug_0/count_0_coutA[4]:Fabric_Debug_0/count_0_coutA[4]:Fabric_Debug_0/count_0_coutA[4]:Fabric_Debug_0/count_0_coutA[4]:Fabric_Debug_0/count_0_coutA[4]:Fabric_Debug_0/count_0_coutA[4]:Fabric_Debug_0/count_0_coutA[4]:Fabric_Debug_0/count_0_coutA[4]:Fabric_Debug_0/count_0_coutA[4]:Fabric_Debug_0/count_0_coutA[4]:Fabric_Debug_0/count_0_coutA[4]:Fabric_Debug_0/count_0_coutA[4]:Fabric_Debug_0/count_0_coutA[4]:Fabric_Debug_0/count_0_coutA[4]:Fabric_Debug_0/count_0_coutA[4]:Fabric_Debug_0/count_0_coutA[4]:Fabric_Debug_0/count_0_coutA[4]:Fabric_Debug_0/count_0_coutA[4]:Fabric_Debug_0/count_0_coutA[4]:Fabric_Debug_0/count_0[4]:Fabric_Debug_0/count_0[4]:Fabric_Debug_0/count_0[4]:Fabric_Debug_0/count_0[4]:Fabric_Debug_0/count_0 | abric_Debug_0/cc                       | C Remove All  | 0/count_chk_0/error:Q                        | Logic   |
| Fabric_Debug_0/count_0_coutA[5]:Fi                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | abric_Debug_0/cc                       |               |                                              |         |
| - · <u>- · _ · · - · · · -</u> · · · ·                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | ······································ |               |                                              | -       |



#### **Reading Active Probes**

Once all of the probes points have been specified, select **Read Active Probes** to gather the current values of the internal signals. Figure 2-14 shows the results similar to a first read of the design.

| Live Probes Active Pro | Active Probe Data                                               |       |      |                |
|------------------------|-----------------------------------------------------------------|-------|------|----------------|
|                        | Name                                                            | Туре  | b    | Value          |
|                        | Fabric_Debug_0/count_0_coutA[0]:Fabric_Debug_0/count_0/coutA[0] |       | Low  | 0 1            |
| Select Active Probes   | Fabric_Debug_0/count_0_coutA[1]:Fabric_Debug_0/count_0/coutA[1] | Logic | Low  | 0 1            |
| Read Active Probes     | Fabric_Debug_0/count_0_coutA[2]:Fabric_Debug_0/count_0/coutA[2] | Logic | Low  | <del>о</del> 1 |
| Write Active Probes    | Fabric_Debug_0/count_chk_0/sync:Fabric_Debug_0/count_chk_0/syn  | Logic | High | 0 1            |
|                        | error_c:Fabric_Debug_0/count_chk_0/error:Q                      | Logic | Low  | 01             |

#### Figure 2-14 • Active Probe Readings

Note: To toggle the states between High and Low, press  $^{O}$  , and to reset the value, press  $^{1}$  .



The cout[2:0] bus will be constantly counting therefore, the value may be different than what is seen on the target platform. The value of sync should be High indicating that the checker on the read side of the DPSRAM has latched onto the count pattern.

Also, the error signal should be Low indicating that there have been no errors in the counting pattern.

When the design is held in reset the sync signal goes Low and waits for a specific pattern from the DPSRAM to sync up the counters. To watch this happen, hold **SW2** down and select **Read Active Probes**. The sync signal will be Low as the design is now held in reset. Release **SW2** and read again, the sync is now High.

### 3. Fabric SRAM Memory Debug

To view the contents of the Large SRAM in this design select the **Memory Blocks** tab, as shown in Figure 2-15.



Figure 2-15 • Memory Blocks Tab

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



The contents of the DPSRAM\_0 will be displayed, as shown in Figure 2-16. See the counting pattern that is loaded into the RAM.

| bug File: |          |        |        | sinar u | Jebug  | _1010  | ayue   | signer | Joina | libebi | ug_top | Joina | ribeb | ug_tu | p_ue | oug.txt |     |           | <br>Browse |
|-----------|----------|--------|--------|---------|--------|--------|--------|--------|-------|--------|--------|-------|-------|-------|------|---------|-----|-----------|------------|
| PGA Arra  | y Debu   | g Data | 9      |         |        |        |        | _      |       |        |        |       |       |       |      |         |     |           |            |
| Live Pro  | bes      | Activ  | /e Pro | bes     | Mer    | mory E | Blocks |        |       |        |        |       |       |       |      |         |     |           |            |
| Fabric    | Debug    | _0/DPS | RAM_   | _0/Fab  | ric_De | ebug_l | DPSR/  | AM_0_  | DPSR  | AM_R   | .0C0/I | NST_F | RAM1  | <18_I | P    |         | ▼ R | ead Block | te Block   |
| Memo      | ry Block | Data   |        |         | _      |        |        |        |       | _      |        | _     |       | _     |      |         |     |           |            |
|           |          |        |        |         |        |        |        |        |       |        |        |       |       |       |      |         |     |           |            |
| 0000      | 000      | 001    | 002    | 003     | 004    | 005    | 006    | 007    | 008   | 009    | 00A    | 00B   | 00C   | 00D   | 00E  | 00F     |     |           |            |
| 0010      | 010      | 011    | 012    | 013     | 014    | 015    | 016    | 017    | 018   | 019    | 01A    | 01B   | 01C   | 01D   | 01E  | 01F     |     |           |            |
| 0020      | 020      | 021    | 022    | 023     | 024    | 025    | 026    | 027    | 028   | 029    | 02A    | 02B   | 02C   | 02D   | 02E  | 02F     |     |           |            |
|           |          |        |        |         |        |        |        |        |       |        |        |       |       |       |      |         |     |           |            |
| 0030      | 030      | 031    | 032    | 033     | 034    | 035    | 036    | 037    | 038   | 039    | 03A    | 03B   | 03C   | 03D   | 03E  | 03F     |     |           |            |
| 0040      | 040      | 041    | 042    | 043     | 044    | 045    | 046    | 047    | 048   | 049    | 04A    | 04B   | 04C   | 04D   | 04E  | 04F     |     |           |            |
| 0050      | 050      | 051    | 052    | 053     | 054    | 055    | 056    | 057    | 058   | 059    | 05A    | 05B   | 05C   | 05D   | 05E  | 05F     |     |           |            |
| 0050      | 000      | 001    | 060    | 060     | 064    | 000    | 000    | 067    | 000   | 000    |        | 000   | 000   | 000   | 0.05 | CCT.    |     |           |            |
| 0060      | 060      | 061    | 062    | 063     | 064    | 065    | 066    | 067    | 068   | 069    | 06A    | 068   | 060   | 060   | UGE  | 00-     |     |           |            |
| 0070      | 070      | 071    | 072    | 073     | 074    | 075    | 076    | 077    | 078   | 079    | 07A    | 07B   | 07C   | 07D   | 07E  | 07F     |     |           |            |
| 0080      | 080      | 081    | 082    | 083     | 084    | 085    | 086    | 087    | 088   | 089    | 08A    | 08B   | 080   | 080   | 08F  | 08F 1   | -   |           |            |
|           |          |        |        |         |        |        |        |        |       |        |        |       |       |       |      |         |     |           |            |

Figure 2-16 • DPSRAM\_0 Contents

## Forcing a Design Modification

The design reads the contents of the DPSRAM and compares it to a synchronized counter in the checker which is looking for errors. If the contents of the DPSRAM is modified it will break the count pattern and cause an error in the checker.

Modify the contents of the DPSRAM and force an error as follows:

- 1. Read the memory content, as shown in Figure 2-16
- 2. In the Active Probe tab, read the probes
- 3. Power cycle the board (turn off and on the board power)
- Note: Since SmartDebug is accessing the SRAM at the same time the counter is writing to the SRAM (due to a known issue) the error LED will go off. To work around this current issue, turn off and on the board power before proceeding. There is no need to restart SmartDebug.
  - Once the board comes back up, read the active probe again. There will be an error, which can be ignored.
  - 5. Read the active probes the second time. On the second read there will be no errors and the LED should come on indicating no errors.
  - 6. Go to the Memory Blocks tab, select an entry and double-click. Each entry is 9-bits wide.



- 7. Modify the value from the current value to break the count pattern, as shown in Figure 2-17.
- 8. Select Write Block to write the modified value to the SRAM.
- 9. The error LED light should go off, indicating an error in the counting pattern.



Figure 2-17 • Modifying DPSRAM Contents

In the **Active Probes** tab, perform a read and you can see that the error signal is now High, refer to Figure 2-18.

| FPGA Array Debug Data | Probes Memory Blocks                    |       |      |                |  |
|-----------------------|-----------------------------------------|-------|------|----------------|--|
| Live Probes Acuve P   | Active Probe Data                       |       |      |                |  |
|                       | Name                                    | Туре  | þ    | Value          |  |
|                       | Fabric_Debug_0/count_0_coutA[0]:Fabric  | Logic | High | <del>ه</del> ٦ |  |
| Select Active Probes  | Fabric_Debug_0/count_0_coutA[1]:Fabric  | Logic | High | <del>ه</del> ٦ |  |
| Read Active Probes    | Fabric_Debug_0/count_0_coutA[2]:Fabric  | Logic | High | 0 7            |  |
| Write Active Probes   | Fabric_Debug_0/count_chk_0/sync:Fabric  | Logic | High | 0 7            |  |
|                       | error_c:Fabric_Debug_0/count_chk_0/erro | Logic | High | 0 1            |  |
|                       |                                         |       |      |                |  |

Figure 2-18 • High Error Signal after Forcing an Error

## **SERDES Debug**

This SmartDebug SERDES tutorial will assist FPGA and the board designers to perform SERDES realtime signal integrity testing and tuning in a system including:

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



1. Select **Debug SERDES** from the SmartDebug Graphical User Interface, as depicted in Figure 2-19.



#### Figure 2-19 • Debug SERDES Operation Selection

2. The Configuration tab will auto-identify and populate which SERDESIF is used in the design and the lanes and how they are programmed and powered-up. The status of each lane is shown as well as the programmed lane mode. This example demonstrates the use of SERDESIF\_0 block, as well as the lock status of the TXPLL and RXCDR. This window can be updated through the Refresh Report button, refer to Figure 2-20.

| Debug SERDES                  |                                                                                                                                                                                                                                                                                                                                                                                                                                     | ? 💌            |
|-------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| Debug SERDES<br>Configuration | SERDES Block SERDESIF_0   Configuration Report:                                                                                                                                                                                                                                                                                                                                                                                     | Refresh Report |
| RBS Jest<br>Dopback Test      | Serdes Block SERDESIF_0 :<br>Lane 0;<br>Lane mode : EPCS (2.5 GHz)<br>PMA Ready : True<br>TxPLL status : Locked<br>Lane 1;<br>Lane mode : EPCS (2.5 GHz)<br>PMA Ready : True<br>TxPLL status : Locked<br>RxCDR status : Locked<br>Lane 2:<br>Lane mode : EPCS (2.5 GHz)<br>PMA Ready : True<br>TxPLL status : Locked<br>Lane 2:<br>Lane mode : EPCS (2.5 GHz)<br>PMA Ready : True<br>TxPLL status : Locked<br>RxCDR status : Locked |                |
|                               | SERDES Register Read or Write:<br>Script:                                                                                                                                                                                                                                                                                                                                                                                           | Execute        |
| Help                          |                                                                                                                                                                                                                                                                                                                                                                                                                                     | Close          |

Figure 2-20 • SERDES Configuration Tab



3. The PRBS Test tab provides several capabilities for each Lane of the SERDES Block. The information is provided per-channel, based on the SERDES Lane selected within the GUI. For example, select Lane 0, select the Near-end Serial Loopback test type, and select PRBS7 Pattern. This test will generate and check PRBS7 data without going off-chip, as shown in Figure 2-21.

| Debug SERDES                                                         |                                                                                                                                                                                                                                                                                                                  | ~ ~           |
|----------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
|                                                                      | SERDES Block SERDESIF_0                                                                                                                                                                                                                                                                                          |               |
| Debug SERDES<br>Configuration<br>Tests<br>PRBS Test<br>Loopback Test | SERDES Lanes:  Lane 0 Lane 0 Lane 1 Lane 2 Lane 3 Lane 0 status: TXPLL RXCDR  Test Type:  Near End Serial Loopback (On-Die) Serial Data (Off-Die) Pattern:  PRBS7 All Zeros (000000) PRBS11 All Ones (111111) PRBS 23 Alternated (10101010) PRBS 31 Dual Alternated (11001100) Ver Defined  Error Count: 0 Reset | Start<br>Stop |
| Help                                                                 |                                                                                                                                                                                                                                                                                                                  | Close         |
| igure 2-21 • SERDES Test Tab                                         |                                                                                                                                                                                                                                                                                                                  |               |
| C                                                                    |                                                                                                                                                                                                                                                                                                                  |               |



As shown in Figure 2-22, the Lane 0 status is indicated after Starting the test. The green LEDs indicate the lock status of the TXPLL and RXCDR for the selected Lane.

In this example setup, the datastream is expected to see zero errors as the datapath does not go off-chip while using the Near-end Serial Loopback. The Error Count will increment up to 255. The Reset button will clear the count and the counter will continue to count while the test continues to run.

| _                      | SERDES Block SERDESIF_0                                     |  |
|------------------------|-------------------------------------------------------------|--|
| Debug SERDES           | SERDES Lanes:                                               |  |
| Configuration<br>Tests | Lane 0 status: TxPLL  RxCDR                                 |  |
| PRBS Test              | Test Type:                                                  |  |
| Loopback Test          | ⊚ Near End Serial Loopback (On-Die) 💿 Serial Data (Off-Die) |  |
|                        | Pattern:                                                    |  |
|                        | PRBS7     All Zeros ( 000000)                               |  |
|                        | PRBS11     All Ones ( 111111 )     Start                    |  |
|                        | PRBS 23     Alternated (10101010)     Stop                  |  |
|                        | PRBS 31 Dual Alternated (1100 1100)                         |  |
|                        | O User Defined                                              |  |
|                        | Error Count:                                                |  |
|                        | 0 Reset                                                     |  |
|                        |                                                             |  |
|                        |                                                             |  |
|                        |                                                             |  |

#### Figure 2-22 • SERDES Link Status

3

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



4. Stop the test and change the Test Type to **Serial Data (Off-Die)**. Restart and observe the Lane 0 error counter. This is due to the fact that the data is no longer looping between Tx and Rx. Lane 0 is not looped together on the PCB. In this case, the error count will increment up to the maximum 255, as shown in Figure 2-23.

| Debug SERDES                                 | SERDES Block SERDESIF_0                                       | ? 💌   |
|----------------------------------------------|---------------------------------------------------------------|-------|
| Debug SERDES<br>Configuration                | SERDES Lanes:                                                 |       |
| <ul> <li>Tests</li> <li>PRBS Test</li> </ul> | Test Type:                                                    |       |
| Loopback Test                                | 🔘 Near End Serial Loopback (On-Die) 🛛 🔘 Serial Data (Off-Die) |       |
|                                              | Pattern:                                                      |       |
|                                              | PRBS7                                                         | Start |
|                                              | O PRBS11 O All Ones (111111)                                  |       |
|                                              | PRBS 23 Alternated (10101010)                                 | Stop  |
|                                              | PRBS 31 Dual Alternated (1100 1100)                           |       |
|                                              | User Defined                                                  |       |
|                                              | Error Count:                                                  |       |
|                                              | 255 Reset                                                     |       |
|                                              |                                                               |       |
|                                              |                                                               |       |
|                                              |                                                               |       |
| Help                                         |                                                               | Close |

Figure 2-23 • Sending Serial Tx Data Off-Die

5



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 being transmitted and received intact. The example demonstrates this, select Lane 1, select the Serial Data test type, and select PRBS7 Pattern. This test will generate and check PRBS7 data going off-chip and folded back on the PCB to the receiver, refer to Figure 2-24.

| _                      | SERDES Blo           | serdesif_0                                  | _     |
|------------------------|----------------------|---------------------------------------------|-------|
| Debug SERDES           | SERDES Lanes: 🔘 La   | ane 0 🔘 Lane 1 🔘 Lane 2 🔘 Lane              | 23    |
| Configuration<br>Tests | Lane 1 status: TxPLL | RxCDR                                       |       |
| PRBS Test              | Test Type:           |                                             |       |
| Loopback Test          | 🔘 Near End Seria     | l Loopback (On-Die) 🔘 Serial Data (Off-Die) |       |
|                        | Pattern:             |                                             |       |
|                        | PRBS7                | All Zeros ( 000000)                         |       |
|                        | PRBS11               | O All Ones ( 111111 )                       | Start |
|                        | PRBS 23              | Alternated (10101010)                       | Stop  |
|                        | PRBS 31              | O Dual Alternated (1100 1100)               |       |
|                        | O User Defined       |                                             |       |
|                        | Error Count:         |                                             |       |
|                        | 0 Reset              |                                             |       |
|                        |                      |                                             |       |
|                        |                      |                                             |       |
|                        |                      |                                             |       |

Figure 2-24 • Lane 1 Transmitting Data Through On-Board Loopback

S



6. The Tx and Rx channels of Lane 2 can be interconnected in a loop-back configuration using coax cables. In this example, as shown in Figure 2-25 and Figure 2-26, after connecting a pair of high-quality 50-Ohm SMA cables to the SMA connections on the Evaluation Kit board, the SERDES debug can be used to send data off-board and check for errors. This requires selection of Lane 2 and Serial Data (Off-Die). A PRBS7 pattern is chosen in the example test.

| 💷 Debug SE             | RDES                                                                       |                          | ? 💌           |  |
|------------------------|----------------------------------------------------------------------------|--------------------------|---------------|--|
|                        |                                                                            | k SERDESIF_0             |               |  |
|                        | ES SERDES Lanes: Lan<br>uration Lane 2 status: TxPLL<br>IS Test Test Type: | ie 0 🔿 Lane 1 🔘 Lane 2 🔿 | Start<br>Stop |  |
| Help                   |                                                                            |                          | Close         |  |
| Figure 2-25 • External | Cable Loopback                                                             |                          |               |  |
| C                      | E 220 - External Gable Loopsdex                                            |                          |               |  |





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

| Debug SERDES               |                      |                                          | 2 🗵   |
|----------------------------|----------------------|------------------------------------------|-------|
| _                          | SERDES Blod          | k SERDESIF_0 *                           | - (   |
| Debug SERDES               | SERDES Lanes: 🔘 Lan  | e 0 💿 Lane 1 💿 Lane 2 💿 L                | ane 3 |
| Configuration<br>Tests     | Lane 2 status: TxPLL | RxCDR                                    |       |
| PRBS Test<br>Loopback Test | Test Type:           |                                          |       |
| LOOPDACK IESt              | Near End Serial L    | .oopback (On-Die) 💿 Serial Data (Off-Die |       |
|                            | Pattern:             |                                          |       |
|                            | PRBS7                | All Zeros ( 000000)                      | Start |
|                            | PRBS11               | O All Ones ( 111111)                     |       |
|                            | PRBS 23              | O Alternated ( 10101010)                 | Stop  |
|                            | PRBS 31              | Oual Alternated ( 1100 1100 )            |       |
|                            | O User Defined       |                                          |       |
|                            | Error Count:         |                                          |       |
|                            | 255 Reset            |                                          |       |
|                            |                      |                                          |       |
|                            |                      |                                          |       |
|                            |                      |                                          |       |
| Help                       |                      |                                          | Close |
|                            |                      |                                          |       |

Figure 2-27 • Lane 2 Transmitting Data Off-Board





#### Figure 2-28 • Connecting Lane 2 to the Test Equipment

Several test patterns are available from the test pattern generator. They include several PRBS and constant patterns. Not all patterns are suited for all applications. For instance, all ones or all zeros will not be useful with AC-coupled channels; as the DC-offset is removed producing a signal that is at-ground. If using the generator to send data to the test equipment, some test equipment cannot tolerate the long run-lengths of some of the PRBS patterns. PRBS7 is a very typical pattern for testing signal integrity in communication applications.

Bit Error Rate (BER) is simply counting the number of errors over time to provide a level of confidence of 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 GUI provides an error counter allowing the user to do any 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, users can receive data from a far-end source and fold the received data (Rx) back out of the transmitter (Tx).

In the example below, Figure 2-29 on page and Figure 2-30 on page, by using the Evaluation Board traffic is received from a far-end transmit source, such as another device or test equipment. It is received into Lane 2 and looped back out the transmitter.

This is accomplished by selecting SERDES Lane 2, selecting the PCS Far End PMS Rx to Tx Test Type, and Start to complete the setup.

Traffic entering the SMA connectors on Lane 2 of the Evaluation board will be observed coming off the board on the Tx SMA connectors.

Note: In this test, the IGLOO2 Evaluation board must use the same SERDES reference clock as the farend. The data path through the SERDEIF goes through the CDR and reclocks the data to the local REFCLK. This requires 0ppm difference between the far-end clock source and the Eval-Kit clock source. For this, use the SMA inputs [designators J17 & J21] of the board rather than the local onboard oscillator, as the input of the SERDES REFCLK.









## **Tcl Support**

The SERDES Debug tool set permits execution of Tcl scripts. This scripting capability 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 will be 0x40028000).

PCIe Core register map

Lane 0 registers

Lane 1 registers

Lane 2 registers

Lane 3 registers

SERDESIF system register map

#### Example Tcl applications:

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

0x0000 - 0x0FFF

0x1000 – 0x13FF 0x1400 – 0x17FF

0x1800 – 0x1BFF 0x1C00 – 0x1FFF

0x2000 - 0x23FF

Reference the IGLOO2 High-Speed Serial Users Guide for register map details.

Attempt only to read the lanes which 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
```

```
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 which lanes are accessed in the design. In this example, simply reading the CONFIG\_PHY\_MODE\_1 register and passing its value and the associated offset will target the correct lane.

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

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

From the Configuration Tab GUI, there is a dialogue box to import an executable Tcl script. The script will contain commands to write/read registers in using a flattened top for most address mapping. Simply browse to the Tcl script file and Execute, refer to Figure 2-31.

| Configuration<br>4 Tests   | Configuration Report:                                                                                                                                                                                                                                                                                                                                                                              |                |
|----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| ▲ Tests                    |                                                                                                                                                                                                                                                                                                                                                                                                    |                |
| PRBS Test<br>Loopback Test | Serdes Block SERDESIF_0 :<br>Lane 0 :<br>Lane mode : EPCS (2.5 GHz)<br>PMA Ready : True<br>TXPLL status : Locked<br>RxCDR status : Locked<br>Lane 1 :<br>Lane mode : EPCS (2.5 GHz)<br>PMA Ready : True<br>TXPLL status : Locked<br>RxCDR status : Locked<br>Lane 2 :<br>Lane mode : EPCS (2.5 GHz)<br>PMA Ready : True<br>TXPLL status : Locked<br>RxCDR status : Locked<br>RxCDR status : Locked | Refresh Report |
|                            | SERDES Register Read or Write:<br>Script: C:/Work/serdes0_config.tcl                                                                                                                                                                                                                                                                                                                               | Execute        |

#### Figure 2-31 • TCL Script Execution User Interface



Upon execution of the Tcl SERDES access, log of the access is displayed in the Libero SoC Console Log pane, as shown in Figure 2-32.



#### Figure 2-32 • SERDES Access Log

Refer to the Appendix for more Tcl examples.

## Executing SERDES Debug from SmartDebug Tcl

#### PRBS:

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>

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

-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. Should be between 0 and 4 and varies between dies.

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

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



-pattern < Pattern Type>: The pattern sequence to use for 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:

- 1. If custom is selected above, then it should be one of all\_zeros, all\_ones, alternated, or dual\_alternated.
- 2. If user is selected above, then it should 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:

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

```
loopback_test [-deviceName <device name>] -stop -serdes <num> -lane <num>
```

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

- 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. Should be between 0 and 4 and varies between dies.
- lane <num>: SERDES lane number. Should be between 0 and 4.
- type <LoopbackType>: Specifies the loopback test type. Should 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 from the GUI. Below 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. While 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.



## A – 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"



# 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"



# **B** – List of Changes

| Date         | Version | Changes                                                             |
|--------------|---------|---------------------------------------------------------------------|
| April 2014   | 3       | Added Note in "1. Specifying Live Probe Points" section (SAR 56593) |
| March 2014   | 2       | Updated the software version from 11.2SP1 to 11.3 (SAR 56012).      |
|              |         | Updated design files using the latest 11.3 SERDES core (SAR 56012)  |
| January 2014 | 1       | Initial release.                                                    |
|              |         |                                                                     |



# C – 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**

Visit the Customer Support website for more information and support. Many answers available on the searchable web resource include diagrams, illustrations, and links to other resources on the website.

## Website

You can browse a variety of technical and non-technical information on the Microsemi SoC home page.

## **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:

Technical support email address: 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 at: soc\_tech@microsemi.com or contact a local Sales office listing at Sales.Support@Microsemi.com.

## **ITAR Technical Support**

Contact technical support at: soc\_tech\_itar@microsemi.com for RH and RT FPGAs that are regulated by International Traffic in Arms Regulations (ITAR). 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 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 Microsemi Corporation (NASDAQ: MSCC) offers a comprehensive portfolio of semiconductor and system solutions for communications, defense and 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; 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,400 employees globally. Learn more at **www.microsemi.com**.

© 2014 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.