

## Introduction (Ask a Question)

Embedded systems for aerospace applications are more susceptible to transient faults due to radiation, EMI, voltage fluctuations, and power supply failure. Transient faults are becoming a concern at the ground level due to low core voltage, decrease in transistor geometry, and increase in switching speeds. Transient faults are real at the ground level in nuclear, automotive, and communication equipment.

To mitigate the transient and intermittent faults, lockstep systems—which are fault-tolerant computer systems—run the same set of operations on two identical systems with a known delay between them. This application note demonstrates dual-core lockstep processor architecture using soft Mi-V processor, which uses redundancy to detect the transient faults. An error is introduced by interrupting a processor and a system Reset is asserted as a response to the lockstep error detection.

## Dual-Core Lockstep Processor Architecture (Ask a Question)

The dual-core lockstep processor architecture provides real-time diagnostics using an additional processor and a comparator. Two identical processors run the same application in lockstep with a known time delay between them. Any differences between two processors outputs are flagged as an error by the comparator on cycle-by-cycle basis. A temporal delay of 0.5 to 2 clock cycles between processors is appropriate to detect most of the common errors.

## Design Requirements (Ask a Question)

The following table lists the hardware and software requirements for this demo design.

**Table 1.** Design Requirements

| Requirement                                                                                                                 | Description                                                                                                     |
|-----------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|
| <b>Hardware</b>                                                                                                             |                                                                                                                 |
| RT PolarFire® Evaluation Kit (RTPF500TS- 1CG1509)<br>• 12V, 5A AC power supply adapter and cords<br>• USB A to Mini-B cable | Rev 1.0                                                                                                         |
| <b>Software</b>                                                                                                             |                                                                                                                 |
| Libero® SoC                                                                                                                 | See the readme.txt file provided in the design files for the software versions used with this reference design. |



**Important:** Libero®, SmartDesign, and configuration screenshots provided in this guide are for illustration purpose only. Refer to the provided Libero design to see the latest updates.

## Prerequisites (Ask a Question)

Before you begin:

