# UG0926 User Guide PolarFire SoC FPGA MSS Simulation

NOTE: PDF files are intended to be viewed on the printed page; links and cross-references in this PDF file may point to external files and generate an error when clicked. View the online help included with software to enable all linked content.



а 🕂 Міскоснір company



## **Revision History**

### **Revision 1.0**

First publication of this document.



# **Table of Contents**

| 1 – INTRODUCTION                                 | 3      |
|--------------------------------------------------|--------|
| 2 – CREATING A PROJECT                           | 4      |
| 3 – SIMULATION FLOW                              | 6      |
| FIC INTERFACE INTERRUPTS                         | 6<br>9 |
| 4 – LIMITATIONS                                  |        |
| 5 – PRODUCT SUPPORT                              | 14     |
| Customer Service                                 | 14     |
| CUSTOMER TECHNICAL SUPPORT CENTER                | 14     |
| TECHNICAL SUPPORT                                | 14     |
| WEBSITE                                          | 14     |
| CONTACTING THE CUSTOMER TECHNICAL SUPPORT CENTER | 14     |



# 1 – Introduction

The PolarFire SoC FPGA's Microcontroller Subsystem (MSS) is modeled with Microsemi's AMBA Bus Functional Model (BFM) and it is limited at FIC itself. For information about the supported instructions and syntax of the BFM commands, refer to the <u>Microsemi DirectCore AMBA BFM User's Guide</u>.

Simulation can be useful in the following situation.

- Verifying the connectivity and addressing of peripherals in the Fabric that are connected to the MSS using the Fabric Interface Controllers (FICs).
- Generation of M2F and F2M interrupt.



## 2 – Creating a Project

Use the MSS stand-alone Configuration tool and Libero SoC to create MSS-based designs. Some steps of design creation are listed here; however, we recommend you refer to the <u>MSS Standalone Configurator User Guide</u> for more information.

- 1. Create the MSS configurator using the pfsoc\_mss application by either creating a new configuration (.cfg) file or opening an existing one.
- 2. Configure the MSS subsystem with the required FIC interface and other necessary modules.
- 3. Generate the MSS component file(.cxz).

After you finish with the MSS stand-alone configuration, import the MSS subsystem in Libero, and then design the entire system, as follows:

- 1. Open the Libero SoC tool.
- 2. Create the project.
- 3. Invoke system builder to create your MSS block.
- 4. Import the MSS component file.
- 5. Design your entire system using MSS, AXI4 interconnect, fabric slaves, and fabric masters.

A typical system should resemble the ones in the following figures.



Figure 1 · Example 1: Typical Smart Design Block





Figure 2 · Example 2: Typical Smart Design Block

6. After designing the entire system, check the DRC and generate the system.

Libero generates three BFM files for three master FIC interfaces in a simulation folder (see Figure 3).

|     | nulation                                        |
|-----|-------------------------------------------------|
|     | ntovec.exe                                      |
|     | bfmtovec.lin                                    |
|     | bfmtovec_compile.log                            |
|     | bfmtovec_compile.tcl                            |
| 😐 💼 | COREAPB3_LIB                                    |
|     | coreapb3_usertb_master.bfm                      |
|     | coreapb3_usertb_master.vec                      |
|     | coreuart_usertb_apb_master.bfm                  |
|     | coreuart_usertb_include.bfm                     |
|     | modelsim.ini                                    |
|     | modelsim.ini.sav                                |
|     | parameter_incl.v                                |
|     | PCIE_0.vec                                      |
|     | PCIE_0_compile_bfm.tcl                          |
|     | PF_PCIE_C0_PF_PCIE_C0_0_PF_PCIE_PCIE_0_user.bfm |
|     | PFSOC_MSS_C0_PFSOC_MSS_FIC0_compile_bfm.tcl     |
|     | PFSOC_MSS_C0_PFSOC_MSS_FIC0_user.bfm            |
|     | PFSOC_MSS_C0_PFSOC_MSS_FIC1_compile_bfm.tcl     |
|     | PFSOC_MSS_C0_PFSOC_MSS_FIC1_user.bfm            |
|     | PFSOC_MSS_C0_PFSOC_MSS_FIC3_compile_bfm.tcl     |
|     | PFSOC_MSS_C0_PFSOC_MSS_FIC3_user.bfm            |
|     | PFSOC_MSS_FIC0.vec                              |
|     | PFSOC_MSS_FIC1.vec                              |
| - E | PFSOC_MSS_FIC3.vec                              |

Figure 3 · BFM Files in the Simulation Folder

7. Add the supported BFM instructions in these BFM files to perform the simulation.



## 3 – Simulation Flow

## **FIC** interface

PolarFire SoC FPGA provides multiple Fabric Interface Controllers (FIC) to enable connectivity between user logic in the FPGA fabric and the Microprocessor Subsystem (MSS). FIC is part of the MSS, and acts as a bridge between MSS and the fabric.

### **BFM Commands**

All BFM commands used in PolarFire PCI BFM and SmartFusion2 FPGA High Speed Serial Interface Simulation can be used to simulate the MSS.

The following shows a typical BFM example.

```
procedure main;
```

memmap FPR\_BASE\_ADDR 0x206000000;

int u;

```
int l;
write64 w FPR_BASE_ADDR 0x0 0x10102020 0xaaaaaaaa
read64 w FPR_BASE_ADDR 0x0
readcheck64 w FPR_BASE_ADDR 0x0 0x10102020 0xaaaaaaaa
readstore64 x FPR_BASE_ADDR 0x0 u l
print "Lower 32bits = %h", l
print "Upper 32bits = %h", u
readmask64 x FPR_BASE_ADDR 0x0 0x10102020 0xaaaaaaaa 0xFFFFFFFF 0x0000FFFF
readstore64 x FPR_BASE_ADDR 0x0 u l
print "Lower 32bits = %h", l
print "Lower 32bits = %h", l
print "Lower 32bits = %h", l
```

```
writemult64 w FPR_BASE_ADDR 0x0 0xFFFFFFF 0xEEEEEEEE 0xAAAAAAAA 0xBBBBBBBB 0xCCCCCCC
0xDDDDDDD 0x01010101 0x02020202 0x0303030 0xBADCAD00
readmult64 w FPR_BASE_ADDR 0x0 5
readmultchk64 w FPR_BASE_ADDR 0x0 0xFFFFFFF 0xEEEEEEEE 0xAAAAAAAA 0xBBBBBBBB
0xCCCCCCCC 0xDDDDDDDD 0x01010101 0x02020202 0x0303030 0xBADCAD00
return
```



After adding a testbench to your design, you can perform MSS simulation with these BFM files by launching the Per-Synth simulation (see Figure 4).

Figure 4 · Simulation Launching



The simulation transcript window displays the BFM transactions, as shown in the following figures.

ala writt PFSOC\_FIC\_0\_BFM:25:readmult64 x 00000020 600f0000 10 at 568 ns PFSOC FIC 0 BFM: Data Write 20600f0018 0101010102020202 PFSOC\_FIC\_0\_BFM: Data Write 20600f0020 03030303badcad00 PFSOC\_FIC\_0\_BFM: Data Read 20600f0000 ffffffffeeeeeee at 895.179000ns PFSOC\_FIC\_0\_BFM: Data Read 20600f0008 aaaaaaaabbbbbbbbb at 905.181000ns PFSOC\_FIC\_0\_BFM: Data Read 20600f0010 ccccccccdddddddd at 915.183000ns # PFSOC\_FIC\_0\_BFM:26:readmultchk64 x 00000020 600f0000 fffffffff ... at 919 ns
# PFSOC\_FIC\_0\_BFM: Data Read 20600f0018 01010102020202 at 925.185000ns # PFSOC\_FIC\_0\_BFM: Data Read 20600f0020 03030303badcad00 at 935.187000ns VSIM 2> run # PFSOC\_FIC\_0\_BFM: Data Read 20600f0000 ffffffffeeeeeee MASK:fffffffffffffffff at 1085.217000ns PFSOC\_FIC\_0\_BFM: Data Read 20600f0008 aaaaaaaabbbbbbbbb MASK:fffffffffffffffffff at 1095.219000ns PFSOC\_FIC\_\_BFM: Data Read 20600f0010 cccccccddddddd MASK:fffffffffffffffffff at 1105.221000ns PFSOC\_FIC\_0\_BFM:31:return # PFSOC\_FIC\_\_BFM: Data Read 20600f0018 0101010102020202 MASK:fffffffffffffffffff at 1115.223000ns # PFSOC FIC 0 BFM: Data Read 20600f0020 03030303badcad00 MASK:ffffffffffffffffff at 1125.225000ns \*\*\*\*\*\*\*\* FIC 0 BFM Simulation Complete - 7 Instructions - NO ERRORS \*\*\*\*\*

Figure 5 · MSS FIC Simulation Log – FIC\_0 as Master

| # BFM:26:readmult64 x 600f0000 10 at 1185 ns                                         |
|--------------------------------------------------------------------------------------|
| # BFM: Data Write 600f0018 01010102020202                                            |
| # FIC_0: 64 Bit Write 600f0000=ffffffffeeeeeeee at 1235 ns                           |
| # FIC_0: 64 Bit Write 600f0008=aaaaaaabbbbbbbbb at 1245 ns                           |
| # FIC_0: 64 Bit Write 600f0010=cccccccdddddddd at 1255 ns                            |
| # FIC_0: 64 Bit Write 600f0018=0101010102020202 at 1265 ns                           |
| # FIC_0: 64 Bit Write 600f0020=03030303badcad00 at 1275 ns                           |
| # BFM: Data Write 600f0020 03030303badcad00                                          |
| # FIC_0: 64 Bit Read 600f0000=ffffffffeeeeeeee at 1605 ns                            |
| # FIC_0: 64 Bit Read 600f0008=aaaaaaabbbbbbbbb at 1615 ns                            |
| # FIC_0: 64 Bit Read 600f0010=cccccccdddddddd at 1625 ns                             |
| # FIC_0: 64 Bit Read 600f0018=0101010102020202 at 1635 ns                            |
| # FIC_0: 64 Bit Read 600f0020=03030303badcad00 at 1645 ns                            |
| # BFM: Data Read 600f0000 ffffffffeeeeeeee at 1865.000000ns                          |
| # BFM: Data Read 600f0008 aaaaaaabbbbbbbbb at 1875.000000ns                          |
| # BFM: Data Read 600f0010 cccccccdddddddd at 1885.000000ns                           |
| # BFM:27:readmultchk64 x 600f0000 ffffffff at 1895 ns                                |
| # BFM: Data Read 600f0018 0101010102020202 at 1895.000000ns                          |
| # BFM: Data Read 600f0020 03030303badcad00 at 1905.000000ns                          |
| # FIC_0: 64 Bit Read 600f0000=ffffffffeeeeeeee at 1995 ns                            |
| # FIC_0: 64 Bit Read 600f0008=aaaaaaabbbbbbbbb at 2005 ns                            |
| # FIC_0: 64 Bit Read 600f0010=cccccccdddddddd at 2015 ns                             |
| # FIC_0: 64 Bit Read 600f0018=0101010102020202 at 2025 ns                            |
| # FIC_0: 64 Bit Read 600f0020=03030303badcad00 at 2035 ns                            |
| # BFM: Data Read 600f0000 ffffffffeeeeeee MASK:ffffffffffffffff at 2255.000000ns     |
| # BFM: Data Read 600f0008 aaaaaaabbbbbbbbb MASK:ffffffffffffffffff at 2265.000000ns  |
| # BFM: Data Read 600f0010 cccccccdddddddd MASK:ffffffffffffffffffffffffffffffffffff  |
| # BFM:33:return                                                                      |
| # BFM: Data Read 600f0018 01010102020202 MASK:ffffffffffffffffffff at 2285.000000ns  |
| # BFM: Data Read 600f0020 03030303badcad00 MASK:ffffffffffffffffffffffffffffffffffff |
| ***************************************                                              |
|                                                                                      |
| # PCIE1 BFM Simulation Complete - 7 Instructions - NO ERRORS                         |
| <b> </b>   <b>#</b>                                                                  |
| ***************************************                                              |

Figure 6 · MSS FIC Simulation Log - FIC\_0 as Slave



### **F2H Interrupts**

The MSS simulation model acknowledges the assertion of F2H interrupts. (Fabric to MSS)

There are 64 F2H interrupt ports. MSS acknowledges them by printing a message on reception of valid active high interrupt (see Figure 7).

| _   |   |      |   |                    |     |          |
|-----|---|------|---|--------------------|-----|----------|
|     | ٠ | INFO | : | F2H_INTERRUPT(63)  | 13  | asserted |
|     | • | INFO | I | F2H INTERRUPT [62] | 13  | asserted |
|     | ٠ | INFO | : | F2H INTERRUPT [61] | 13  | asserted |
| 1   | • | INFO | : | F2H INTERRUPT [60] | 13  | asserted |
|     | • | INFO | : | F2H_INTERRUPT[59]  | 13  | asserted |
|     | ٠ | INFO | : |                    |     |          |
|     | • | INFO |   | F2H INTERRUPT [57] | 1.5 | asserted |
|     | • | INFO | : | F2H_INTERRUPT[56]  | 1.0 | asserted |
|     | • |      |   | F2H INTERRUPT (55) |     |          |
| 1   | • | INFO | : | F2H INTERRUPT [54] | 13  | asserted |
|     | • | INFO |   | F2H INTERRUPT [53] | 1.3 | asserted |
|     |   | INFO | : | F2H INTERRUPT [52] | 1.0 | asserted |
|     |   | INFO |   | F2H INTERRUPT [51] | 13  | asserted |
|     |   | INFO | : |                    |     |          |
|     |   | INFO | : |                    |     |          |
|     | • | INFO | : | F2H INTERRUPT [48] | 13  | asserted |
| 1   |   | INFO | : | F2H INTERRUPT [47] | 13  | asserted |
|     | ٠ | INFO | : | F2H_INTERRUPT[46]  | 1.5 | asserted |
|     | • |      |   | F2H INTERRUPT [45] |     |          |
|     | • | INFO |   | F2H INTERRUPT (44) | 18  | asserted |
|     |   | INFO |   | F2H INTERRUPT [43] | 13  | asserted |
|     |   | INFO | : | F2H INTERRUPT [42] | 13  | asserted |
|     | • | INFO | : | F2H INTERRUPT [41] | 13  | asserted |
| 1   |   | INFO | : | F2H INTERRUPT [40] | 13  | asserted |
|     |   | INFO | : | F2H INTERRUPT (39) | 10  | asserted |
|     |   | INFO | : | F2H INTERRUPT [38] | 13  | asserted |
|     | • | INFO |   | F2H INTERRUPT [37] | 13  | asserted |
|     |   | INFO |   | F2H INTERRUPT [36] |     |          |
|     | • | INFO |   |                    |     |          |
|     |   | INFO | : | F2H INTERRUPT [34] |     |          |
|     |   | INFO | : |                    |     |          |
|     |   | INFO | : | F2H INTERRUPT [32] | 13  | asserted |
|     | ٠ | INFO | : | F2H_INTERRUPT[31]  | 13  | asserted |
| - L |   |      |   |                    |     |          |

Figure 7 · F2H Interrupt Simulation Log (Valid Interrupts)

The interrupt inputs should be high for one clock of MSS clock; otherwise, the MSS model rejects the interrupt and prints a message about the interrupt level being too low (see Figure 8).



rnco

MICROCHIP company



### H2F Interrupts

The MSS simulation model allows you to use text files to set and clear H2F interrupts (MSS to Fabric). To do this, add the following command in the run.do file, as follows:

vsim -L polarfire -L presynth -t 1ps -g H2F\_MEMFILE=(path)/\*.txt presynth.tb

Example: vsim -L polarfire -L presynth -t 1ps -g H2F\_MEMFILE=E:/mss\_sim/h2f\_sim.txt presynth.tb

There are 16 H2F interrupts. Table 1 shows their allocation in MSS.

| H2F Line | Group          |
|----------|----------------|
| 0        | GPIO           |
| 1        | MMUART,SPI,CAN |
| 2        | 12C            |
| 3        | MACO           |
| 4        | MAC1           |
| 5        | WATCHDOGS      |
| 6        | Maintenance    |
| 7        | SCB            |
| 8        | G5C-Message    |
| 9        | DDRC           |
| 10       | G5C-DEVRST     |
| 11       | RTC/USOC       |
| 12       | TIMER          |
| 13       | ENVM, QSPI     |
| 14       | USB            |
| 15       | MMC/SDIO       |

| Table 1 | · H2F | Interrupt | Allocation |
|---------|-------|-----------|------------|
|---------|-------|-----------|------------|

You use entries in the text file to set and clear an interrupt, as shown below.

| Wait time       | (Time to wait in number MSS PLL clock cycles, Hex) |
|-----------------|----------------------------------------------------|
| Interrupt Value | (16-bit value, Hex)                                |
| Wait time       | (Time to wait in number MSS PLL clock cycles, Hex) |
| Interrupt Value | (16-bit value, Hex)                                |
| <br>Example:    |                                                    |

| 100  | (Wait for 100 (256 in DEC) MSS PLL clock cycles) |
|------|--------------------------------------------------|
| FFFF | (Set all 16 interrupts)                          |
| 1000 | (Wait for 1000 (4096 in DEC) MSS clock cycles)   |
| 0000 | (Clear all 16 interrupts)                        |
|      |                                                  |



You can also clear interrupts by clearing an interrupt register bit in corresponding peripheral. These AXI transactions can be generated by a Master in fabric.

| H2F Line Group AXI Address and Data Bits to Clear an Interrupt |           |                  | a Bits to Clear an Interrupt                             |
|----------------------------------------------------------------|-----------|------------------|----------------------------------------------------------|
| 0                                                              | GPIO      | Reg              | g5soc_mss_regmap:GPIO:INTR                               |
|                                                                |           | Physical address | 0x2012 0080                                              |
|                                                                |           |                  | 0x2012 1080                                              |
|                                                                |           |                  | 0x2012 2080                                              |
|                                                                |           |                  | 0x2812 0080                                              |
|                                                                |           |                  | 0x2812 1080                                              |
|                                                                |           |                  | 0x2812 2080                                              |
|                                                                |           | Data             | Bit-0: To clear an interrupt the bit is written with '1' |
| 1                                                              | MMUART    | Reg              | g5soc_mss_regmap:MMUART:RTO                              |
|                                                                |           | Physical address | 0x2000 004C                                              |
|                                                                |           |                  | 0x2010 004C                                              |
|                                                                |           |                  | 0x2010 204C                                              |
|                                                                |           |                  | 0x2010 404C                                              |
|                                                                |           |                  | 0x2010 604C                                              |
|                                                                |           |                  | 0x2800 004C                                              |
|                                                                |           |                  | 0x2810 004C                                              |
|                                                                |           |                  | 0x2810 204C                                              |
|                                                                |           |                  | 0x2810 404C                                              |
|                                                                |           |                  | 0x2810 604C                                              |
|                                                                |           | Data             | Writing the RTO register clears this interrupt.          |
|                                                                | SPI       | Reg              | g5soc_mss_regmap:SPI:INT_CLEAR                           |
|                                                                |           | Physical address | 0x2010 800C                                              |
|                                                                |           |                  | 0x2010 900C                                              |
|                                                                |           |                  | 0x2810 800C                                              |
|                                                                |           |                  | 0x2810 900C                                              |
|                                                                |           | Data             | Bit-5: Write one to clear the interrupt                  |
|                                                                |           |                  | Bit-4: Write one to clear the interrupt                  |
|                                                                | CAN       |                  | Support will be added in a future Libero release         |
| 2                                                              | 12C       |                  | Support will be added in a future Libero release         |
| 3                                                              | MAC0      |                  | Support will be added in a future Libero release         |
| 4                                                              | MAC1      |                  | Support will be added in a future Libero release         |
| 5                                                              | WATCHDOGS |                  | Support will be added in a future Libero release         |

| Table 2 · H2F Vr | terrupt Clearing A | Addresses |
|------------------|--------------------|-----------|
|------------------|--------------------|-----------|



| H2F Line | Group       | AXI Address and Data Bits to Clear an Interrupt  |  |  |
|----------|-------------|--------------------------------------------------|--|--|
| 6        | Maintenance | Support will be added in a future Libero release |  |  |
| 7        | SCB         | Support will be added in a future Libero release |  |  |
| 8        | G5C-Message | Support will be added in a future Libero release |  |  |
| 9        | DDRC        | Support will be added in a future Libero release |  |  |
| 10       | G5C-DEVRST  | Support will be added in a future Libero release |  |  |
| 11       | RTC/USOC    | Support will be added in a future Libero release |  |  |
| 12       | TIMER       | Support will be added in a future Libero release |  |  |
| 13       | ENVM, QSPI  | Support will be added in a future Libero release |  |  |
| 14       | USB         | Support will be added in a future Libero release |  |  |
| 15       | MMC/SDIO    | Support will be added in a future Libero release |  |  |



# 4 – Limitations

- The FIC AXI BFM slave does not support 38-bit addressing. When addressed with a 38-bit address from the fabric master, the AXI transaction is not considered and a message appears in the console.
- Bits 2 to 15 of the H2F interrupts cannot be cleared through FIC AXI.



## 5 – 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, **650.318.8044** 

### **Customer Technical Support Center**

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

### **Technical Support**

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

### Website

You can browse a variety of technical and non-technical information on the Microsemi SoC Products Group home page at https://www.microsemi.com/product-directory/design-resources/1750-libero-soc.

## Contacting the Customer Technical Support Center

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

#### Email

You can communicate your technical questions through our Web portal and receive answers back by email, fax, or phone. Also, if you have design problems, you can upload your design files to receive assistance. We constantly monitor the cases created from the web portal 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 can be reached at https://soc.microsemi.com/Portal/Default.aspx.



#### **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 at https://soc.microsemi.com/Portal/Default.aspx or contact a local sales office.

Visit About Us for sales office listings and corporate contacts.

Sales office listings can be found at https://www.microsemi.com/locations



а 🔨 Міскоснір company

Microsemi Headquarters One Enterprise, Aliso Viejo, CA 92656 USA Within the USA: +1 (800) 713-4113 Outside the USA: +1 (949) 380-6100 Fax: +1 (949) 215-4996 Email: sales.support@microsemi.com www.microsemi.com

©2019 Microsemi, a wholly owned subsidiary of Microchip Technology Inc. All rights reserved. Microsemi and the Microsemi logo are registered trademarks of Microsemi Corporation. All other trademarks and service marks are the property of their respective owners.

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

#### About Microsemi

Microsemi, a wholly owned subsidiary of Microchip Technology Inc. (Nasdaq: MCHP), offers a comprehensive portfolio of semiconductor and system solutions for aerospace & defense, communications, data center 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; enterprise storage and communication solutions, security technologies and scalable anti-tamper products; Ethernet solutions; Power-over-Ethernet ICs and midspans; as well as custom design capabilities and services. Learn more at www.microsemi.com.

5-02-00926-0/7.20