How to raise the RTL abstraction level and design conciseness with SystemVerilog - Part 2
By Sachin Kakkar, Sanjay Gupta, Ayan Banerjee, and Rohit Goel, Mentor Graphics
Programmable Logic DesignLine -- (05/14/08, 12:43:00 PM EDT)
As discussed in Part 1, this article proposes four steps to raise the abstraction level of current Verilog HDL designs and provide a phase wise approach to migrate to SystemVerilog.
- Enhance conciseness and expressiveness of designs.
- Add built-in checks to avoid design issues.
- Design efficient FSM and RAM/ROM memory models.
- Graduate to object oriented generic hardware designs.
In Part 1 we examined Steps1 and 2 – conciseness of expression and built-in code verification. Now, in Part 2, we will elaborate on Steps 3 and 4 and demonstrate how designers can improve code encapsulation, re-use, and consistency in model behavior – all without adversely affecting the quality of results.
Step 3: Design efficient FSMs and RAM/ROM memory models
#1 – Designing finite state machines
SystemVerilog enables modelling at higher levels of abstraction through the use of the following:
- Strongly typed enumerated types with state encoding.
- 2-state data types and user defined types.
- Specialized always_comb, always_latch, and always_ff blocks.
- Unique and priority case statements.
These enhancements enable accurate modelling that simulate and synthesize correctly with consistent behaviour across all tools.
The new SystemVerilog coding style is also easy to read and maintain compared to the Verilog method of modelling FSM's.
To read the full article, click here
Related Semiconductor IP
- NPU IP Core for Mobile
- NPU IP Core for Edge
- Specialized Video Processing NPU IP
- HYPERBUS™ Memory Controller
- AV1 Video Encoder IP
Related White Papers
- 'Smart' verification moves beyond SystemVerilog 3.0
- SystemVerilog 3.1 adds assertions and testbench automation
- SystemVerilog key to new design paradigm
- Synopsys 'ARMs' SystemVerilog
Latest White Papers
- Ramping Up Open-Source RISC-V Cores: Assessing the Energy Efficiency of Superscalar, Out-of-Order Execution
- Transition Fixes in 3nm Multi-Voltage SoC Design
- CXL Topology-Aware and Expander-Driven Prefetching: Unlocking SSD Performance
- Breaking the Memory Bandwidth Boundary. GDDR7 IP Design Challenges & Solutions
- Automating NoC Design to Tackle Rising SoC Complexity