## **VSDBabySoC**

Digital VLSI SoC Design and Planning



**Atharv Aggarwal** 

04.10.2025

Pre-synth sim is the RTL simulation of the design before synthesis to validate functional behavior with the original Verilog sources and the testbench that generates a VCD waveform. Post-synth sim is the gate-level simulation of the synthesized netlist to check that behavior matches the RTL and to observe effects introduced by synthesis, producing a separate VCD waveform

## What pre-synth sim means

Pre-synth sim runs the testbench with the top-level RTL modules directly, using a define that enables dumping signals to a VCD file for waveform viewing in GTKWave. This produces pre\_synth\_sim.vcd under the pre\_synth\_sim output directory for inspecting clocks, resets, and data buses at the RTL level.

## What post-synth sim means

Post-synth sim runs the same testbench against the synthesized netlist file vsdbabysoc.synth.v to validate logic after synthesis transforms. This produces post\_synth\_sim.vcd under the post\_synth\_sim output directory for analyzing gate-level behavior that corresponds to the RTL intent.

## How they are run

The flow provides commands that compile and run pre-synth sim with the RTL sources and a macro for conditional dumping, followed by opening the generated VCD in GTKWave. The flow also provides commands that compile and run post-synth sim using the synthesized netlist after the synthesis step completes, followed by opening its VCD in GTKWave.

| Aspect           | Pre-synth sim                                                         | Post-synth sim                                                                                      |
|------------------|-----------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------|
| Design simulated | RTL sources with the top-level module and testbench [1]               | Synthesized netlist vsdbabysoc.synth.v with the same testbench                                      |
| Purpose          | Fast functional verification before synthesis and quick debugging [1] | Functional checking after synthesis<br>to confirm equivalence and<br>observe changes from synthesis |

| Toolchain usage    | Icarus Verilog for compile and run, VCD viewed in GTKWave, PRE_SYNTH_SIM define used in the testbench <sup>[1]</sup> | Synthesis produces the netlist,<br>Icarus Verilog compiles the netlist<br>with the testbench, VCD viewed in<br>GTKWave |
|--------------------|----------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------|
| Output VCD         | output/pre_synth_sim/pre_synth_si<br>m.vcd [1]                                                                       | output/post_synth_sim/post_synth_<br>sim.vcd                                                                           |
| Signals to inspect | Clock, reset, and data buses at<br>RTL such as RV_TO_DAC and OUT<br>as driven by the testbench [1]                   | The same logical signals as realized in the synthesized netlist to match RTL intent                                    |