



# SCORE BOOSTER

# 2019 PATTERN

As per the New Revised Credit System Syllabus of  
SAVITRIBAI PHULE PUNE UNIVERSITY

# VLSI Design and Technology

SEMESTER – VII (Final Year)  
Electronics and Tele. Engineering

E-Book For In-Sem Exam

- » Solved University Question Paper
- » Simplified & Conceptual Solution
- » Solved Model Question Papers
- » Dedicated Group For Discussion



**Savitribai Phule Pune University**  
**2019 Pattern**  
**( As Per New Revised Syllabus )**

# **ScoreBooster**

**VLSI Design and  
Technology**

**Semester- VII**  
**Electronics & Tele. Engineering**



**Unit I Design with HDL**Syllabus Topics :

Design Flow, Language constructs, Data objects, Data types, Entity, Architecture & types of modeling, Sequential statements, Concurrent statements, Packages, Sub programs, Attributes, HDL modeling of Combinational, Sequential circuits and FSM. Simulations, Synthesis, Efficient coding styles, Hierarchical and flat designs, Partitioning for synthesis, Pipelining, Resource sharing.

**Unit II Digital Design and Issues**Syllabus Topics :

Sequential synchronous machine design, Moore and Mealy machines, HDL code for Machines, FIFO. Meta-stability and solutions. Noise margin, Fan-out, Skew, Timing considerations, Hazards, Clock distribution, Clock jitter, Supply and ground bounce, Power distribution techniques, Power optimization. Interconnect routing techniques, Wire parasitic, Signal integrity issues. I/O architecture.



## Unit I Design with HDL

### Imp, Expected & Pyq's Question :

1. Draw and explain design flow of VLSI. [8]
2. What is meant by concurrent and sequential statements in VHDL? Describe with two examples of each. [5]
3. Explain Process Statement in VHDL with suitable examples. [5]
4. Explain any 2 Concurrent Statement in VHDL with suitable examples. [5]
5. Explain various data objects and data types used in VHDL. [5]
6. Explain in brief different modeling styles supported by VHDL. [5]
7. Explain different modeling styles in VHDL. [8]
8. Write VHDL code for 4:1 Mux using behavioral modeling style. [5]
9. Write VHDL code for full adder using behavioral modeling style. [5]
10. Write VHDL code for 8:1 mux using structural style of modeling. [7]
11. Write VHDL Code for full adder and its test bench. [10]
12. Write VHDL Code for Arithmetic logic Unit and its test bench. [10]
13. Explain the role of packages, subprograms, and attributes in VHDL. [5]
14. Explain pipelining technique in HDL design with example. [5]



## Unit II Digital Design and Issues

### Imp, Expected & Pyq's Question :

1. Explain and compare Moore and Mealy machine. [8]
2. Draw state diagram and write VHDL code and its test bench for sequence detector 111. [10]
3. Draw state diagram and write VHDL code and its test bench for sequence detector 101. [10]
4. What is Setup time and Hold Time? Explain Meta-stability in detail. [5]
5. What is meant by Meta-stability? Explain any one solution in detail. [5]
6. Write short note on noise margin. [5]
7. Explain the concept of fan-out and its effect on digital design. [5]
8. What is Clock Skew? What are techniques to minimize it? [5]
9. What is Clock Jitter? What are sources of it? [5]
10. Explain clock Distribution Techniques in detail. [5]
11. Write short note on power distribution techniques. [5]
12. Write Short note on Power Optimization. [5]
13. Explain Interconnect routing Techniques. [5]
14. Explain signal integrity issues. [5]





# Unit 1 : Design with HDL

7

Design with HDL:

Pyq Question:

- Draw and explain design flow of VLSI. [8]

Introduction:

- VLSI (Very Large Scale Integration) design involves integrating millions of transistors on a single chip using hardware description languages (HDLs) and CAD tools.
- To design a VLSI chip successfully, a structured flow is followed from specification to fabrication and testing.

Definition:

- **Design Flow:** It refers to the complete sequence of steps followed to develop a hardware design from its specification to its final implementation.

Explanation of Design Flow:

- The design flow of VLSI includes several steps such as design entry, functional simulation, synthesis, place and route, verification, and fabrication.
- Each stage ensures that the design adheres to requirements and performs accurately under real hardware conditions.

Stepwise Design Flow:

- **Specification:** Describes the functionality, speed, area, and power constraints of the chip using high-level details.
- **Design Entry:** The behavior of the circuit is written using HDLs like Verilog or VHDL for simulation and verification purposes.
- **Behavioral Simulation:** The design is simulated to verify its logic and behavior before synthesis using test benches.
- **RTL Synthesis:** Converts HDL code into a gate-level netlist using synthesis tools, ensuring all logical operations are optimized.
- **Technology Mapping:** The synthesized netlist is mapped onto the target fabrication technology using standard cell libraries.



**Place and Route:** Physical layout of cells is done by placing and connecting them using routing techniques on the silicon chip.

- **Static Timing Analysis:** Verifies the timing of the entire design to ensure that it meets performance constraints.
- **Layout Versus Schematic (LVS):** Checks if the physical layout matches the logical schematic to detect layout errors.
- **Design Rule Check (DRC):** Verifies that the layout follows all manufacturing constraints provided by the fabrication process.
- **Post-Layout Simulation:** Performed to confirm the design behavior with interconnect delays after physical layout.
- **Fabrication:** The final layout is sent to foundries to fabricate the physical IC using semiconductor processes.
- **Testing and Validation:** Chips are tested for correct functionality, defects, and to verify if they meet desired specifications.

**Diagram:**

diagram : (Figure : VLSI Design Flow Diagram)



### Explanation of Diagram:

- **Specification:** Acts as input to the entire flow and defines the target function of the VLSI system.
- **Design Entry:** Converts specifications into code, which is later used for further automation in tools.
- **Simulation:** Ensures correctness before moving into irreversible steps like synthesis and layout.
- **Synthesis and Mapping:** Translates code into a netlist with actual logic gates optimized for area and power.
- **Place and Route:** Provides the actual location of logic blocks and interconnections physically on the chip.
- **DRC and LVS:** Ensure the layout is manufacturable and matches the original design intent.
- **Post-layout Simulation:** Confirms the chip will behave correctly with parasitics included.
- **Fabrication and Testing:** Brings the digital design into the real world and confirms it meets expectations.

### Language Constructs and Statements:

#### Pyq Question:

- What is meant by concurrent and sequential statements in VHDL? Describe with two examples of each. [5]

### Introduction:

- VHDL (VHSIC Hardware Description Language) supports both concurrent and sequential types of code execution to model hardware behavior effectively.
- These two types of statements reflect real-world hardware operations and are used based on the target design behavior and context.

### Definition:



**Concurrent Statements:** These are executed simultaneously, just like hardware components operate in parallel. They are written outside process blocks in architecture.

- **Sequential Statements:** These are executed one after another, in the order they are written. They are used inside process, function, or procedure blocks.

#### *Explanation of Concurrent Statements:*

- Concurrent statements reflect parallelism in hardware and are used for structural and dataflow modeling.
- These statements are evaluated and updated automatically whenever there is a change in the signal involved.

#### *Examples of Concurrent Statements:*

- Signal Assignment Statement:  $A \leftarrow B \text{ and } C$ ; (Performs AND operation continuously as input changes.)
- Component Instantiation Statement: U1: and\_gate port map(A, B, C); (Maps signals to a component working in parallel.)

#### *Explanation of Sequential Statements:*

- Sequential statements reflect operations that happen in order and are used to describe algorithmic behavior.
- These statements are written inside process, function, or procedure blocks where execution order matters.

#### *Examples of Sequential Statements:*

- If Statement:

```
if (A = '1') then
```

```
    B := '0';
```

```
end if;
```

(Executes conditionally inside process.)

- Case Statement:

```
case sel is
```

```
when "00" => Y := A;
```



```
when "01" => Y := B;  
11 when others => Y := '0';  
end case;
```

(Selects based on input value inside a process.)

#### Additional Important Points:

- Concurrent statements are sensitive to signal changes and represent the physical wiring and logic connections.
- Sequential statements are useful to model decision-making and step-wise logical operations inside controllers or FSMs.
- Misplacement of concurrent and sequential statements leads to synthesis errors or unexpected simulation behavior.
- Only signal assignments can be used in concurrent statements, while variable and signal assignments both are used in sequential context.
- Proper understanding of the difference is essential to write valid and synthesizable VHDL code.

#### Language Constructs and Statements:

##### Pyq Question:

- Explain Process Statement in VHDL with suitable examples. [5]

#### Introduction:

- VHDL supports various modeling styles to describe hardware, and one of the most important constructs used is the process statement.
- The process statement allows the designer to describe sequential behavior similar to software but reflects actual hardware logic in simulation and synthesis.

#### Definition:



- **Process Statement:** It is a sequential block in VHDL where instructions are executed in the exact order they are written, used to describe time-based and conditional operations.

### *Explanation:*

- A process block begins with the process keyword and ends with the end process; statement.
- All statements inside the process block execute sequentially, making it ideal for describing combinational and clocked logic.
- The sensitivity list determines when the process should execute, depending on the change of listed signals.

### *Syntax of Process Statement:*

```
process (clk, reset)
begin
  if (reset = '1') then
    output <= '0';
  elsif rising_edge(clk) then
    output <= input;
  end if;
end process;
```

- In the above example, the process activates on the change in clk or reset and executes the block inside accordingly.

### *Example 1: Combinational Process Block*

```
process (A, B, SEL)
begin
  if (SEL = '1') then
    OUTP <= A;
  else
    OUTP <= B;
  end if;
end process;
```



- This is a simple multiplexer modeled using a process block and works like combinational logic based on inputs.

13

### *Example 2: Clocked Process Block (Flip-Flop)*

```
process (CLK, RESET)
begin
if (RESET = '1') then
    Q <= '0';
elsif rising_edge(CLK) then
    Q <= D;
end if;
end process;
```

- This example shows the use of a clock signal to design a D Flip-Flop with asynchronous reset inside a process block.

### *Language Constructs and Statements:*

#### *Pyq Question:*

- Explain any 2 Concurrent Statement in VHDL with suitable examples. [5]

#### *Introduction:*

- VHDL supports concurrent statements that mimic the real-time parallel behavior of hardware circuits.
- These statements execute independently and simultaneously without waiting for each other, unlike sequential statements.

#### *Definition:*

- **Concurrent Statements:** These are statements in VHDL architecture that are evaluated and executed in parallel, reflecting actual hardware logic structure and behavior.

#### *Explanation of Concurrent Statements:*



- Concurrent statements are written outside the process blocks and are continuously active during simulation.

14

These statements are sensitive to changes in the signals involved and automatically re-evaluate when inputs change.

- They are mainly used in *dataflow modeling* or to instantiate components in *structural modeling*.

### *Concurrent Statement 1: Signal Assignment Statement*

- The signal assignment statement is used to assign values to signals continuously based on the logic written.
- It models simple combinational logic like AND, OR, and NOT gates effectively in parallel hardware.

#### *Example:*

$Y \leftarrow A \text{ and } B;$

- This line assigns the result of A AND B to output Y continuously, without any process block or control structure.

### *Concurrent Statement 2: Conditional Signal Assignment Statement*

- This statement is used when multiple conditions determine the output, making it useful for modeling multiplexers or combinational decisions.
- The conditions are evaluated concurrently, and the appropriate value is assigned based on the current logic condition.

#### *Example:*

$OUTP \leftarrow A \text{ when } SEL = '1' \text{ else } B;$

- This statement works like a 2x1 multiplexer, continuously checking the condition and assigning value accordingly.

#### *Additional Important Notes:*

- All concurrent statements execute as soon as any signal on their right-hand side changes value, just like actual parallel circuits.



- These statements do not require any clock and are ideal for modeling combinational logic.

15

Using concurrent statements simplifies the representation of basic logic circuits without the need for process or behavioral control.

- Incorrect use of concurrent logic can cause simulation mismatches, so it's important to ensure all signals are properly defined and updated.

### *Language Constructs and Statements:*

#### *Pyq Question:*

- Explain in brief different WAIT statements supported by VHDL. [5]

#### *Introduction:*

- In VHDL, wait statements are used to control the flow of execution inside a process by suspending it until a specified condition is met.
- These statements help in modeling hardware behavior that depends on certain events or signal changes.

#### *Definition:*

- **WAIT Statement:** A wait statement temporarily suspends the execution of a process until a specific event, time, or condition occurs.

#### *Explanation of WAIT Statements in VHDL:*

- VHDL supports multiple forms of wait statements, and each type allows precise control over when the process should resume.
- Wait statements are used only in processes that do not have a sensitivity list.

#### *Type 1: wait on Statement*

- This form suspends the process until there is an event on any of the signals mentioned.
- It is commonly used for modeling combinational logic in an event-driven manner.

#### *Example:*



wait on A, B, C;

- The process resumes execution whenever A, B, or C changes value.

#### 16 : 2: wait until Statement

- This statement halts the process until the specified condition becomes true.
- Mostly used in synchronous logic where the design waits for a clock edge.

Example:

`wait until CLK = '1';`

- The process resumes when the clock signal becomes logic high.

#### Type 3: wait for Statement

- It suspends the process for a fixed simulation time regardless of signal activity or logic condition.
- Mainly useful for creating delays in testbenches or simulation-only code.

Example:

`wait for 10 ns;`

- The process resumes execution after exactly 10 nanoseconds.

#### Type 4: Combined Wait Statement

- This form combines multiple conditions such as a condition with a timeout or an event.
- Helps in building advanced timing models for simulation or test environments.

Example:

`wait on A until A = '1' for 20 ns;`

- The process waits until A becomes logic 1 or for 20 ns, whichever happens first.

#### Additional Important Notes:

- Wait statements can only be used in processes with no sensitivity list; using both causes simulation errors.



- These statements are ignored during synthesis in most cases, as they are simulation-focused constructs.
- Only one wait statement should be used in a process to avoid ambiguity in control flow.

17

Wait statements are useful in testbenches to mimic real hardware timing or clock-based behavior.

- Instead of wait statements, using clocked processes with sensitivity lists is preferred for synthesizable designs.

## Data Objects and Data Types:

### Pyq Question:

- Explain various data objects and data types used in VHDL. [5]

### Introduction:

- VHDL uses data objects and data types to represent and store data during simulation and synthesis of digital systems.
- Understanding the difference and usage of each type helps in writing efficient and error-free code.

### Definition:

- **Data Objects:** These are named containers that hold data values during simulation, like variables in programming.
- **Data Types:** These define the kind of values that a data object can hold such as bits, integers, and logic levels.

### Types of Data Objects in VHDL:

- **Signal:** Represents a physical connection or wire and is used for communication between concurrent statements or processes.
- **Variable:** Declared inside a process or function and is used for temporary storage during sequential execution.
- **Constant:** Holds a fixed value throughout the simulation and cannot be changed once assigned.



- **File:** Used to read or write external text or binary files during simulation for advanced I/O operations.
- Signals are updated after a delta delay, while variables update immediately, which affects simulation behavior significantly.

18

Constants are useful for defining fixed parameters like clock periods or limits, ensuring easy updates across design.

### Types of Data Types in VHDL:

- **Scalar Types:** Represent single values and include:
  - **Bit:** Takes values '0' or '1' only.
  - **Boolean:** Takes values true or false.
  - **Integer:** Stores numeric values within a range.
  - **Character:** Stores any valid character like 'A', '1', or '\$'.
- **Composite Types:** Combine multiple scalar values and include:
  - **Array:** A group of elements of the same type, like `std_logic_vector(7 downto 0)`.
  - **Record:** A group of different types combined into one object for structured data storage.
- **Access Types:** Similar to pointers in software programming, used for dynamic memory access (less commonly used in synthesis).
- **File Types:** Specialized types to handle file operations using file object declarations.
- In practical design, most commonly used types include `std_logic`, `std_logic_vector`, and `integer`.

### Additional Important Points:

- Use of `std_logic` allows modeling multiple logic states like 'U', 'X', '0', '1', 'Z', and improves synthesis compatibility.
- The choice of data type affects simulation accuracy, resource usage, and synthesis result.
- Arrays help in creating buses, registers, or memory blocks, while records help in managing grouped signals.
- Understanding the behavior of signals vs variables avoids mismatches in simulation vs hardware execution.



## *Entity, Architecture, and Modeling Styles:*

### *Pyq Question:*

- Explain in brief different modeling styles supported by VHDL. [5]
- 19 Explain different modeling styles in VHDL. [8]

### *Introduction:*

- VHDL supports multiple modeling styles to describe hardware behavior and structure effectively.
- Choosing the right modeling style impacts simulation accuracy, synthesis quality, and code readability.

### *Definition:*

- *Modeling Styles:* These are different methods or formats of describing the behavior or structure of a digital circuit in VHDL.
- VHDL provides mainly three modeling styles: behavioral, dataflow, and structural.

### *Modeling Styles in VHDL:*

#### *Behavioral Modeling Style:*

- Behavioral modeling describes what a system does, focusing on functionality rather than its physical structure.
- It is written using sequential statements inside a process, and is similar to writing software-like code.
- This style uses process blocks, variables, if-else conditions, loops, and case statements.
- It is mainly used in algorithmic level descriptions or high-level testbenches.
- *Example usage:* Describing a counter or finite state machine using clock-based process.

#### *Dataflow Modeling Style:*

- Dataflow modeling uses concurrent signal assignment to describe how data flows between components.

- It relies on logical and arithmetic expressions and focuses on how output depends on input values.
- It is suitable for modeling combinational circuits like adders, multiplexers, and encoders.

20

Signals are assigned using `<=` operator with concurrent statements.

*Example usage:* `Y <= (A and B) or (C and D);` – output directly defined based on logic expression.

### Structural Modeling Style:

- Structural modeling describes a design using interconnected components and their hierarchy.
- It is similar to a block diagram approach and shows how components are connected in the design.
- This style uses component declarations, component instantiation, and port mapping.
- It is mainly used in large designs that involve hierarchy or reuse of predefined modules.
- *Example usage:* Instantiating AND, OR, and NOT gates and connecting them to build a full adder circuit.

### Mixed Modeling Style:

- Mixed modeling combines two or more modeling styles in a single design.
- It provides flexibility and is commonly used in complex systems to achieve optimized simulation and synthesis.
- For example, control logic may be modeled behaviorally while data path is modeled structurally.

### Additional Points:

- Each modeling style serves different design purposes and selecting the appropriate style improves clarity and efficiency.
- Behavioral is easiest to write and debug, dataflow is good for direct logic, and structural supports hierarchical design.
- All styles produce equivalent hardware if written correctly, but synthesis tools may optimize them differently.



- Using a consistent and clean modeling style helps in better documentation and maintenance of VHDL projects.

### Behavioral Modeling:

21 Question:

- Write VHDL code for 4:1 Mux using behavioral modeling style. [5]

### Introduction:

- Behavioral modeling describes what the system does, using sequential logic inside a process block.
- It uses procedural constructs like if, case, loops, and process to describe the function of a digital system.

### Definition:

- **Behavioral Modeling:** This style defines a circuit's functionality in terms of algorithmic behavior using sequential statements within a process block.
- It is often used to model control logic, state machines, or components with complex behavior.

### Explanation of 4:1 Mux:

- A 4:1 multiplexer has four data inputs ( $I_0, I_1, I_2, I_3$ ), two select lines ( $S_1$  and  $S_0$ ), and one output ( $Y$ ).
- The output is selected based on the binary value of select inputs  $S_1$  and  $S_0$ .
- When  $S_1S_0$  is 00 :  $Y = I_0$
- When  $S_1S_0$  is 01 :  $Y = I_1$
- When  $S_1S_0$  is 10 :  $Y = I_2$
- When  $S_1S_0$  is 11 :  $Y = I_3$
- Behavioral modeling is ideal for this logic as it can use case statement to decide output based on select lines.

### VHDL Code (Behavioral Modeling Style):

library IEEE;



```
use IEEE.STD_LOGIC_1164.ALL;
```

```
entity mux4x1 is
```

```
Port (
```

```
    I0 : in STD_LOGIC;
```

22

```
    I1 : in STD_LOGIC;
```

```
    I2 : in STD_LOGIC;
```

```
    I3 : in STD_LOGIC;
```

```
    S : in STD_LOGIC_VECTOR(1 downto 0);
```

```
    Y : out STD_LOGIC
```

```
);
```

```
end mux4x1;
```

```
architecture Behavioral of mux4x1 is
```

```
begin
```

```
process(I0, I1, I2, I3, S)
```

```
begin
```

```
case S is
```

```
    when "00" => Y <= I0;
```

```
    when "01" => Y <= I1;
```

```
    when "10" => Y <= I2;
```

```
    when "11" => Y <= I3;
```

```
    when others => Y <= '0';
```

```
end case;
```

```
end process;
```

```
end Behavioral;
```

*Explanation of Code:*

- The entity defines all inputs and output ports including four inputs (I0 to I3), two select lines S, and output Y.
- Architecture defines a behavioral block using process that triggers on change of any input or select lines.



- Inside the process, a case statement selects the appropriate input based on the value of S.
- If none of the conditions match, default value of Y is set to '0' using when others.

### Additional Related Concepts:

23

Behavioral code is hardware-synthesizable if only supported sequential constructs are used.

- Reset and clock are not required for simple combinational logic like mux, but are necessary in flip-flop and counter designs.
- Avoid using delays or wait inside synthesizable behavioral code unless explicitly intended for simulation.

### Behavioral Modeling:

#### Pyq Question:

- Write VHDL code for full adder using behavioral modeling style. [5]

### Introduction:

- Behavioral modeling in VHDL allows us to define the operation of a circuit using sequential programming constructs such as if, case, and loops.
- It is suitable for describing logic where functionality is the main focus rather than structural detail.

### Definition:

- **Full Adder:** A digital circuit that performs the arithmetic sum of three input bits: A, B, and Carry-in (Cin), producing Sum and Carry-out (Cout) as output.
- **Behavioral Model:** It uses a process block to describe circuit behavior, with outputs computed through logical expressions based on input changes.

### Working of Full Adder:

- Inputs to the full adder are A, B, and Cin.
- Outputs are Sum and Cout.



\*

The logic operations are:

- o  $\text{Sum} = A \text{ XOR } B \text{ XOR } \text{Cin}$
- o  $\text{Cout} = (\text{A AND B}) \text{ OR } (\text{B AND Cin}) \text{ OR } (\text{A AND Cin})$

VHDL Code (Behavioral Modeling Style):

24      library IEEE;

use IEEE.STD\_LOGIC\_1164.ALL;