1. Download the design files using the following link: [www.microchip.com/en-us/application-notes/AN4228](http://www.microchip.com/en-us/application-notes/AN4228)
2. Download and install Libero SoC on the host PC from the following web page: [www.microchip.com/en-us/products/fpgas-and-plds/fpga-and-soc-design-tools/fpga/libero-software-later-versions#Download%20Software](http://www.microchip.com/en-us/products/fpgas-and-plds/fpga-and-soc-design-tools/fpga/libero-software-later-versions#Download%20Software)

## Table of Contents

|                                                                 |    |
|-----------------------------------------------------------------|----|
| Introduction.....                                               | 1  |
| Dual-Core Lockstep Processor Architecture.....                  | 1  |
| Design Requirements.....                                        | 2  |
| Prerequisites.....                                              | 2  |
| 1. Design Description.....                                      | 4  |
| 1.1. Clocking Structure.....                                    | 5  |
| 1.2. Reset Structure.....                                       | 6  |
| 1.3. Design Implementation.....                                 | 7  |
| 2. Dual-Core Lockstep Simulation.....                           | 9  |
| 3. Running the Demo.....                                        | 10 |
| 3.1. Programming the Device using Libero SoC .....              | 10 |
| 3.2. Running the Design.....                                    | 12 |
| 4. Appendix: Programming the Device using FlashPro Express..... | 13 |
| 5. Appendix: Running the TCL Script.....                        | 17 |
| 6. Revision History.....                                        | 18 |
| Microchip FPGA Support.....                                     | 19 |
| Microchip Information.....                                      | 19 |
| The Microchip Website.....                                      | 19 |
| Product Change Notification Service.....                        | 19 |
| Customer Support.....                                           | 19 |
| Microchip Devices Code Protection Feature.....                  | 19 |
| Legal Notice.....                                               | 20 |
| Trademarks.....                                                 | 20 |
| Quality Management System.....                                  | 21 |
| Worldwide Sales and Service.....                                | 22 |

**1.****Design Description** [\(Ask a Question\)](#)

The following figure shows high-level block diagram of the dual-core lockstep design. The design has two Mi-V processor cores, LSRAM, comparator logic, GPIO IPs, and Debounce logic. Mi-V Processor-1 (Manager) is responsible for all the read or write transactions from or to the system memory (LSRAM) while Mi-V Processor-2 (Subordinate) executes the instructions fetched by Mi-V Processor-1.

A temporal delay of two clock cycles is introduced by releasing the Mi-V Processor-2 Reset two cycles after the Mi-V Processor-1 Reset. The processors execution is temporally separated to detect the faults which causes the same error on both the processors. Comparator logic is used to compare the read and write transactions from the two processors, and asserts a fault if there is a transaction mismatch. This fault bit is connected to the on-board LED. A sample GPIO application which blinks user LEDs on the board is used for testing the lockstep execution.

An external input with a Debounce logic is used to generate an interrupt to Mi-V Processor-1 for introducing a fault condition. As a fault recovery mechanism, a system Reset is applied after 30 seconds of detecting the fault. This 30 seconds timer is only used to visually see the fault LED glow before the system Reset is applied.

**Figure 1-1.** Lockstep Design High-level Block Diagram



## 1.1

## Clocking Structure [\(Ask a Question\)](#)

In the design, there is a single clock domain. The on-board 50 MHz crystal oscillator is connected to the PF\_CCC block, which generates 65 MHz system clock that is given to all the design blocks, as shown in following figure.

**Figure 1-2.** Clocking Structure



**1.2****Reset Structure** [\(Ask a Question\)](#)

In this design, the CORERESET\_PF module generates the Reset signal. Reset signal to the MIV\_RV32\_C1 module is connected through ARESETN\_2D port of the processors2memory module. This ensures MIV\_RV32\_C1 comes out of Reset state two clock cycles after MIV\_RV32\_C0. The user\_rstn signal from the processors2memory module is ANDed with external Reset signal (EXT\_RST\_N) and the output is connected as an input to the CORERESET\_PF module. This is done to trigger user\_rstn 30 seconds after an error is detected, which in-turn triggers a system Reset through the CORERESET\_PF\_C0. The following figure shows the Reset structure used in the design.

**Figure 1-3.** Reset Structure



## 1.3 Design Implementation [\(Ask a Question\)](#)

The following table lists the IP cores used in the reference design.

**Table 1-1. IP Cores and Description**

| IP Core          | Description                                                                                                                                                                                                       |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MIV_RV32         | Mi-V soft processor                                                                                                                                                                                               |
| CoreJTAGDEBUG    | Facilitates the connection of JTAG compatible soft core processors to the JTAG header for debugging. It provides fabric access to the JTAG interface using the UJTAG macro.                                       |
| PF_INIT_Monitor  | System controller uses this macro to check the status of device initialization. The device initialization includes SRAM initialization from µPROM/sNVM/SPI Flash. The DEVICE_INIT_DONE signal is used as a Reset. |
| PF_SRAM_AHBL_AXI | PolarFire® LSRAM. Used as a system memory for the Mi-V processor.                                                                                                                                                 |
| PF_CCC           | Macro to access PolarFire CCC block. It is used to synthesize 65 MHz clock frequency from the CCC with an on-board 50 MHz reference clock.                                                                        |
| COREReset_PF     | Generates a Reset, which is asserted asynchronously by one of the multiple potential sources and which negates synchronously to a specified clock.                                                                |
| CoreGPIO         | Core GPIO provides an APB register-based interface with 32 GPIOs. It is used to check whether the application runs as expected.                                                                                   |
| CoreAPB3         | Provides APB fabric for interconnecting an APB Initiator and up to 16 APB targets.                                                                                                                                |

Configure two MIV\_RV32 processors with Reset vector address (RSA) set to 0x8000\_0000. In the Mi-V processors memory map, the 0x8000\_0000 to 0x8001\_FFFF range is defined for the AXI Initiator interface, and the 0x6000\_0000 to 0x6FFF\_FFFF range is defined for the APB Initiator interface. MIV-RV32\_C0 processor accesses PF\_SRAM\_AHBL\_AXI\_C0 (processor main memory, where the application code (hex file) is stored) by sending transactions between addresses 0x8000\_0000 to 0x8001\_FFFF.

The following figure shows the SmartDesign view of the dual-core lockstep design.

**Figure 1-4. Smart Design Dual-Core Lockstep Design**



The processors2memory RTL module directs the MIV-RV32\_C0 processor's read and write transactions to the PF\_SRAM\_AHBL\_AXI and delays the read data transactions from the PF\_SRAM\_AHBL\_AXI memory to MIV-RV32\_C1 processor by two clock cycles. It also delays the read address, write address, and write data transactions from the MIV-RV32\_C0 processor by two clock cycles to compare with MIV-RV32\_C1 processor's read address, write address, and write data transactions. This RTL module also has comparison logic to compare the transactions from two processors on cycle-by-cycle basis and flags an error on Lockstep\_Error output if there is a

transaction mismatch. Lockstep\_Error output gets asserted if there is any mismatch on AXI address, AXI data, or AXI sideband/control signals. This Lockstep\_Error output is mapped to an on-board LED.

MIV-RV32 processor's AXI Initiator interface connects to processors2memory module's AXI Target interface while processors2memory module's AXI Initiator interface connects to PF\_SRAM\_AHBL\_AXI module's target interface.

The APB interface of CoreGPIO IPs is connected to the initiator APB interface of MIV\_RV32 processors through CoreAPB3. CoreGPIO is configured to have 32-bits APB width and four output ports. These output ports are mapped to the debug LEDs on the board to verify whether the application code works as expected.

An I/O pad with Debounce logic is used to introduce an error in the dual-core lockstep design by asserting an interrupt (EXT\_IRQ) to the MIV-RV32\_C0 core. MIV-RV32\_C0 core switches the execution to interrupt service routine (ISR) while MIV-RV32\_C1 core continues executing its normal transactions. This leads to transactions mismatch and an error is detected.

As a fault recovery mechanism, system Reset is applied to the design after 30 seconds of detecting the fault. Here, the 30 seconds delay is used to prolong the LED glowing when the fault is detected. This is done through user RTL logic where user\_rstn output from processors2memory module is ANDed with external Reset (EXT\_RST\_N).

## 2. Dual-Core Lockstep Simulation [\(Ask a Question\)](#)

There is a HDL testbench for running the simulation for the dual-core lockstep design. Clock generator block generates 50 MHz clock. Reset generator generates active-low Reset for the design and is asserted for initial 1000 ns of running simulation.

To run the simulation:

1. Go to **Stimulus Hierarchy** and verify if the `top_tb` file is set as active stimulus. If not set, right-click on the file and select **Set as active stimulus**.
2. In the **Design Flow** tab, double-click **Simulate** under **Verify Pre-Synthesized Design** to simulate the design as shown in the following figure.

**Figure 2-1.** Run Simulation



The following figure shows the simulation waveform for the dual-core lockstep design highlighting the data and address transactions from both the processors. The address, data, and control signals coming out from the two processors are matching and their corresponding faults are zero until the error is introduced as highlighted. The design is kept in the Reset state for initial 1000 ns.

**Figure 2-2.** Dual-core Lockstep Simulation



### 3. Running the Demo [\(Ask a Question\)](#)

This chapter describe the steps to program the RT PolarFire device with the dual-core lockstep design and detailed procedure to inject faults in the design through the SmartDebug tool.

Before programming the RT PolarFire device, check the following:

- Ensure the jumper settings on the board is same as the default jumper settings specified in *RT PolarFire Evaluation Kit User Guide*.
- Connect the host PC to the J24 connector using the USB cable.
- Connect the power supply to the J19 connector and switch ON the power supply switch, SW7.

#### 3.1 Programming the Device using Libero SoC [\(Ask a Question\)](#)

The RT PolarFire device can be programmed using the provided Libero SoC project. The following figure shows the Libero design flow.

**Figure 3-1.** Libero Design Flow Program Action



To program the device, follow these steps:

1. Open the design in Libero SoC. The Libero **Design Flow** window appears.
2. Double-click **Configure Design Initialization Data and Memories** on the **Design Flow** tab.

3. In the **Fabric RAMs** tab, double-click on **PF\_SRAM\_AHBL\_AXI\_C0\_0** from the list of logical instances and click **Edit**.
4. In the **Edit Fabric RAM Initialization Client** window, ensure that the storage type is selected as sNVM and in the **Import Memory file location**, `sample_gpio.hex` is properly located as shown in the following figure. The system controller initializes the RAM instance with the sNVM client's content at power-up.

**Figure 3-2.** Edit Fabric RAM Initialization Client

5. In the **sNVM** tab, ensure that the sNVM client is added as shown in the following figure.

**Figure 3-3.** sNVM Tab

6. Double-click **Run PROGRAM Action**. Once the device is successfully programmed, a green tick appears on **Run PROGRAM Action**.



**Important:** To program the device using FlashPro Express, see [4. Appendix: Programming the Device using FlashPro Express](#).

### 3.2

## Running the Design [\(Ask a Question\)](#)

Once the device is programmed, LED2, LED3, LED6, and LED7 continuously toggle which ensures that the MIV-RV32\_C0 and MIV-RV32\_C1 are in lockstep. To inject fault, follow these steps:

1. Press external push button, SW1.
2. LED8 on the board glows to show the lockstep error is introduced.
3. System Reset must be asserted after 30 seconds of detecting the fault. When the system Reset is released, application code restarts and lockstep error is zero. LED1, LED5, and LED8 stops glowing.



**Important:** LED1 glows as the Interrupt Service Routine (ISR) is called after the external IRQ is triggered for MIV-RV32\_C0. The same set of instructions to execute the ISR for MIV-RV32\_C0 reaches MIV-RV32\_C1 (through the read bus) which glows LED5. When interrupt is asserted, there is a difference in MIV-RV32\_C0 and MIV-RV32\_C1 output ports for few clock cycles, which asserts the lockstep error, but the MIV-RV32\_C1 might sync-up with MIV-RV32\_C0 as the valid instructions are delivered to MIV-RV32\_C1 as well. Hence, LED2, LED3, LED6, and LED7 continue to toggle. Ideally, there should be a system Reset or corrective action immediately after the lockstep error.

This concludes the demo.

## 4. Appendix: Programming the Device using FlashPro Express [\(Ask a Question\)](#)

This section describes how to program the RT PolarFire device with the .job programming file using FlashPro Express. The .job file is available at the following design files folder location:  
<download\_folder>\Programming\_Job

To program the device, complete the following steps:

1. On the host PC, launch the **FlashPro Express** software.
2. Click **New** or select **New Job Project** from **Project** menu to create a new job project, as shown in the following figure.

**Figure 4-1.** New Job Project-FlashPro Express



3. Enter the following in the **Create New Job Project** dialog box:

- **Programming job file:** Click **Browse** and navigate to the location where the .job file is located and select the file. The default location is: <download\_folder>\Programming\_Job
- **FlashPro Express job project location:** Click **Browse** and navigate to the location where you want to save the project.

**Figure 4-2.** Create New Job Project

4. Click **OK**. The required programming file is selected and ready to be programmed in the device.
5. The **FlashPro Express** window appears as shown in the following figure. Confirm that a programmer number appears in the Programmer field. If it does not, confirm the board connections and click **Refresh/Rescan Programmers**.

**Figure 4-3.** Refresh/Rescan Programmers

6. Click **RUN** to program the device. When the device is programmed successfully, a **PROGRAMMER(S) PASSED** status is displayed as shown in the following figure.

**Figure 4-4.** Programming Successful

## 7. Close FlashPro Express, Project > Exit.

See [3. Running the Demo](#) section to run the demo.

## 5. Appendix: Running the TCL Script [\(Ask a Question\)](#)

TCL scripts are provided in the design files folder under the `TCL_Scripts` directory. If required, the design flow can be reproduced from Design Implementation till the generation of `.job` file.

To run the TCL script, follow the steps:

1. Launch the Libero SoC.
2. Click **Project > Execute Script**.
3. Click **Browse** and select `script.tcl` from  
`<$Download_Directory>\rtpf_an4228_v2023p2_df\TCL_Scripts`.
4. Click **Run**. After successful execution of TCL script, Libero project is created within `TCL_Scripts` directory. For more information about TCL scripts, see `<$Download_Directory>\rtpf_an4228_v2023p2_df/TCL_Scripts/TCL_Scripts_readme.txt`.  
For more information about TCL commands, see [Libero® SoC TCL Command Reference Guide](#). Contact [Microchip Support](#) for any queries encountered when running the TCL script.

## 6. Revision History [\(Ask a Question\)](#)

The revision history table describes the changes that were implemented in the document. The changes are listed by revision, starting with the most current publication.

**Table 6-1.** Revision History

| Revision | Date    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|----------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| B        | 09/2023 | <p>The following is the list of changes in the revision B of the document:</p> <ul style="list-style-type: none"><li>• Updated part number and revision number of the RT PolarFire Evaluation Kit <a href="#">Table 1</a></li><li>• Updated <a href="#">Figure 1-4</a></li><li>• Updated <a href="#">Figure 2-2</a></li><li>• Updated the <a href="#">3. Prerequisites</a> section links</li><li>• Updated TCL script folder location in <a href="#">5. Appendix: Running the TCL Script</a> section</li></ul> |
| A        | 10/2021 | The first publication of the document.                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

## Microchip FPGA Support

Microchip FPGA products group backs its products with various support services, including Customer Service, Customer Technical Support Center, a website, and worldwide sales offices. Customers are suggested to visit Microchip online resources prior to contacting support as it is very likely that their queries have been already answered.

Contact Technical Support Center through the website at [www.microchip.com/support](http://www.microchip.com/support). Mention the FPGA Device Part number, select appropriate case category, and upload design files while creating a technical support case.

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

## Microchip Information

### The Microchip Website

Microchip provides online support via our website at [www.microchip.com/](http://www.microchip.com/). This website is used to make files and information easily available to customers. Some of the content available includes:

- **Product Support** – Data sheets and errata, application notes and sample programs, design resources, user's guides and hardware support documents, latest software releases and archived software
- **General Technical Support** – Frequently Asked Questions (FAQs), technical support requests, online discussion groups, Microchip design partner program member listing
- **Business of Microchip** – Product selector and ordering guides, latest Microchip press releases, listing of seminars and events, listings of Microchip sales offices, distributors and factory representatives

### Product Change Notification Service

Microchip's product change notification service helps keep customers current on Microchip products. Subscribers will receive email notification whenever there are changes, updates, revisions or errata related to a specified product family or development tool of interest.

To register, go to [www.microchip.com/pcn](http://www.microchip.com/pcn) and follow the registration instructions.

### Customer Support

Users of Microchip products can receive assistance through several channels:

- Distributor or Representative
- Local Sales Office
- Embedded Solutions Engineer (ESE)
- Technical Support

Customers should contact their distributor, representative or ESE for support. Local sales offices are also available to help customers. A listing of sales offices and locations is included in this document.

Technical support is available through the website at: [www.microchip.com/support](http://www.microchip.com/support)

### Microchip Devices Code Protection Feature

Note the following details of the code protection feature on Microchip products:

- Microchip products meet the specifications contained in their particular Microchip Data Sheet.
- Microchip believes that its family of products is secure when used in the intended manner, within operating specifications, and under normal conditions.
- Microchip values and aggressively protects its intellectual property rights. Attempts to breach the code protection features of Microchip product is strictly prohibited and may violate the Digital Millennium Copyright Act.
- Neither Microchip nor any other semiconductor manufacturer can guarantee the security of its code. Code protection does not mean that we are guaranteeing the product is "unbreakable". Code protection is constantly evolving. Microchip is committed to continuously improving the code protection features of our products.

## Legal Notice

This publication and the information herein may be used only with Microchip products, including to design, test, and integrate Microchip products with your application. Use of this information in any other manner violates these terms. Information regarding device applications is provided only for your convenience and may be superseded by updates. It is your responsibility to ensure that your application meets with your specifications. Contact your local Microchip sales office for additional support or, obtain additional support at [www.microchip.com/en-us/support/design-help/client-support-services](http://www.microchip.com/en-us/support/design-help/client-support-services).

THIS INFORMATION IS PROVIDED BY MICROCHIP "AS IS". MICROCHIP MAKES NO REPRESENTATIONS OR WARRANTIES OF ANY KIND WHETHER EXPRESS OR IMPLIED, WRITTEN OR ORAL, STATUTORY OR OTHERWISE, RELATED TO THE INFORMATION INCLUDING BUT NOT LIMITED TO ANY IMPLIED WARRANTIES OF NON-INFRINGEMENT, MERCHANTABILITY, AND FITNESS FOR A PARTICULAR PURPOSE, OR WARRANTIES RELATED TO ITS CONDITION, QUALITY, OR PERFORMANCE.

IN NO EVENT WILL MICROCHIP BE LIABLE FOR ANY INDIRECT, SPECIAL, PUNITIVE, INCIDENTAL, OR CONSEQUENTIAL LOSS, DAMAGE, COST, OR EXPENSE OF ANY KIND WHATSOEVER RELATED TO THE INFORMATION OR ITS USE, HOWEVER CAUSED, EVEN IF MICROCHIP HAS BEEN ADVISED OF THE POSSIBILITY OR THE DAMAGES ARE FORESEEABLE. TO THE FULLEST EXTENT ALLOWED BY LAW, MICROCHIP'S TOTAL LIABILITY ON ALL CLAIMS IN ANY WAY RELATED TO THE INFORMATION OR ITS USE WILL NOT EXCEED THE AMOUNT OF FEES, IF ANY, THAT YOU HAVE PAID DIRECTLY TO MICROCHIP FOR THE INFORMATION.

Use of Microchip devices in life support and/or safety applications is entirely at the buyer's risk, and the buyer agrees to defend, indemnify and hold harmless Microchip from any and all damages, claims, suits, or expenses resulting from such use. No licenses are conveyed, implicitly or otherwise, under any Microchip intellectual property rights unless otherwise stated.

## Trademarks

The Microchip name and logo, the Microchip logo, Adaptec, AVR, AVR logo, AVR Freaks, BesTime, BitCloud, CryptoMemory, CryptoRF, dsPIC, flexPWR, HELDO, IGLOO, JukeBlox, KeeLoq, Kleer, LANCheck, LinkMD, maXStylus, maXTouch, MediaLB, megaAVR, Microsemi, Microsemi logo, MOST, MOST logo, MPLAB, OptoLyzer, PIC, picoPower, PICSTART, PIC32 logo, PolarFire, Prochip Designer, QTouch, SAM-BA, SenGenuity, SpyNIC, SST, SST Logo, SuperFlash, Symmetricom, SyncServer, Tachyon, TimeSource, tinyAVR, UNI/O, Vectron, and XMEGA are registered trademarks of Microchip Technology Incorporated in the U.S.A. and other countries.

AgileSwitch, ClockWorks, The Embedded Control Solutions Company, EtherSynch, Flashtec, Hyper Speed Control, HyperLight Load, Libero, motorBench, mTouch, Powermite 3, Precision Edge, ProASIC, ProASIC Plus, ProASIC Plus logo, Quiet-Wire, SmartFusion, SyncWorld, TimeCesium, TimeHub, TimePictra, TimeProvider, and ZL are registered trademarks of Microchip Technology Incorporated in the U.S.A.

Adjacent Key Suppression, AKS, Analog-for-the-Digital Age, Any Capacitor, AnyIn, AnyOut, Augmented Switching, BlueSky, BodyCom, Clockstudio, CodeGuard, CryptoAuthentication, CryptoAutomotive, CryptoCompanion, CryptoController, dsPICDEM, dsPICDEM.net, Dynamic

Average Matching, DAM, ECAN, Espresso T1S, EtherGREEN, EyeOpen, GridTime, IdealBridge, IGaT, In-Circuit Serial Programming, ICSP, INICnet, Intelligent Paralleling, IntelliMOS, Inter-Chip Connectivity, JitterBlocker, Knob-on-Display, MarginLink, maxCrypto, maxView, memBrain, Mindi, MiWi, MPASM, MPF, MPLAB Certified logo, MPLIB, MPLINK, mSiC, MultiTRAK, NetDetach, Omniscient Code Generation, PICDEM, PICDEM.net, PICkit, PICtail, Power MOS IV, Power MOS 7, PowerSmart, PureSilicon, QMatrix, REAL ICE, Ripple Blocker, RTAX, RTG4, SAM-ICE, Serial Quad I/O, simpleMAP, SimpliPHY, SmartBuffer, SmartHLS, SMART-I.S., storClad, SQI, SuperSwitcher, SuperSwitcher II, Switchtec, SynchroPHY, Total Endurance, Trusted Time, TSHARC, Turing, USBCheck, VariSense, VectorBlox, VeriPHY, ViewSpan, WiperLock, XpressConnect, and ZENA are trademarks of Microchip Technology Incorporated in the U.S.A. and other countries.

SQTP is a service mark of Microchip Technology Incorporated in the U.S.A.

The Adaptec logo, Frequency on Demand, Silicon Storage Technology, and Symmcom are registered trademarks of Microchip Technology Inc. in other countries.

GestIC is a registered trademark of Microchip Technology Germany II GmbH & Co. KG, a subsidiary of Microchip Technology Inc., in other countries.

All other trademarks mentioned herein are property of their respective companies.

© 2023, Microchip Technology Incorporated and its subsidiaries. All Rights Reserved.

ISBN: 978-1-6683-3104-0

## Quality Management System

For information regarding Microchip's Quality Management Systems, please visit [www.microchip.com/quality](http://www.microchip.com/quality).

# Worldwide Sales and Service

| AMERICAS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | ASIA/PACIFIC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | ASIA/PACIFIC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | EUROPE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Corporate Office</b><br>2355 West Chandler Blvd.<br>Chandler, AZ 85224-6199<br>Tel: 480-792-7200<br>Fax: 480-792-7277<br>Technical Support:<br><a href="http://www.microchip.com/support">www.microchip.com/support</a><br>Web Address:<br><a href="http://www.microchip.com">www.microchip.com</a>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | <b>Australia - Sydney</b><br>Tel: 61-2-9868-6733<br><b>China - Beijing</b><br>Tel: 86-10-8569-7000<br><b>China - Chengdu</b><br>Tel: 86-28-8665-5511<br><b>China - Chongqing</b><br>Tel: 86-23-8980-9588<br><b>China - Dongguan</b><br>Tel: 86-769-8702-9880<br><b>China - Guangzhou</b><br>Tel: 86-20-8755-8029<br><b>China - Hangzhou</b><br>Tel: 86-571-8792-8115<br><b>China - Hong Kong SAR</b><br>Tel: 852-2943-5100<br><b>China - Nanjing</b><br>Tel: 86-25-8473-2460<br><b>China - Qingdao</b><br>Tel: 86-532-8502-7355<br><b>China - Shanghai</b><br>Tel: 86-21-3326-8000<br><b>China - Shenyang</b><br>Tel: 86-24-2334-2829<br><b>China - Shenzhen</b><br>Tel: 86-755-8864-2200<br><b>China - Suzhou</b><br>Tel: 86-186-6233-1526<br><b>China - Wuhan</b><br>Tel: 86-27-5980-5300<br><b>China - Xian</b><br>Tel: 86-29-8833-7252<br><b>China - Xiamen</b><br>Tel: 86-592-2388138<br><b>China - Zhuhai</b><br>Tel: 86-756-3210040 | <b>India - Bangalore</b><br>Tel: 91-80-3090-4444<br><b>India - New Delhi</b><br>Tel: 91-11-4160-8631<br><b>India - Pune</b><br>Tel: 91-20-4121-0141<br><b>Japan - Osaka</b><br>Tel: 81-6-6152-7160<br><b>Japan - Tokyo</b><br>Tel: 81-3-6880- 3770<br><b>Korea - Daegu</b><br>Tel: 82-53-744-4301<br><b>Korea - Seoul</b><br>Tel: 82-2-554-7200<br><b>Malaysia - Kuala Lumpur</b><br>Tel: 60-3-7651-7906<br><b>Malaysia - Penang</b><br>Tel: 60-4-227-8870<br><b>Philippines - Manila</b><br>Tel: 63-2-634-9065<br><b>Singapore</b><br>Tel: 65-6334-8870<br><b>Taiwan - Hsin Chu</b><br>Tel: 886-3-577-8366<br><b>Taiwan - Kaohsiung</b><br>Tel: 886-7-213-7830<br><b>Taiwan - Taipei</b><br>Tel: 886-2-2508-8600<br><b>Thailand - Bangkok</b><br>Tel: 66-2-694-1351<br><b>Vietnam - Ho Chi Minh</b><br>Tel: 84-28-5448-2100 | <b>Austria - Wels</b><br>Tel: 43-7242-2244-39<br>Fax: 43-7242-2244-393<br><b>Denmark - Copenhagen</b><br>Tel: 45-4485-5910<br>Fax: 45-4485-2829<br><b>Finland - Espoo</b><br>Tel: 358-9-4520-820<br><b>France - Paris</b><br>Tel: 33-1-69-53-63-20<br>Fax: 33-1-69-30-90-79<br><b>Germany - Garching</b><br>Tel: 49-8931-9700<br><b>Germany - Haan</b><br>Tel: 49-2129-3766400<br><b>Germany - Heilbronn</b><br>Tel: 49-7131-72400<br><b>Germany - Karlsruhe</b><br>Tel: 49-721-625370<br><b>Germany - Munich</b><br>Tel: 49-89-627-144-0<br>Fax: 49-89-627-144-44<br><b>Germany - Rosenheim</b><br>Tel: 49-8031-354-560<br><b>Israel - Ra'anana</b><br>Tel: 972-9-744-7705<br><b>Italy - Milan</b><br>Tel: 39-0331-742611<br>Fax: 39-0331-466781<br><b>Italy - Padova</b><br>Tel: 39-049-7625286<br><b>Netherlands - Drunen</b><br>Tel: 31-416-690399<br>Fax: 31-416-690340<br><b>Norway - Trondheim</b><br>Tel: 47-72884388<br><b>Poland - Warsaw</b><br>Tel: 48-22-3325737<br><b>Romania - Bucharest</b><br>Tel: 40-21-407-87-50<br><b>Spain - Madrid</b><br>Tel: 34-91-708-08-90<br>Fax: 34-91-708-08-91<br><b>Sweden - Gothenberg</b><br>Tel: 46-31-704-60-40<br><b>Sweden - Stockholm</b><br>Tel: 46-8-5090-4654<br><b>UK - Wokingham</b><br>Tel: 44-118-921-5800<br>Fax: 44-118-921-5820 |
| <b>Atlanta</b><br>Duluth, GA<br>Tel: 678-957-9614<br>Fax: 678-957-1455<br><b>Austin, TX</b><br>Tel: 512-257-3370<br><b>Boston</b><br>Westborough, MA<br>Tel: 774-760-0087<br>Fax: 774-760-0088<br><b>Chicago</b><br>Itasca, IL<br>Tel: 630-285-0071<br>Fax: 630-285-0075<br><b>Dallas</b><br>Addison, TX<br>Tel: 972-818-7423<br>Fax: 972-818-2924<br><b>Detroit</b><br>Novi, MI<br>Tel: 248-848-4000<br><b>Houston, TX</b><br>Tel: 281-894-5983<br><b>Indianapolis</b><br>Noblesville, IN<br>Tel: 317-773-8323<br>Fax: 317-773-5453<br>Tel: 317-536-2380<br><b>Los Angeles</b><br>Mission Viejo, CA<br>Tel: 949-462-9523<br>Fax: 949-462-9608<br>Tel: 951-273-7800<br><b>Raleigh, NC</b><br>Tel: 919-844-7510<br><b>New York, NY</b><br>Tel: 631-435-6000<br><b>San Jose, CA</b><br>Tel: 408-735-9110<br>Tel: 408-436-4270<br><b>Canada - Toronto</b><br>Tel: 905-695-1980<br>Fax: 905-695-2078 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |