Resets in FPGA & ASIC control and data paths
Mufaddal Saifee (Provino Technologies) & Jaymin Patel (eInfochips)
EDN - August 31, 2016
Reset is an important mechanism to bring a digital system into a known state. The need for reset is governed by the system design and application, and various data and control paths are designed to use a reset signal. Flip-flops in the control path should have reset parameters to bring the system to a known state, while one can usually do without reset in the data path. Let’s discuss various use cases of resets in ASICs and FPGAs.
Introduction
Various data path systems are designed to synchronize with inputs, process them, and provide output. For such designs, if all the unused states are waiting for acquiring the sync state, then the design can do without ever being reset. For designs where the state machine logic has been optimized during synthesis by avoiding logic reduction, resets are a must to prevent the design from starting in a random state.
There are various scenarios apart from the device reboot where the resets are required in real-world designs. Some likely scenarios include:
- If a clock source drops out, then the design should enter the reset until PLL lock is acquired.
- Communication channel must be reset, when the link partner loses sync.
- A user-accessible push button reset.
- Reset from microprocessor after some event, example after expiry of a watch dog timer.
- Partial reconfiguration in modern FPGAs where the swapped logic block must be reset independently of its environment.
- Use of legacy IP from previous ASICs or an IP vendor requiring reset.
- Reset to start clean simulations.
To achieve better performance, designs nowadays have their data pipelined through chains of Flip-Flops. For such designs, the usage of reset can be eliminated in the pipelined Flops to achieve better area utilization and performance. Choosing reset usage and its strategies in ASIC/FPGA designs require many design considerations like whether every Flip-Flop will require a reset, whether to use a synchronous reset or asynchronous reset, how the reset tree will be structured and buffered, how to verify timing of reset tree, how test scan vectors are applied to check functionality of reset and how reset is handled in multi clock domain designs. In this article, we will see the reset usage in Data and Control path in ASIC and FPGA. We will also see how FPGA components like shift registers, Block RAM, Distributed RAM, and DSP Slices can be used efficiently with proper use of reset.
To read the full article, click here
Related Semiconductor IP
- Root of Trust (RoT)
- Fixed Point Doppler Channel IP core
- Multi-protocol wireless plaform integrating Bluetooth Dual Mode, IEEE 802.15.4 (for Thread, Zigbee and Matter)
- Polyphase Video Scaler
- Compact, low-power, 8bit ADC on GF 22nm FDX
Related White Papers
- Optimizing Communication and Data Sharing in Multi-Core SoC Designs
- Shift Power Reduction Methods and Effectiveness for Testability in ASIC
- Analog and Power Management Trends in ASIC and SoC Designs
- Advanced Topics in FinFET Back-End Layout, Analog Techniques, and Design Tools
Latest White Papers
- Reimagining AI Infrastructure: The Power of Converged Back-end Networks
- 40G UCIe IP Advantages for AI Applications
- Recent progress in spin-orbit torque magnetic random-access memory
- What is JESD204C? A quick glance at the standard
- Open-Source Design of Heterogeneous SoCs for AI Acceleration: the PULP Platform Experience