## Day-4

# GLS, Blocking vs Non-blocking and Synthesis Simulation Mismatch

### **Gate Level Simulation (GLS)**

#### What is GLS?

Running the test bench with Netlist as Design Under Test. As Netlist is logically same as RTL Code same Test Bench will align with the design. So, we plug the Netlist in place of RTL code and run the simulation.

### Why?

In order to verify the logical correctness of the design after synthesis we perform GLS. As design might not be synthesizing correct logic. GLS also ensured timing design is met for which GLS needs to be run with delay annotation.

### **GLS Flow**



Gate Level Verilog Models contain information regarding gates in the netlist. These models can be either Timing or Functional Aware. If only Functional aware then we can validate only the functionality and if Timing aware then we can validate both Functionality and Timing of the gates.

### **Synthesis Simulation Mismatch**

Synthesis and Simulation mismatch can occur due to the following:

- Missing Sensitivity List
- Blocking V/s Non-Blocking Assignment Inside always block:
  - = Blocking assignment statements are executed one after the another in the order in which they are written.
  - <= Non-Blocking assignment statements executes all RHS statements parallelly and assign then to the LHS Incorrect use of Blocking statements to create sequential logic can result in Simulation and Synthesis Mismatch, so it is always recommended to use NON-Blocking Assignment statements for Sequential Logic.</p>

Non-Standard Verilog Coding

Hence, we should check the behaviour of the circuit with GLS

#### **Lab Examples**

- 1.Ternary\_Operator\_mux
- 2.Bad\_mux
- 3.Good\_mux

Following is the Verilog Code:

### 1.Ternary\_Operator\_mux

The below waveform after simulation clearly indicates the behaviour of 2:1 Mux.



```
Terminal

Termin
```

## Hence, a 2:1 MUX is synthesized.





Clearly the waveform after simulation and synthesis matches.

### 2.Bad\_mux.v

Simulation Waveform-Here y is not following the changes in i1 or i0, only changing its value at the rising edge of sel.



Waveform after Synthesis Using Netlist-Here y is following the changing in i1 and i0.



Both the waveforms obtained after simulation and synthesis are different, this clearly indicated Simulation and Synthesis Mismatch

**Example**- Synthesis and Simulation Mismatch because of Blocking Statements

### Verilog Code



At the pointer, we can see that past values a and b are considered and anded with c to give the present value of d. It seems as if a and b are flopped



After Synthesis-y is evaluating at present value od a and b.



Evaluating correct.

So, this is clearly simulation and synthesis mismatch because of blocking statements

So, it is advisable to use Non-Blocking Statements.