```
entity full_adder is
  Port (
    A : in STD_LOGIC;
    B : in STD_LOGIC;
    Cin : in STD_LOGIC;
    Sum : out STD_LOGIC;
    Cout : out STD_LOGIC
  );
end full_adder;
```

```
architecture Behavioral of full_adder is
begin
  process(A, B, Cin)
  begin
    Sum <= A xor B xor Cin;
    Cout <= (A and B) or (B and Cin) or (A and Cin);
  end process;
end Behavioral;
```

Explanation of Code:

- Entity full\_adder defines three inputs ( $A, B, \text{Cin}$ ) and two outputs ( $\text{Sum}, \text{Cout}$ ).
- Architecture Behavioral contains a process block triggered by changes in any of the input signals.
- Inside the process, the  $\text{Sum}$  is computed using chained XOR operations.

- The Cout is calculated using OR of all possible input AND combinations.

#### Additional Related Concepts:

- Full adder is a key building block in arithmetic circuits like ripple carry adders and ALUs.
- The process block in behavioral modeling ensures that the outputs update whenever inputs change.

25

Behavioral modeling provides better readability and compactness for complex logic, as compared to structural modeling.

#### Structural Modeling:

##### Pyq Question:

- Write VHDL code for 8:1 mux using structural style of modeling. [7]

#### Introduction:

- Structural modeling in VHDL describes a circuit by connecting smaller components together, similar to building a block diagram in code form.
- It closely resembles real-world hardware design and is useful for creating complex systems from simpler building blocks.

#### Definition:

- **Structural Modeling:** It is a method of writing VHDL code that focuses on the interconnection of predefined components instead of the behavior.
- **Multiplexer (Mux):** A multiplexer is a combinational circuit that selects binary information from one of many input lines and directs it to a single output line.

#### 8:1 Multiplexer Overview:

- An 8:1 multiplexer has 8 input lines (I0 to I7), 3 selection lines (S2, S1, S0), and 1 output line (Y).
- The output Y is connected to one of the inputs based on the combination of selection inputs.



## Component Design Strategy:

- To implement an 8:1 Mux structurally, we use smaller mux units like 2:1 Mux as building blocks.
- Each 2:1 Mux is written as a separate component and then instantiated multiple times to form the 8:1 Mux.

### 26 VHDL Code (Structural Modeling Style):

```
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
```

```
-- 2:1 MUX Component
```

```
entity mux2to1 is
  Port (
    a : in STD_LOGIC;
    b : in STD_LOGIC;
    sel : in STD_LOGIC;
    y : out STD_LOGIC
  );
end mux2to1;
```

```
architecture Behavioral of mux2to1 is
```

```
begin
  y <= a when sel = '0' else b;
end Behavioral;
```

```
-- 8:1 MUX using structural modeling
```

```
entity mux8to1 is
  Port (
    i : in STD_LOGIC_VECTOR(7 downto 0);
    sel : in STD_LOGIC_VECTOR(2 downto 0);
    y : out STD_LOGIC
  );
```



```
end mux8to1;
```

```
architecture Structural of mux8to1 is
```

```
    signal mux_out : STD_LOGIC_VECTOR(3 downto 0);
```

```
    signal mux_out2 : STD_LOGIC_VECTOR(1 downto 0);
```

```
component mux2to1
```

27 Port (

```
    a : in STD_LOGIC;
```

```
    b : in STD_LOGIC;
```

```
    sel : in STD_LOGIC;
```

```
    y : out STD_LOGIC
```

```
);
```

```
end component;
```

```
begin
```

```
-- Level 1: 4 MUXes to handle 8 inputs
```

```
m1: mux2to1 port map(i(0), i(1), sel(0), mux_out(0));
```

```
m2: mux2to1 port map(i(2), i(3), sel(0), mux_out(1));
```

```
m3: mux2to1 port map(i(4), i(5), sel(0), mux_out(2));
```

```
m4: mux2to1 port map(i(6), i(7), sel(0), mux_out(3));
```

```
-- Level 2: 2 MUXes to handle outputs of level 1
```

```
m5: mux2to1 port map(mux_out(0), mux_out(1), sel(1), mux_out2(0));
```

```
m6: mux2to1 port map(mux_out(2), mux_out(3), sel(1), mux_out2(1));
```

```
-- Level 3: Final MUX to produce final output
```

```
m7: mux2to1 port map(mux_out2(0), mux_out2(1), sel(2), y);
```

```
end Structural;
```

*Explanation of Code:*



- A mux2to1 component is defined first, which selects between two inputs using one selection line.
- In the mux8to1 entity, multiple instances of mux2to1 are used to structurally implement the 8:1 Mux logic.
- Three levels of selection are used:
  - First level handles input grouping.
  - Second level narrows down to 2 choices.
  - Third level selects the final output.

28

#### *Additional Notes:*

- Structural modeling is ideal when we need to reuse smaller components in larger circuits.
- The mux hierarchy improves design clarity and makes it easier to simulate and debug hardware blocks.
- This modeling style ensures reusability and promotes modular hardware design practices.

#### *Combinational Circuits:*

##### *Pyq Question:*

- Write VHDL Code for full adder and its test bench. [10]

##### *Introduction:*

- Combinational circuits are logic circuits whose output depends only on the current input values and not on any past inputs.
- A full adder is a common combinational circuit used to perform binary addition of three input bits producing a sum and a carry output.

##### *Definition:*

- **Full Adder:** A full adder adds three one-bit binary numbers ( $A$ ,  $B$ , and  $Cin$ ) and outputs a sum ( $S$ ) and a carry-out ( $Cout$ ).



- It is a basic digital component used in arithmetic logic units, processors, and other digital systems for binary operations.

### *Explanation of Logic:*

- The full adder calculates:
  - Sum = A XOR B XOR Cin
  - Carry = (A AND B) OR (B AND Cin) OR (Cin AND A)
- It takes into account both the input bits and a carry-in from the previous stage, making it suitable for multi-bit binary addition.

29

### *VHDL Code for Full Adder:*

```
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;

entity full_adder is
Port (
    A : in STD_LOGIC;
    B : in STD_LOGIC;
    Cin : in STD_LOGIC;
    Sum : out STD_LOGIC;
    Cout : out STD_LOGIC
);
end full_adder;
```

### *architecture Behavioral of full\_adder is*

```
begin
    Sum <= A xor B xor Cin;
    Cout <= (A and B) or (B and Cin) or (Cin and A);
end Behavioral;
```

### *Test Bench for Full Adder:*

```
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
```



```
entity tb_full_adder is
-- Test bench does not have any ports
end tb_full_adder;
```

```
architecture Behavioral of tb_full_adder is
```

```
-- Component Declaration
30 component full_adder
  Port (
    A : in STD_LOGIC;
    B : in STD_LOGIC;
    Cin : in STD_LOGIC;
    Sum : out STD_LOGIC;
    Cout : out STD_LOGIC
  );
end component;
```

```
-- Test signals
signal A, B, Cin, Sum, Cout : STD_LOGIC;
```

```
begin
```

```
-- Unit under test
uut: full_adder port map (
  A => A,
  B => B,
  Cin => Cin,
  Sum => Sum,
  Cout => Cout
);
```

```
-- Stimulus process
```

```

stim_proc: process
begin
    -- Apply all 8 combinations of A, B, Cin
    A <= '0'; B <= '0'; Cin <= '0'; wait for 10 ns;
    A <= '0'; B <= '0'; Cin <= '1'; wait for 10 ns;
    A <= '0'; B <= '1'; Cin <= '0'; wait for 10 ns;
    A <= '0'; B <= '1'; Cin <= '1'; wait for 10 ns;
    A <= '1'; B <= '0'; Cin <= '0'; wait for 10 ns;
    A <= '1'; B <= '0'; Cin <= '1'; wait for 10 ns;
31     A <= '1'; B <= '1'; Cin <= '0'; wait for 10 ns;
          A <= '1'; B <= '1'; Cin <= '1'; wait for 10 ns;

    -- End simulation
    wait;
end process;

end Behavioral;

```

#### *Explanation of Test Bench:*

- A test bench simulates the behavior of the full adder by generating all possible input combinations.
- It uses wait for 10 ns; delay to allow signal transitions to propagate and be observed clearly.
- The output signals Sum and Cout are generated and can be verified using waveform simulation tools like ModelSim or Xilinx Vivado.

#### *Additional Notes:*

- The full adder is a key building block in multi-bit binary adders such as ripple carry adders and lookahead adders.
- The test bench ensures all eight possible input combinations are tested, validating both functionality and correctness of the full adder.



## *Sequential Circuits:*

### *Pyq Question:*

- Write VHDL code for D Flip-Flop and its test bench. [5]

### *Introduction:*

- Sequential circuits are digital logic circuits whose outputs depend on both current inputs and previous states stored in memory elements.
- A D Flip-Flop is a widely used memory element in sequential logic circuits for storing one-bit data values on a clock edge.

32

### *Definition:*

- **D Flip-Flop:** A D (Data or Delay) Flip-Flop captures the value of the data input (D) on the rising or falling edge of the clock and holds it until the next clock edge.

### *Working Concept:*

- When the clock triggers, the D Flip-Flop transfers the input D to output Q.
- It is edge-triggered and changes state only on the defined clock edge, making it suitable for synchronous design.

### *VHDL Code for D Flip-Flop:*

```
library IEEE;  
use IEEE.STD_LOGIC_1164.ALL;
```

```
entity d_flip_flop is
```

```
Port (
```

```
    D : in STD_LOGIC;
```

```
    CLK : in STD_LOGIC;
```

```
    Q : out STD_LOGIC
```

```
);
```

```
end d_flip_flop;
```

```
architecture Behavioral of d_flip_flop is
```

```
begin
```



```
process(CLK)
begin
    if rising_edge(CLK) then
        Q <= D;
    end if;
end process;
end Behavioral;
```

### *Explanation of Code:*

- 33
- The process block is sensitive to the clock signal and checks for the rising edge using `rising_edge(CLK)`.
  - At each rising edge, the input `D` is assigned to the output `Q`, effectively storing the value until the next edge.

### *Test Bench for D Flip-Flop:*

```
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
```

```
entity tb_d_flip_flop is
-- No ports for test bench
end tb_d_flip_flop;
```

```
architecture Behavioral of tb_d_flip_flop is
```

```
component d_flip_flop
Port (
    D : in STD_LOGIC;
    CLK : in STD_LOGIC;
    Q : out STD_LOGIC
);
```

```
end component;
```

```
signal D, CLK, Q : STD_LOGIC;
```



begin

```
    uut: d_flip_flop port map (
        D => D,
        CLK => CLK,
        Q => Q
    );
```

stim\_proc: process

34

begin

```
    D <= '0';
    CLK <= '0';
    wait for 10 ns;
    CLK <= '1';
    wait for 10 ns;
```

```
    D <= '1';
    CLK <= '0';
    wait for 10 ns;
    CLK <= '1';
    wait for 10 ns;
```

```
    D <= '0';
    CLK <= '0';
    wait for 10 ns;
    CLK <= '1';
    wait for 10 ns;
```

wait;

end process;

end Behavioral;



### *Explanation of Test Bench:*

- The test bench applies different values of D and toggles the clock to verify the Flip-Flop's edge-triggered storage.
- The output Q will update only on the rising edge of CLK and match the value of D at that instant.

### *Additional Notes:*

- D Flip-Flops are fundamental in designing registers, counters, memory cells, and finite state machines.

35

The clock edge sensitivity ensures predictable timing and avoids glitches in synchronous systems.

### *FSM (Finite State Machine):*

#### *Pyq Question:*

- Write VHDL code for a simple FSM (e.g., sequence detector). [5]

#### *Introduction:*

- FSM stands for Finite State Machine, a sequential circuit model used to design logic where output depends on current state and inputs.
- It consists of a finite number of states and transitions between states based on input conditions, used in control systems.

#### *Definition:*

- *Finite State Machine:* A computational model that can exist in one of a finite number of states at a time and transition between states on clock edges.

#### *Types of FSM:*

- *Moore Machine:* Output depends only on the current state.
- *Mealy Machine:* Output depends on both the current state and input signals.



## Sequence Detector Example:

- A sequence detector FSM checks for a specific sequence in input bits (e.g., detects sequence "1011").
- The FSM transitions from one state to another with each bit of input until it matches the complete sequence.

## FSM Design Concept:

- Inputs: serial input (e.g., X), clock (CLK), reset
- Output: Y (asserted when target sequence detected)
- States: Represent the progress of matching sequence

36

## VHDL Code for Sequence Detector (Detecting "1011"):

```
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;

entity seq_detector is
    Port (
        CLK : in STD_LOGIC;
        RESET : in STD_LOGIC;
        X : in STD_LOGIC;
        Y : out STD_LOGIC
    );
end seq_detector;
```

```
architecture Behavioral of seq_detector is
```

```
    type state_type is (S0, S1, S2, S3, S4);
    signal state, next_state : state_type;
begin
```

```
    process(CLK, RESET)
```

```
    begin
```



```
if RESET = '1' then  
    state <= S0;  
elsif rising_edge(CLK) then  
    state <= next_state;  
end if;  
end process;
```

```
process(state, X)  
begin  
    case state is  
        when S0 =>  
            if X = '1' then  
                next_state <= S1;  
            else  
                next_state <= S0;  
            end if;  
            Y <= '0';  
  
        when S1 =>  
            if X = '0' then  
                next_state <= S2;  
            else  
                next_state <= S1;  
            end if;  
            Y <= '0';  
  
        when S2 =>  
            if X = '1' then  
                next_state <= S3;  
            else  
                next_state <= S0;  
            end if;  
            Y <= '0';
```



```
when S3 =>
    if X = '1' then
        next_state <= S4;
    else
        next_state <= S2;
    end if;
    Y <= '0';
```

```
when S4 =>
    next_state <= S0;
    Y <= '1';
```

38

```
end case;
end process;
```

```
end Behavioral;
```

#### *Explanation of Code:*

- State type defines five states representing the sequence tracking from S0 to S4.
- Transitions occur on each clock cycle based on current input bit X.
- When final state S4 is reached, output Y is set to '1' indicating the sequence 1011 is detected.
- Reset brings the FSM back to initial state S0, ensuring predictable operation.

#### *Application:*

- FSMs like this are widely used in control logic, protocol decoding, traffic light controllers, and digital locks.
- Sequence detectors specifically are useful in pattern recognition, communication systems, and stream analysis.



## *Arithmetic Logic Unit (ALU):*

### *Pyq Question:*

- Write VHDL code for 4-bit ALU to perform different eight operations. [7]

### *Introduction:*

- ALU stands for Arithmetic Logic Unit and it is a digital circuit used to perform arithmetic and logical operations on binary numbers.
- It is an essential component of CPUs and microcontrollers, responsible for processing mathematical and logical instructions.

### *Definition:*

39

*Arithmetic Logic Unit:* A combinational digital circuit that performs arithmetic operations (like addition, subtraction) and logic operations (like AND, OR, XOR).

### *Purpose of a 4-bit ALU:*

- The ALU takes two 4-bit binary inputs and based on a control signal, performs one of several predefined operations.
- It produces a 4-bit output result and may also generate status outputs like carry or zero flags.

### *Operations Performed by 4-bit ALU (Eight Total):*

- Logical AND
- Logical OR
- Logical XOR
- Logical NOT (on A)
- Addition
- Subtraction
- Increment A
- Decrement A

### *Inputs and Outputs of ALU:*

- Inputs: A (4-bit), B (4-bit), SEL (3-bit selector)
- Outputs: ALU\_RESULT (4-bit), CARRY (optional)



VHDL Code for 4-bit ALU:

```
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
use IEEE.STD_LOGIC_UNSIGNED.ALL;

entity ALU_4bit is
    Port (
        A      : in STD_LOGIC_VECTOR(3 downto 0);
        B      : in STD_LOGIC_VECTOR(3 downto 0);
        SEL    : in STD_LOGIC_VECTOR(2 downto 0);
        40     ALU_RESULT: out STD_LOGIC_VECTOR(3 downto 0)
    );
end ALU_4bit;
```

architecture Behavioral of ALU\_4bit is

begin

process (A, B, SEL)

begin

case SEL is

when "000" => -- AND

ALU\_RESULT <= A and B;

when "001" => -- OR

ALU\_RESULT <= A or B;

when "010" => -- XOR

ALU\_RESULT <= A xor B;

when "011" => -- NOT A

ALU\_RESULT <= not A;



```

when "100" => -- ADD
    ALU_RESULT <= A + B;

when "101" => -- SUB
    ALU_RESULT <= A - B;

when "110" => -- INCREMENT A
    ALU_RESULT <= A + "0001";

when "111" => -- DECREMENT A
    ALU_RESULT <= A - "0001";

when others =>
    ALU_RESULT <= "0000";
end case;
end process;
end Behavioral;

```

#### *Explanation of Code:*

- The ALU supports eight operations based on 3-bit selection input SEL.
- Each SEL value corresponds to a particular operation performed using A and B.
- All operations are performed using standard logic operators and VHDL arithmetic expressions.
- The final output is a 4-bit ALU\_RESULT which holds the result of the selected operation.

#### *Application of ALU:*

- Used in CPUs, calculators, embedded processors, and programmable digital systems for processing logical and arithmetic instructions.
- Forms the basic execution block in arithmetic computations and decision-making circuits.



## *Arithmetic Logic Unit (ALU):*

### *Pyq Question:*

- Write VHDL Code for Arithmetic Logic Unit and its test bench.

### *Introduction:*

- An Arithmetic Logic Unit (ALU) is a key component of a digital system that performs both arithmetic and logic operations.
- It is a combinational circuit designed to compute mathematical and logical results depending on control inputs.

### *Definition:*

- ALU: A hardware module or block that accepts data inputs and a control signal, then performs selected arithmetic or logic operations based on that control.

42

### *Purpose of ALU in Digital Systems:*

- To execute a wide range of mathematical and logical instructions inside processors or digital control units.
- It works with binary data and performs real-time computations that are essential in microprocessors and digital computers.

### *Common Operations Supported by ALU:*

- Arithmetic: Addition, subtraction, increment, decrement
- Logic: AND, OR, XOR, NOT

### *VHDL Code for Arithmetic Logic Unit:*

```
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
use IEEE.STD_LOGIC_UNSIGNED.ALL;
```

entity ALU is

Port (



```
A      : in STD_LOGIC_VECTOR(3 downto 0);
B      : in STD_LOGIC_VECTOR(3 downto 0);
SEL    : in STD_LOGIC_VECTOR(2 downto 0);
RESULT : out STD_LOGIC_VECTOR(3 downto 0)
);
end ALU;
```

architecture Behavioral of ALU is

begin

process(A, B, SEL)

begin

case SEL is

when "000" => -- Addition

RESULT <= A + B;

43

when "001" => -- Subtraction

RESULT <= A - B;

when "010" => -- AND

RESULT <= A and B;

when "011" => -- OR

RESULT <= A or B;

when "100" => -- XOR

RESULT <= A xor B;

when "101" => -- NOT A

RESULT <= not A;

when "110" => -- Increment A

RESULT <= A + "0001";



```
when "111" => -- Decrement A  
    RESULT <= A - "0001";  
  
when others =>  
    RESULT <= "0000";  
end case;  
end process;  
end Behavioral;
```

#### *Explanation of VHDL Code:*

- The A and B inputs are 4-bit vectors on which operations are performed depending on the 3-bit SEL input.
- For each SEL value, one specific operation is performed and the result is stored in the 4-bit RESULT.

44

This structure enables flexible control over different operations using a single selector input.

#### *Test Bench for ALU:*

```
library IEEE;  
use IEEE.STD_LOGIC_1164.ALL;  
use IEEE.STD_LOGIC_UNSIGNED.ALL;  
  
entity ALU_TB is  
end ALU_TB;
```

architecture behavior of ALU\_TB is

```
component ALU  
Port (  
    A      : in STD_LOGIC_VECTOR(3 downto 0);  
    B      : in STD_LOGIC_VECTOR(3 downto 0);  
    SEL   : in STD_LOGIC_VECTOR(2 downto 0);
```



```
RESULT : out STD_LOGIC_VECTOR(3 downto 0)
);
end component;
```

```
signal A : STD_LOGIC_VECTOR(3 downto 0) := "0000";
signal B : STD_LOGIC_VECTOR(3 downto 0) := "0000";
signal SEL : STD_LOGIC_VECTOR(2 downto 0) := "000";
signal RESULT : STD_LOGIC_VECTOR(3 downto 0);
```

```
begin
```

```
uut: ALU Port map (
```

```
    A => A,
```

```
    B => B,
```

```
    SEL => SEL,
```

45

```
    RESULT => RESULT
```

```
);
```

```
process
```

```
begin
```

```
    A <= "0101"; B <= "0011"; SEL <= "000"; -- ADD
```

```
    wait for 10 ns;
```

```
    SEL <= "001"; -- SUB
```

```
    wait for 10 ns;
```

```
    SEL <= "010"; -- AND
```

```
    wait for 10 ns;
```

```
    SEL <= "011"; -- OR
```

```
    wait for 10 ns;
```

```
    SEL <= "100"; -- XOR
```



wait for 10 ns;

SEL <= "101"; -- NOT A

wait for 10 ns;

SEL <= "110"; -- INCREMENT A

wait for 10 ns;

SEL <= "111"; -- DECREMENT A

wait for 10 ns;

wait;

end process;

end behavior;

#### 46. Explanation of Test Bench:

- The test bench simulates the ALU operations by changing SEL values with given inputs A and B.
- Each case is separated by a 10 ns delay to observe changes.
- Helps in verifying the correctness of each operation through simulation.

#### Importance of Test Bench:

- Ensures that the ALU design behaves correctly under all conditions.
- Helps detect logical errors and edge cases before hardware implementation.

#### Synthesizable and Non-Synthesizable Statements:

#### Pyq Question:

- What is meant by synthesizable and non-synthesizable statement? Give two examples of each. [5]

#### Introduction:



- In VHDL or Verilog coding, not all written statements are suitable for hardware implementation. Such statements are categorized as synthesizable or non-synthesizable.
- Understanding the difference helps in writing code that can be successfully implemented on FPGA or ASIC hardware.

#### Definition:

- **Synthesizable Statement:** Statements that can be translated into actual digital hardware components during the synthesis process are known as synthesizable.
- **Non-Synthesizable Statement:** Statements used only for simulation or testing purposes and are ignored during synthesis are non-synthesizable.

#### Explanation of Synthesizable Statement:

- These are converted into physical logic gates, flip-flops, and other hardware structures on FPGA or ASIC.

47

Used for actual circuit design and implementation.

Common examples are logic expressions, conditional statements, and concurrent signal assignments.

#### Examples of Synthesizable Statements:

- `A <= B and C;` : Logical AND operation using concurrent signal assignment.
- `if clk = '1' and clk'event then Q <= D;` : Flip-flop behavior description using clock edge detection.

#### Explanation of Non-Synthesizable Statement:

- These are helpful for simulation, debugging, or monitoring internal signals but do not affect the actual synthesized hardware.
- They do not generate physical hardware and are removed during synthesis.
- Mostly used in testbenches and verification code.

#### Examples of Non-Synthesizable Statements:

- `wait for 10 ns;` : Simulation delay, has no hardware equivalent.
- `report "Simulation completed";` : Displays messages during simulation only.

### *Key Points of Comparison:*

- Synthesizable statements produce hardware, while non-synthesizable ones do not and are used for simulation only.
- Writing correct synthesizable code is essential for successful synthesis and real hardware testing.

### *Packages, Subprograms, and Attributes in VHDL:*

#### *Pyq Question:*

- Explain the role of packages, subprograms, and attributes in VHDL. [5]

#### *Introduction:*

- In VHDL, modular and reusable code structures are supported using packages, subprograms, and attributes.

48

These constructs promote efficient design, code reuse, and ease of maintenance in digital system modeling.

#### *Definition:*

- **Package:** A package in VHDL is a collection of related definitions, such as data types, constants, functions, and procedures.
- **Subprogram:** Subprograms are reusable blocks of code implemented using functions and procedures to perform a particular task.
- **Attribute:** Attributes provide extra information about signals, variables, and entities for analysis or simulation.

#### *Explanation of Package:*

- Packages help in sharing commonly used data types and subprograms across multiple design units.
- They are declared in a separate section using the package and package body keywords.



- Package declarations define the interface, while the package body defines the implementation of functions and procedures.

#### Key Use of Package:

- Helps in organizing reusable code such as constants, functions, and types.
- Avoids redundancy by making utility code accessible across multiple entities or architectures.

#### Example of Package:

- package Logic\_Utils is
- function And\_Gate(a, b : std\_logic) return std\_logic;

#### Explanation of Subprogram:

- Subprograms increase modularity and are written using either function or procedure keyword.
- A function returns a single value and is typically used in expressions, while a procedure may return multiple outputs through parameters.
- They allow abstraction of complex logic into understandable and reusable components.

49

#### Example of Function (Subprogram):

- function Add\_4bit(a, b : std\_logic\_vector(3 downto 0)) return std\_logic\_vector;

#### Explanation of Attributes:

- Attributes are used to extract additional information about objects like signals, types, and components.
- They may be predefined by VHDL or user-defined.
- Useful during synthesis and simulation to retrieve signal values, event occurrences, and data ranges.

#### Commonly Used Attributes:

- 'event : Indicates a change in value of a signal.
- 'last\_value : Stores the last value of a signal.
- 'range : Provides the range of an array or signal.



### *Importance in VHDL Design:*

- Packages provide global accessibility to useful resources across various VHDL files.
- Subprograms promote structured programming and help reduce redundant logic.
- Attributes enhance observability and control during simulation and debugging.

### *Pipelining in HDL Design:*

#### *Pyq Question:*

- Explain pipelining technique in HDL design with example. [5]

#### *Introduction:*

- Pipelining is a technique used in digital circuit design to improve performance by dividing tasks into stages.
- In HDL (Hardware Description Language) designs, pipelining enhances throughput without increasing the clock speed.

50

#### *nition:*

- **Pipelining:** It is a method of implementing sequential operations in multiple stages where each stage completes part of the task in parallel.

#### *Need for Pipelining in HDL Design:*

- Complex digital operations like multiplication, filtering, or encoding require multiple steps which may not complete in one clock cycle.
- Without pipelining, such operations introduce delay and reduce system throughput.

#### *Working Principle of Pipelining:*

- Operations are divided into sequential stages such as fetch, decode, execute, etc., depending on the logic function.
- Each stage is executed in parallel with the help of registers between them, allowing a new input at every clock cycle.

#### *Design Methodology in HDL:*



- Registers are inserted between combinational logic blocks to hold intermediate values between clock cycles.
- Each stage processes part of the data and passes the result to the next stage via a flip-flop or register.

### *Example of HDL-Based Pipelining:*

- Consider a three-stage pipeline for adding three numbers A, B, and C in steps:
  - Stage 1: Add A and B
  - Stage 2: Store result in temporary register
  - Stage 3: Add result with C and store final output

### *VHDL Example Code:*

```

library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
use IEEE.STD_LOGIC_ARITH.ALL;
use IEEE.STD_LOGIC_UNSIGNED.ALL;

51   library IEEE;
      library PipelineAdder is
      Port ( A, B, C : in STD_LOGIC_VECTOR(3 downto 0);
             clk    : in STD_LOGIC;
             result : out STD_LOGIC_VECTOR(3 downto 0));
      end PipelineAdder;

```

```

architecture Behavioral of PipelineAdder is
  signal temp_sum1 : STD_LOGIC_VECTOR(3 downto 0);
  signal temp_sum2 : STD_LOGIC_VECTOR(3 downto 0);
begin
  process(clk)
  begin
    if rising_edge(clk) then
      temp_sum1 <= A + B;
      temp_sum2 <= temp_sum1;
      result <= temp_sum2 + C;
    end if;
  end process;
end Behavioral;

```



```
end if;  
end process;  
end Behavioral;
```

### *Advantages of Pipelining:*

- Reduces the overall processing time of operations by utilizing clock cycles efficiently.
- Improves the throughput of the system as new data can be processed every clock cycle.
- Allows better performance in high-speed digital systems and processors.

### *Limitations of Pipelining:*

- Introduces latency as output appears only after all stages are filled.
- More registers and control logic are required which may increase hardware resource usage.
- Handling of data hazards and control hazards requires additional care.

52

### *Application Areas:*

Widely used in CPU instruction processing, signal processing (DSP), image processing, and high-speed arithmetic circuits.

### *Resource Sharing in HDL:*

#### *Pyq Question:*

- What is resource sharing in HDL and how does it affect design efficiency? [5]

### *Introduction:*

- In HDL-based digital design, resource sharing refers to using one hardware unit to perform multiple functions during different time intervals.
- It is an optimization technique to reduce area and cost without compromising functionality.

### *Definition:*



- **Resource sharing:** It is a technique in HDL design where common hardware blocks are reused to perform different operations sequentially.

### Need for Resource Sharing:

- In large-scale digital circuits, using separate hardware blocks for every function increases chip area and power consumption.
- Resource sharing minimizes redundant hardware, optimizing performance and resource utilization.

### Working Principle:

- A shared unit (like an adder or multiplier) performs operations for different functional blocks one at a time using control logic.
- Multiplexers and control units decide which inputs to process and when to process them using shared resources.

### Effect on Design Efficiency:

- Reduces the total hardware components required for implementing a complex system.
- 53      Helps achieve compact, power-efficient designs suitable for FPGA or ASIC implementations.
- Reduces cost and improves reliability due to fewer hardware components involved.

### Impact on Timing and Performance:

- While area is optimized, timing may be slightly affected due to sequential usage of shared blocks.
- Appropriate scheduling and pipelining strategies are essential to balance performance and sharing.

### HDL Implementation Consideration:

- Designers must use conditional structures (like if-else, case) and enable signals in HDL to implement sharing efficiently.
- Use of control FSMs (Finite State Machines) is common to manage timing and switching of shared resources.

### *Example Scenario:*

- A single multiplier unit is shared between two blocks - one performing FFT and the other performing convolution.
- Instead of two multipliers, one is reused in alternating clock cycles based on the system control logic.

### *Advantages:*

- Reduces chip area, power usage, and cost significantly, especially in ASIC or FPGA designs.
- Simplifies routing and layout by minimizing logic block count.

### *Disadvantages:*

- May introduce latency since hardware units are not concurrently used.
- Requires careful control logic to avoid timing conflicts or incorrect operations.

### *Application Areas:*

- Embedded systems, real-time digital signal processing, control systems, and low-cost hardware designs.



## Unit 2 : Digital Design and Issues

### Sequential Synchronous Machine Design

#### Pyq Question:

- Explain and compare Moore and Mealy machine. [8]

#### Introduction:

- Moore and Mealy machines are two types of finite state machines used in sequential circuit design for modeling digital systems.
- They are widely used for designing controllers, protocol checkers, and various digital logic systems.

#### Definition:

- **Moore Machine:** A finite state machine in which outputs depend only on the present state of the system.
- **Mealy Machine:** A finite state machine in which outputs depend on both the present state and the current inputs.

#### Characteristics of Moore Machine:

55

Outputs are generated solely from the current state, independent of input changes.

Output remains stable until the machine enters a new state.

- Design is simple and easier to debug as outputs are not affected by glitches in input.
- Requires more states as each output variation needs a different state.

#### Characteristics of Mealy Machine:

- Outputs are based on the current state and current inputs simultaneously.
- Can respond faster since output changes immediately with input without waiting for state transition.
- Requires fewer states compared to Moore machine for the same output behavior.
- More efficient in terms of state usage but sensitive to input glitches.

#### Output Dependency Comparison:

- In Moore machine: Output = f(State)
- In Mealy machine: Output = f(State, Input)



### *Advantages of Moore Machine:*

- Easier to implement and debug due to output stability.
- Output is synchronized with clock cycles which enhances reliability.

### *Advantages of Mealy Machine:*

- Faster response time since outputs depend directly on input.
- More compact state diagram with reduced state count for complex designs.

### *Disadvantages of Moore Machine:*

- Slower response due to dependence on state transition.
- Larger number of states needed which may increase circuit complexity.

### *Disadvantages of Mealy Machine:*

- Output may change asynchronously with inputs, which may introduce glitches.
- Slightly complex to design due to dependency on both state and input.

### *Tabular Comparison Between Moore and Mealy Machines:*

| Aspect                  | Moore Machine               | Mealy Machine                  |
|-------------------------|-----------------------------|--------------------------------|
| Input Depends On        | Current State               | Current State and Input        |
| State Count             | More                        | Less                           |
| Output Timing           | Changes on state transition | Can change any time with input |
| Circuit Complexity      | Simple                      | Slightly Complex               |
| Sensitivity to Glitches | Less                        | More                           |
| Implementation          | Easier to implement         | Harder to debug                |

### *Application Areas:*

- Moore machines: Preferred where reliable and stable output is required, e.g., traffic controllers.
- Mealy machines: Preferred in time-critical systems like communication protocols or decoders.

## Sequential Synchronous Machine Design

Pyq Question:

- Draw state diagram and write VHDL code and its test bench for sequence detector 111. [10]

Definition:

- **Sequence Detector:** A sequential circuit that identifies a predefined sequence in a stream of binary input.
- The detector moves through a set of defined states and sets an output signal high when the target pattern is matched.

State Description:

- To detect sequence 111, we need four states:
  - $S_0$ : Initial state where no match has occurred yet.
  - $S_1$ : First 1 detected.
  - $S_2$ : Two consecutive 1s detected.
  - $S_3$ : Full sequence 111 detected.

57

ram:

(Figure : sequence detector 111 state diagram)



### *Explanation of Diagram:*

- In  $S_0$ , when input is 1, transition occurs to  $S_1$ ; otherwise, stay in  $S_0$ .
- In  $S_1$ , if next input is 1, go to  $S_2$ , else reset to  $S_0$ .
- In  $S_2$ , third 1 leads to  $S_3$  and output becomes high.
- In  $S_3$ , output is 1. For next 1, go to  $S_1$  to allow overlapping sequence detection.

### *VHDL Code for Sequence Detector 111:*

```
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
use IEEE.STD_LOGIC_ARITH.ALL;
use IEEE.STD_LOGIC_UNSIGNED.ALL;
```

```
entity seq_detector is
```

```
Port (
```

```
    clk : in std_logic;
    rst : in std_logic;
    x : in std_logic;
    y : out std_logic
);
```

```
58
```

```
seq_detector;
```

```
architecture Behavioral of seq_detector is
```

```
type state_type is (S0, S1, S2, S3);
```

```
signal state, next_state : state_type;
```

```
begin
```

```
process(clk, rst)
```

```
begin
```

```
if rst = '1' then
```

```
    state <= S0;
```

```
elsif rising_edge(clk) then
```

```
    state <= next_state;
```

```
end if;
```



end process;

process(state, x)

begin

case state is

when S0 =>

if x = '1' then

next\_state <= S1;

else

next\_state <= S0;

end if;

y <= '0';

when S1 =>

if x = '1' then

next\_state <= S2;

else

next\_state <= S0;

end if;

y <= '0';

59

when S2 =>

if x = '1' then

next\_state <= S3;

else

next\_state <= S0;

end if;

y <= '0';

when S3 =>

if x = '1' then

next\_state <= S1;

else



```
    next_state <= S0;
  end if;
  y <= '1';
end case;
end process;
end Behavioral;
```

#### *Explanation of VHDL Code:*

- Four states are declared using enumerated data type.
- Clock and reset control state transition.
- Output 'y' is asserted only when state is  $S_3$ , i.e., sequence 111 is detected.
- The design allows overlapping detection such as in stream "1111".

#### *Test Bench for Sequence Detector 111:*

```
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
```

```
entity tb_seq_detector is
end tb_seq_detector;
```

60      *Architecture behavior of tb\_seq\_detector is*  
          signal clk, rst, x : std\_logic := '0';  
          signal y : std\_logic;

```
component seq_detector
Port (
  clk : in std_logic;
  rst : in std_logic;
  x : in std_logic;
  y : out std_logic
);
end component;
```



```
begin
    uut: seq_detector Port Map (
        clk => clk,
        rst => rst,
        x => x,
        y => y
    );
```

```
clk_process :process
begin
    clk <= '0';
    wait for 10 ns;
    clk <= '1';
    wait for 10 ns;
end process;
```

```
stim_proc: process
```

```
begin
    rst <= '1';
    wait for 20 ns;
```

61

```
    rst <= '0';
```

```
    x <= '1'; wait for 20 ns;
    x <= '1'; wait for 20 ns;
    x <= '1'; wait for 20 ns;
    x <= '0'; wait for 20 ns;
    x <= '1'; wait for 20 ns;
    x <= '1'; wait for 20 ns;
    x <= '1'; wait for 20 ns;
    wait;
```

```
end process;
```

```
end behavior;
```



### *Explanation of Test Bench:*

- A clock of 20 ns period is generated.
- Reset is activated initially for initialization.
- Inputs simulate a stream containing two occurrences of the 111 pattern.
- Output 'y' will go high when 111 is detected.

### *Important Note:*

- State machine resets to  $S_0$  on 0 and allows overlapping sequence detection.
- This type of design is essential in communication protocols and serial data stream monitoring.

## *Sequential Synchronous Machine Design*

### *Pyq Question:*

- Draw state diagram and write VHDL code and its test bench for sequence detector 101. [10]

### *Introduction:*

- A sequence detector is a type of finite state machine (FSM) that monitors a stream of input bits to identify a specific pattern.

62

The sequence detector for pattern 101 activates an output signal when this sequence appears in the input.

### *Definition:*

- **Sequence Detector:** A circuit that generates an output signal when a particular input pattern is detected within a stream of bits.
- It is designed using FSM techniques and categorized into Moore or Mealy models.

### *State Description:*

- The design requires four states to detect 101:
  - $S_0$ : Initial state with no match.



- $S_1$ : Detected first 1.
- $S_2$ : Detected 10.
- $S_3$ : Full pattern 101 matched.

Diagram:



Explanation of Diagram:

- In  $S_0$ , if input is 1, move to  $S_1$ , else stay in  $S_0$ .
  - In  $S_1$ , if input is 0, move to  $S_2$ , else stay in  $S_1$ .
  - In  $S_2$ , input 1 leads to  $S_3$ , which activates output.
- 63      In  $S_3$ , output is high and next transitions allow overlapping pattern detection.

VHDL Code for Sequence Detector 101:

```

library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
  
```

```

entity seq_detector_101 is
  
```

Port (

clk : in std\_logic;

rst : in std\_logic;

x : in std\_logic;



```
y : out std_logic  
);  
end seq_detector_101;
```

```
architecture Behavioral of seq_detector_101 is
```

```
type state_type is (S0, S1, S2, S3);  
signal state, next_state : state_type;  
begin
```

```
process(clk, rst)  
begin  
if rst = '1' then  
    state <= S0;  
elsif rising_edge(clk) then  
    state <= next_state;  
end if;  
end process;
```

```
process(state, x)  
begin  
case state is  
when S0 =>  
    if x = '1' then  
        next_state <= S1;  
    else  
        next_state <= S0;  
    end if;  
    y <= '0';
```

```
when S1 =>  
    if x = '0' then  
        next_state <= S2;  
    else
```



```

next_state <= S1;
end if;
y <= '0';

when S2 =>
if x = '1' then
    next_state <= S3;
else
    next_state <= S0;
end if;
y <= '0';

when S3 =>
if x = '1' then
    next_state <= S1;
else
    next_state <= S0;
end if;
y <= '1';
end case;
end process;
end Behavioral;

```

65

; Bench for Sequence Detector 101:

```

library IEEE;
use IEEE.STD_LOGIC_1164.ALL;

entity tb_seq_detector_101 is
end tb_seq_detector_101;

architecture behavior of tb_seq_detector_101 is
signal clk, rst, x : std_logic := '0';

```



```
signal y : std_logic;

component seq_detector_101
Port (
    clk : in std_logic;
    rst : in std_logic;
    x : in std_logic;
    y : out std_logic
);
end component;
```

```
begin
```

```
uut: seq_detector_101 Port Map (
    clk => clk,
    rst => rst,
    x => x,
    y => y
);
```

```
clk_process :process
begin
    clk <= '0'; wait for 10 ns;
66    clk <= '1'; wait for 10 ns;
end process;
```

```
stim_proc: process
begin
    rst <= '1'; wait for 20 ns;
    rst <= '0';
    x <= '1'; wait for 20 ns;
    x <= '0'; wait for 20 ns;
```



```
x <= '1'; wait for 20 ns;  
x <= '1'; wait for 20 ns;  
x <= '0'; wait for 20 ns;  
x <= '1'; wait for 20 ns;  
wait;  
end process;  
  
end behavior;
```

#### *Explanation of Test Bench:*

- A clock with 20 ns cycle is generated continuously.
- Reset is applied for initialization at the start.
- The input stream is designed to include 101 multiple times for testing.
- Output y is expected to go high when the sequence 101 is detected.

#### *Meta-stability and Timing Constraints*

##### *Pyq Question:*

- What is Setup time and Hold Time? Explain Meta-stability in detail. [5]

##### *Introduction:*

- Timing constraints are important in digital circuits to ensure the correct storage and transfer of data between flip-flops and registers.

67

The concepts of setup time, hold time, and meta-stability are directly related to synchronization and reliability in sequential circuits.

##### *Definition:*

- *Setup time* : The minimum time before the active clock edge during which the input data must be stable to be reliably sampled by the flip-flop.
- *Hold time* : The minimum time after the clock edge during which the input data must remain stable to be correctly captured.



### *Explanation of Setup Time:*

- Setup time ensures that data has reached and settled at the input of a flip-flop before the clock transition occurs.
- Violating the setup time may lead to incorrect data being stored, which causes circuit malfunction or unstable output.

### *Explanation of Hold Time:*

- Hold time ensures that the data does not change immediately after the clock edge, giving the flip-flop enough time to register the correct value.
- Violation of hold time may lead to data corruption, especially in high-speed circuits with short delays.

### *Meta-stability:*

- Meta-stability is a condition where a digital system enters an undefined state due to violation of setup or hold time.
- When a flip-flop receives data close to the clock edge, it may not resolve to a stable high or low level within the expected time.
- In meta-stable state, the output may oscillate or settle to an invalid logic level, leading to unpredictable behavior.
- Meta-stability does not mean failure, but it introduces a probability of unreliable or delayed data capture.

### *Cause of Meta-stability:*

68

Occurs typically in asynchronous data transfer between two clock domains.

- When a signal from one clock domain is fed to another without proper synchronization, it may be captured incorrectly.

### *Solutions for Meta-stability:*

- **Use of synchronizer circuits :** Typically, a pair of flip-flops connected in series helps reduce the probability of metastability affecting downstream logic.
- **Increase setup and hold margin :** Designing with sufficient timing margins and considering delays in critical paths.



- Use of Gray code counters in asynchronous communication to ensure only one bit changes at a time.
- Implementing clock domain crossing (CDC) techniques : These include dual flip-flop synchronizers or FIFO buffers for reliable data transfer.

#### **Additional Notes:**

- Meta-stability cannot be completely eliminated but its probability can be reduced significantly with careful timing design.
- It is a critical consideration in high-speed and multi-clock domain digital systems.

### **(Sequential System Timing Issues)**

#### **Pyq Question:**

- What is meant by Meta-stability? Explain any one solution in detail. [5]

#### **Introduction:**

- Meta-stability is a crucial concern in digital design where signals pass between different clock domains or asynchronous inputs are used.
- It can lead to unpredictable logic behavior, causing unreliable operation in synchronous digital circuits.

#### **Definition:**

- Meta-stability is a condition where a flip-flop or any sequential element enters an undefined state due to violation of setup or hold timing.
- It results in an output that is neither logic high nor logic low, and it may take unpredictable time to resolve.

69

#### **Explanation of Meta-stability:**

- When a signal is captured by a flip-flop without satisfying setup or hold time, the output may oscillate or stay at an unknown voltage.
- It causes uncertainty in logic evaluation, leading to data corruption or unstable system behavior.

- Meta-stability usually occurs at the boundary where signals cross from one clock domain to another asynchronously.
- Once meta-stability occurs, the resolving time of the flip-flop may exceed the clock period, affecting downstream logic stages.

#### *Impact of Meta-stability on Design:*

- Causes timing violations and data misinterpretation at the output of the synchronizing flip-flop.
- Can propagate faulty logic through the system if not properly managed.
- Severely affects high-speed and low-power digital circuits where margins are already tight.

#### *Solution to Meta-stability:*

- One common and effective method to address meta-stability is Double Flop Synchronization using two flip-flops in series.

#### *Explanation of Double Flop Synchronization:*

- The asynchronous signal is passed through two cascaded flip-flops which are clocked by the same clock domain.
- The first flip-flop captures the asynchronous signal, possibly entering meta-stability.
- The second flip-flop gets more time to receive a stable logic level as the first flip-flop settles by the next clock cycle.
- This reduces the probability of meta-stability propagating into the synchronous logic.

70

#### *Advantages of Double Flop Synchronization:*

- Offers high reliability for resolving meta-stability in practical systems.
- Simple to implement and does not require complex additional hardware.
- Can be extended with more flip-flops if system timing is more stringent or probability of meta-stability is high.

#### *Use Case in Digital Design:*



- Frequently used when interfacing between asynchronous input lines (like external buttons or sensors) and system logic.
- Also applied in clock domain crossing situations to ensure timing-safe transfer of control signals.

### (Noise Margin and Fan-out in Digital Logic)

#### Pyq Question:

- Write short note on noise margin. [5]
- Explain the concept of fan-out and its effect on digital design. [5]

#### Introduction:

- Digital logic systems are affected by electrical characteristics such as noise, loading, and signal degradation.
- Noise margin and fan-out are critical parameters that define robustness and reliability in digital circuit design.

#### Noise Margin:

- Noise margin is the maximum electrical noise voltage that a digital signal can tolerate without causing logic errors.
- It provides a safety buffer to ensure that logic levels remain recognizable even when noise is present in the circuit.
- Logic levels are classified as high (logic 1) or low (logic 0), and noise margin ensures distinction between these two levels.

71

There are two types of noise margins — Noise Margin High (NMH) and Noise Margin Low (NML) which apply to logic 1 and logic 0 levels respectively.

- NMH is the difference between minimum output high voltage and minimum input high voltage required by logic gate.
- NML is the difference between maximum input low voltage and maximum output low voltage that the logic gate can handle.
- A good digital design ensures sufficient noise margin to avoid malfunction due to coupling, crosstalk, or voltage fluctuations.

### *Importance of Noise Margin:*

- Ensures noise immunity in digital systems operating in harsh or high-interference environments.
- Improves stability and reliability by reducing the chances of spurious transitions or incorrect logic interpretation.
- Vital for interfacing different logic families which may have different threshold levels and drive capabilities.

### *Fan-out:*

- Fan-out is defined as the maximum number of inputs a single digital output can drive without performance degradation.
- It is a measure of the driving capability of a logic gate's output with respect to the number of loads it can support.
- Fan-out depends on the current sinking or sourcing capacity of the driving gate and the input current requirement of receiving gates.
- If fan-out exceeds the permissible limit, the signal may become slow, distorted, or may not reach the required logic level.

### *Effect of Fan-out on Digital Design:*

- High fan-out reduces the speed of logic transitions due to increased capacitance and load.
- It can introduce delays and weaken the output signal level, resulting in timing errors in synchronous designs.
- Modern CMOS gates typically allow higher fan-out compared to older TTL logic due to lower input current requirements.

72

To maintain signal integrity, buffers or drivers may be used when fan-out requirements exceed standard capability.

### *Related Design Considerations:*

- Fan-out must be considered while designing clock distribution networks, buses, or control lines to avoid signal attenuation.



- In systems with high-speed switching, improper fan-out can lead to glitches, race conditions, and degraded performance.
- Designers often refer to datasheets for standard logic families like TTL or CMOS to ensure fan-out compatibility.

### (Clock Skew and Timing Considerations)

#### Pyq Question:

- What is Clock Skew? What are techniques to minimize it? [5]
- Write short note on clock skew and clock jitter. [7]

#### Introduction:

- In synchronous circuits, a common clock signal is used to trigger all sequential elements simultaneously.
- Variations or inconsistencies in clock arrival times at different parts of the circuit can introduce issues like skew and jitter.

#### Definition:

- Clock skew refers to the difference in arrival time of the clock signal at different flip-flops or elements in a synchronous circuit.
- Clock jitter is the deviation in timing of clock edges from their expected position due to noise, power fluctuations, or signal distortion.

#### Explanation of Clock Skew:

- 73
- Clock skew occurs due to unequal wire lengths, different delays in routing, or variations in buffers distributing the clock signal.
  - It can lead to timing violations like setup or hold time errors if the skew exceeds the tolerable limit of the circuit.
  - There are two types of clock skew — positive skew and negative skew — depending on whether the clock reaches the source or destination flip-flop first.
  - In positive skew, the clock reaches the destination after the source, while in negative skew, it reaches earlier than the source.

### *Consequences of Clock Skew:*

- Clock skew may cause a flip-flop to capture data too early or too late, leading to race conditions or data corruption.
- It reduces timing margins and can violate the synchronous operation of the system if not handled properly.
- Clock skew affects maximum operating frequency and overall performance of digital systems.

### *Techniques to Minimize Clock Skew:*

- Use of *clock tree synthesis (CTS)* in physical design to ensure balanced clock routing paths to each flip-flop.
- Use of *buffer insertion* and *delay balancing* to equalize propagation delay across all branches of the clock network.
- *Symmetric layout design* to keep all clock paths of equal length and characteristics.
- Application of *phase-locked loops (PLLs)* and *delay-locked loops (DLLs)* to realign clock phases and mitigate skew.
- Maintain consistent *load capacitance* on all clock-driven elements to prevent skew caused by unequal fan-out.

### *Explanation of Clock Jitter:*

- Clock jitter represents the temporal instability of clock edges, observed as rapid variations from the ideal timing.
- It is typically caused by electrical noise, power supply instability, or poor shielding in transmission lines.
- Jitter is critical in high-speed digital and communication systems where even small variations can cause synchronization failure.
- Unlike skew, jitter is not systematic and varies randomly over time.

74

### *Difference Between Skew and Jitter (Table Only Where Needed):*

| Parameter  | Clock Skew                       | Clock Jitter                          |
|------------|----------------------------------|---------------------------------------|
| Definition | Time difference in clock arrival | Deviation in actual clock edge timing |

|         |                                   |                                           |
|---------|-----------------------------------|-------------------------------------------|
| Nature  | Systematic (static)               | Random or pseudo-random (dynamic)         |
| Cause   | Uneven path delays, routing       | Noise, supply voltage variation           |
| Impact  | Causes setup/hold time violations | Affects signal stability, synchronization |
| Control | Managed through layout techniques | Reduced using low-noise design            |

### Design Considerations:

- Both skew and jitter are timing challenges and must be carefully analyzed during *timing analysis* and *clock distribution design*.
- In critical path design, keeping timing margins and accounting for skew/jitter ensures robust and high-performance operation.
- Timing constraints* in design tools (like Synopsys, Cadence) include skew and jitter during *clock domain crossing* or *data transfer analysis*.

### (Clock Jitter)

#### Pyq Question:

- What is Clock Jitter? What are sources of it? [5]

#### Introduction:

- In synchronous digital circuits, a stable clock signal is essential for accurate timing and coordination of sequential operations.
- Any variation in clock signal timing can lead to errors in data transfer and synchronization across the system.

75

#### Definition:

- Clock jitter* is the deviation of a clock signal's transition time from its expected position due to instability or noise.
- It is measured as the difference between actual and ideal arrival time of a clock edge at a given reference point.



### *Explanation of Clock Jitter:*

- Clock jitter introduces uncertainty in the timing of digital events, potentially leading to timing violations.
- It is particularly critical in high-frequency systems where even a small deviation affects proper data capture.
- Jitter does not follow a fixed pattern and appears randomly, making it harder to compensate without proper design techniques.
- It affects clock-to-output delay, setup time, and hold time margins, degrading overall performance.

### *Types of Clock Jitter:*

- *Cycle-to-cycle jitter* : Difference in the duration of consecutive clock periods.
- *Period jitter* : Variation in individual clock periods over a reference period.
- *Phase jitter* : Deviation in phase position of a clock edge from its ideal timing.

### *Sources of Clock Jitter:*

- *Power supply noise* : Fluctuations in the supply voltage affect internal oscillators and drivers.
- *Electromagnetic interference (EMI)* : External noise from nearby circuits or devices disturbs the timing pulse.
- *Crosstalk from adjacent signals* : High-speed transitions on nearby lines induce timing errors in the clock path.
- *Thermal noise and transistor mismatch* : Internal random variations at transistor level cause clock instability.
- *Ground bounce and switching noise* : Rapid switching causes common return path voltage variations, impacting clock edge timing.

76

*Imperfect Phase-Locked Loop (PLL) or Delay-Locked Loop (DLL)* : Inaccurate feedback loops in PLL/DLL circuits can introduce periodic jitter.

### *Design Considerations to Minimize Jitter:*

- Use low-jitter clock sources such as crystal oscillators and high-quality PLLs with proper loop filter design.

- Ensure clean and isolated power supply to sensitive clock circuits to avoid coupling of noise.
- Route clock signals away from noisy data lines and use proper shielding or differential signaling.
- Apply decoupling capacitors near clock buffers and receivers to suppress high-frequency noise components.

### Importance in System Design:

- Clock jitter must be accounted for in timing analysis and timing closure during digital IC design.
- Systems using high-speed data transmission protocols (like USB, PCIe, DDR) impose strict jitter tolerance limits.
- Proper jitter management ensures reliable operation, better timing margins, and error-free data sampling.

### (Clock Distribution)

#### Pyq Question:

- Explain clock Distribution Techniques in detail. [5]

#### Introduction:

- In synchronous digital circuits, the clock signal must be delivered uniformly to all sequential elements like flip-flops and registers.
- Improper distribution can lead to clock skew, jitter, and overall system failure in timing-critical operations.

77

#### Definition:

Clock distribution is the method of routing the clock signal across a chip or circuit to ensure consistent and synchronized operation.

- It involves structured network paths designed to balance clock delay, loading, and signal integrity.

### Need for Clock Distribution:

- Without proper distribution, signals may arrive late or early at different circuit locations, causing timing violations.
- A well-designed clock distribution ensures minimal skew, balanced load, and synchronized system performance.

### Clock Distribution Techniques:

- H-Tree Distribution**: Uses a symmetrical H-shaped layout where the clock signal is divided evenly at each branch to reach all endpoints simultaneously.
- Spine and Branch (Fishbone) Method**: Clock signal is routed along a central spine and branched off to various logic blocks with equal-length lines.
- Grid-Based Distribution**: A clock grid is spread across the chip with multiple points of delivery, ideal for very large chips with high logic density.
- Buffered Tree Network**: Clock tree is segmented and uses buffers at nodes to regenerate the signal and reduce delay degradation.
- Clock Mesh Network**: Interconnected clock wires form a mesh, offering high redundancy and tolerance to local clock mismatches.

### Diagram:

- As the question explicitly asks to explain clock distribution techniques, a diagram is required for H-Tree topology.



78

### Explanation of Diagram:

- Clock signal starts from the central source and is divided equally using buffer B1 into two symmetric halves.

- Each half further splits through buffers B2 and B3, maintaining equal-length paths to minimize skew.
- Final branches reach leaf nodes A, B, C, and D, ensuring synchronous arrival of the clock signal at all points.

#### *Design Considerations in Clock Distribution:*

- Maintain symmetrical routing to ensure equal propagation delays across all paths.
- Use low-skew buffers and keep wiring lengths matched to reduce phase mismatches.
- Avoid excessive fan-out from any single buffer, as it causes signal delay and distortion.
- Shield clock lines from noisy signals and place decoupling capacitors to maintain power stability.

#### *Impact on Performance:*

- Efficient clock distribution helps in timing closure, improves chip reliability, and ensures error-free data capture.
- Especially critical in high-speed, low-power digital designs where even minor delays can degrade functionality.

#### (Supply and Ground Bounce)

#### *Pyq Question:*

- Why should supply and ground bounce be taken care? How are these minimized? [5]

#### *Introduction:*

- In high-speed digital circuits, rapid switching causes variations in supply and ground voltage levels, known as bounce effects.

79

These effects are critical because they interfere with the correct logic level detection in circuits.

#### *Definition:*



- Supply bounce refers to a temporary rise in the power ( $V_{DD}$ ) line voltage due to sudden current demand by multiple switching gates.
- Ground bounce refers to a momentary rise in the ground potential above 0 volts due to return current surge from multiple switching transistors.

#### *Reasons to Take Care of Bounce Effects:*

- Noise margin is reduced when power or ground lines fluctuate, increasing the risk of false triggering in logic gates.
- Signal integrity is compromised due to overlapping of power supply noise with logic threshold levels, leading to unreliable system behavior.
- Excessive bounce can delay or even corrupt timing-sensitive paths in VLSI systems, causing setup and hold violations.
- Input/output buffers and flip-flops become more sensitive to incorrect logic detection, increasing functional errors.

#### *Causes of Supply and Ground Bounce:*

- Simultaneous switching of multiple output drivers in a short time duration, called simultaneous switching output (SSO).
- Inductance in power and ground lines causes voltage spikes when current changes rapidly, as described by  $L \times di/dt$  behavior.
- Longer traces or weak PCB layout increases inductive impedance and hence the voltage fluctuation on the power-ground rails.

#### *Techniques to Minimize Bounce Effects:*

- Use of Decoupling Capacitors : Placed close to IC power pins, they absorb transient current and maintain voltage levels during switching.
- Split Power and Ground Planes : Providing wide, solid planes on PCB reduces inductive impedance and voltage fluctuations.

*Controlled Slew Rate Drivers :* Slowing the output transition reduces the rate of current change ( $di/dt$ ) and hence voltage spikes.

- Reduced Simultaneous Switching : Design logic so that fewer outputs switch at once, preventing a collective surge of return current.



- **Power and Ground Pin Multiplication** : Using multiple V<sub>DD</sub> and ground pins lowers the total impedance and distributes return current effectively.
- **Use of On-Chip Decoupling** : Integrated capacitance within the chip close to transistors helps control localized bounce issues.
- **Termination Techniques** : Proper signal line termination reduces reflection and minimizes noise-induced current that adds to bounce.

#### *Impact on Circuit Reliability:*

- Ground and supply bounce may not damage hardware, but can cause intermittent, hard-to-debug logic errors.
- It is critical in nanometer-scale technologies where even small noise margins are enough to cause logic failures.

#### *(Power Distribution Techniques)*

#### *Pyq Question:*

- Write short note on power distribution techniques. [5]

#### *Introduction:*

- In VLSI and digital circuit design, power distribution techniques are used to ensure stable and noise-free power supply to all active components.

#### *Definition:*

- Power distribution refers to the method of delivering power (V<sub>DD</sub> and GND) uniformly across the entire integrated circuit with minimal voltage drop and noise.

#### *Objective of Power Distribution Techniques:*

- To ensure even power supply to all parts of the chip regardless of their position or current demands.
- To reduce voltage fluctuations, ground bounce, and IR drop that can lead to faulty logic operations or performance loss.



### *Challenges in Power Distribution:*

- Increased current density and switching speeds lead to rapid current surges, causing noise in power lines.
- IR drop or voltage loss due to resistance in metal layers affects logic thresholds.
- Non-uniform power flow in complex ICs causes localized power starvation or overheating.

### *Power Distribution Techniques:*

- *Power Grid Network*: A mesh of metal lines spreads power throughout the chip to maintain uniform voltage and reduce IR drop.
- *Multiple Power Rails*: Separate rails for core logic, I/O, and analog blocks to prevent noise coupling between different modules.
- *Decoupling Capacitors*: Placed near switching elements to provide quick local current during transients and suppress voltage fluctuations.
- *Use of Wide Metal Layers*: Wider interconnects reduce resistance and help carry more current without excessive voltage drop.
- *Hierarchical Power Routing*: Divides power distribution into stages (global, intermediate, and local) to efficiently handle high-current paths.
- *Use of Power Rings*: Rings around the periphery of blocks distribute power evenly and feed it into the grid at multiple points.
- *On-Chip Voltage Regulators*: Convert higher voltage into stable internal supply, reducing noise from external sources.
- *Dedicated Power and Ground Pads*: Extra I/O pins ensure better connectivity and reduce impedance in power delivery path.

### *Importance in VLSI Design:*

- Effective power distribution ensures consistent operation across the chip and prevents timing errors due to voltage variations.
- Helps in reducing power integrity issues, making designs robust at higher frequencies and lower technology nodes.



## (Power Optimization)

### Pyq Question:

- Write Short note on Power Optimization. [5]

### Introduction:

- Power optimization is a major concern in modern VLSI and embedded systems to reduce heat, enhance performance, and prolong battery life in portable devices.

### Definition:

- Power optimization refers to the process of reducing overall power consumption of a system without compromising performance, speed, or functionality.

### Need for Power Optimization:

- Excessive power consumption leads to heating issues, reduced reliability, and increased cooling cost.
- Essential for battery-operated devices to extend operating time without frequent recharging.
- Helps in meeting thermal and energy budgets for compact systems like mobile and IoT devices.

### Types of Power Dissipation in Circuits:

- Dynamic Power : Caused due to charging and discharging of load capacitances during switching activity.
- Static Power : Occurs due to leakage currents even when the circuit is idle or not switching.
- Short-Circuit Power : Generated briefly when both PMOS and NMOS are ON during input transitions.

### Techniques for Power Optimization:

83

Voltage Scaling : Lowering supply voltage directly reduces dynamic power as power is proportional to square of voltage.



- *Clock Gating* : Stops clock to idle blocks to prevent unnecessary switching and save power.
- *Power Gating* : Disconnects power supply to unused blocks using sleep transistors to reduce leakage power.
- *Multi-V<sub>DD</sub> Design* : Uses different supply voltages for different blocks based on performance requirements.
- *Dynamic Voltage and Frequency Scaling (DVFS)* : Adjusts voltage and frequency according to workload to balance performance and power.
- *Use of Low-Power Cells* : Replacing standard cells with optimized low-power versions during synthesis for power saving.
- *Activity-Driven Design* : Minimizes switching activity in logic by using signal encoding or operand isolation.
- *Technology Scaling and Process Optimization* : Uses advanced fabrication techniques to lower threshold voltages and leakage.

#### *Importance in Modern Design:*

- Power optimization is critical in nanoscale technologies where leakage dominates and thermal limits are tight.
- Helps meet environmental goals by lowering energy usage in large-scale computing and data centers.

#### (Interconnect Routing Techniques)

#### *Pyq Question:*

- Explain Interconnect routing Techniques. [5]

#### *Introduction:*

- Interconnect routing techniques are used to establish signal paths between components on an integrated circuit during layout design of VLSI circuits.



- Interconnect routing refers to the process of creating physical metal paths that connect various logic gates or functional blocks in a chip layout.

#### Purpose of Interconnect Routing:

- Ensures signal integrity, timing accuracy, and minimization of delay and power consumption in modern ICs.
- Facilitates functional and electrical connectivity between multiple circuit blocks.

#### Phases of Routing in VLSI:

- Global Routing : Determines coarse routing paths between source and destination blocks across large regions.
- Detailed Routing : Assigns specific metal layers and tracks to define precise wire paths and vias between nets.

#### Interconnect Routing Techniques:

- Channel Routing : Used between two rows of cells; all nets pass through a predefined channel between the rows.
- Maze Routing : Uses a grid-based algorithm to find the shortest or least-cost path between terminals; ensures no overlap or violation.
- Line-Probe Algorithm : Traces a path from one terminal and probes for connection using horizontal or vertical segments.
- Steiner Tree Routing : Minimizes total wire length and delay by connecting multiple points efficiently using Steiner points.
- Greedy Algorithm-Based Routing : Connects nets based on cost functions, often used in conjunction with heuristics in global routing.
- Spine-and-Rib Routing : A backbone (spine) runs through the center, with individual connections (ribs) extending to modules.
- Z-routing and L-routing : Common in PCB and IC layout, where tracks are laid using L-shaped or Z-shaped paths to avoid obstacles.

#### Important Routing Considerations:



- *Crosstalk Minimization* : Prevents unwanted interference by spacing signals correctly.
- *Congestion Handling* : Balances routing resources to avoid overuse in dense areas.
- *Layer Assignment* : Ensures minimum number of vias and maintains manufacturability by choosing appropriate layers.

#### *Applications of Routing Techniques:*

- Used in ASIC and FPGA design flow for chip implementation.
- Essential for timing-driven layout synthesis to meet setup and hold time requirements.

#### *Related Concepts:*

- Routing tools (like Cadence Innovus or Synopsys IC Compiler) use these algorithms for efficient automatic layout generation.
- Advanced routing supports multi-metal layers and complex design rules in modern technology nodes.

### **(Signal Integrity Issues)**

#### *Pyq Question:*

- Explain signal integrity issues. [5]

#### *Introduction:*

- In digital systems, signal integrity refers to the ability of signals to propagate without distortion, delay, or interference from their source to destination.

#### *Definition:*

- *Signal Integrity (SI)* is the measure of the quality of electrical signals in an interconnect path, especially their voltage levels, timing, and shape.

- Ensures reliable data transmission in high-speed digital circuits.



- Prevents logic errors caused due to unexpected signal behavior like ringing, glitches, or overshoot.

### *Causes of Signal Integrity Issues:*

- *Reflection* : Occurs when impedance mismatch causes part of the signal to bounce back toward the source.
- *Crosstalk* : Unwanted coupling between nearby signal lines causing noise or distortion.
- *Ringing* : Oscillation of the signal due to underdamped transmission lines or improper termination.
- *Ground Bounce and Supply Noise* : Fluctuation in ground or power rails due to simultaneous switching, affecting signal levels.
- *Delay Variations* : Skew or delay caused due to wire resistance, parasitic capacitance, and inductance.
- *Simultaneous Switching Output (SSO) Noise* : Noise generated when multiple outputs switch simultaneously causing voltage fluctuations.

### *Impact of Signal Integrity Problems:*

- Leads to incorrect logic detection by the receiving circuits, resulting in data corruption.
- Increases bit error rates, especially in high-speed serial interfaces or buses.
- May cause functional failure or require additional error correction circuitry.

### *Solutions to Signal Integrity Issues:*

- *Proper Termination* : Use of resistive or matched termination to reduce reflections at the ends of signal lines.
- *Impedance Control* : Designing PCB traces with consistent width and dielectric spacing to maintain constant impedance.
- *Reduced Edge Rates* : Slower transition times minimize crosstalk and ringing in high-speed signals.
- *Differential Signaling* : Reduces susceptibility to common-mode noise and improves noise immunity.



- *Use of Ground Planes* : Minimizes ground bounce and provides low impedance return paths.
- *Shielding and Spacing* : Increases spacing between high-speed lines or adds shielding to reduce electromagnetic interference.
- *Skew Management* : Ensures equal delay for related signals by controlling routing length and load.

#### *Design Practices for Signal Integrity:*

- Avoid sharp turns in PCB routing to reduce signal reflection.
- Minimize stubs and branching in signal lines to prevent delay and impedance changes.
- Simulate interconnect behavior using signal integrity tools during design phase.

#### *Real-World Importance:*

- Critical in high-speed processors, DDR memory, USB, HDMI, PCIe, and other advanced digital systems.
- Essential in VLSI and PCB design for predictable and reliable electronic behavior.

