

### MSPA-01 Evaluation

|                                  |                         |
|----------------------------------|-------------------------|
| Name : <b>SHIVAM NITIN SALVE</b> | Roll No. <b>56</b>      |
| Branch : <b>VLSI</b>             | Sem <b>5</b>            |
| Batch: <b>A4</b>                 | Reg no: <b>23070029</b> |

#### Classroom Examples ( 5 Marks )

|          |                                                                                                                                           |
|----------|-------------------------------------------------------------------------------------------------------------------------------------------|
| Code     | <pre> 22 //SHIVAM SALVE 23 module and_gate(y,a,b); 24   output wire y; 25   input wire a,b; 26   assign y=a&amp;b; 27 endmodule 28 </pre> |
| RTL View |                                                                                                                                           |

|          |                                                                                                 |
|----------|-------------------------------------------------------------------------------------------------|
| Code     | <pre> //SHIVAM SALVE module or_gate(y,a,b); output y; input a,b; assign y=a b; endmodule </pre> |
| RTL View |                                                                                                 |

|          |                                                                                                                                                                                                                                        |
|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Code     | <pre> 20 //SHIVAM SALVE VLSI 56 21 module ex_or_gate(Y,a,b); 22 input a,b; 23 output Y; 24 wire t1,t2,t3,t4; 25 assign t1=~a; 26 assign t2=~b; 27 assign t3=a&amp;t2; 28 assign t4=b&amp;t1; 29 assign Y=t3 t4; 30 endmodule 31 </pre> |
| RTL View | <pre> graph LR     a((a)) --&gt; t1[RTL_AND]     b((b)) --&gt; t2[RTL_AND]     t1 --&gt; t3[RTL_OR]     t2 --&gt; t3     t3 --&gt; Y((Y)) </pre>                                                                                       |

|          |                                                                                                                                                                                          |
|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Code     | <pre> 20 //SHIVAM SALVE VLSI 56 21 module ckt_1(y,a,b,c); 22 output y; 23 input a,b,c; 24 wire t1,t2; 25 assign t1=a&amp;b; 26 assign t2=b c; 27 assign y=t1&amp;t2; 28 endmodule </pre> |
| RTL View | <pre> graph LR     a((a)) --&gt; t1[RTL_AND]     b((b)) --&gt; t1     t1 --&gt; t2[RTL_AND]     c((c)) --&gt; t2     t2 --&gt; t3[RTL_OR]     t3 --&gt; y((y)) </pre>                    |

|          |                                                                                                                                                                                    |
|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Code     | <pre> 20 //SHIVAM SALVE VLSI 56 21 module half_adder(sum,carry,a,b); 22   output sum,carry; 23   input a,b; 24   assign sum=a^b; 25   assign carry=a&amp;b; 26 endmodule 27 </pre> |
| RTL View |                                                                                                                                                                                    |

|          |                                                                                                                                                                                                                                                                                 |
|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Code     | <pre> 20 //SHIVAM SALVE VLSI 56 21 module fullAdder(sum,cout,a,b,cin); 22   input a,b,cin; 23   output sum,cout; 24   wire t1,t2,t3; 25   assign t1=a^b; 26   assign t2=a&amp;b; 27   assign sum=t1^cin; 28   assign t3=t1&amp;cin; 29   assign cout=t2 t3; 30 endmodule </pre> |
| RTL View |                                                                                                                                                                                                                                                                                 |

|          |                                                                                                                                                                                     |
|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Code     | <pre> 20 //SHIVAM SALVE VLSI 56 21 module halfSub(d,bo,a,b); 22 input a,b; 23 output d,bo; 24 wire t1; 25 assign t1=~a; 26 assign d=a^b; 27 assign bo=t1&amp;b; 28 endmodule </pre> |
| RTL View |                                                                                                                                                                                     |

|          |                                                                                                                                                                                                                                                                                             |
|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Code     | <pre> 20 //SHIVAM SALVE VLSI 56 21 module fullSub(d,bo,a,b,cin); 22 input a,b,cin; 23 output d,bo; 24 wire t1,t2,t3,t4,t5; 25 assign t1=~a; 26 assign t2=~cin; 27 assign t3=a^b; 28 assign d=t3^cin; 29 assign t4=b&amp;t1; 30 assign t5=t2&amp;t3; 31 assign bo=t4 t5; 32 endmodule </pre> |
| RTL View |                                                                                                                                                                                                                                                                                             |

|          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Code     | <pre> 20 //SHIVAM SALVE VLSI 56 21 module incremental_code(y3,y2,y1,y0,x3,x2,x1,x0); 22   output y3,y2,y1,y0; 23   input x3,x2,x1,x0; 24   assign y3=(x3&amp;~x1) (x3&amp;x2) ((~x3)&amp;(~x2)&amp;x1&amp;x0) (x3); 25   assign y2=(x2&amp;(~x1)) (x2&amp;x0) ((x3)&amp;(~x2)&amp;x1&amp;x0) ((~x3)&amp;(~x2)&amp;x1&amp;x0); 26   assign y1=x1^x0; 27   assign y0=~x0; 28 endmodule </pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| RTL View | <p>The RTL diagram illustrates the logic implementation of the <code>incremental_code</code> module. It starts with four input signals: <code>x0</code>, <code>x1</code>, <code>x2</code>, and <code>x3</code>. These are processed through a series of logic gates to produce four output signals: <code>y0</code>, <code>y1</code>, <code>y2</code>, and <code>y3</code>.</p> <p>The logic flow is as follows:</p> <ul style="list-style-type: none"> <li><code>x0</code> is connected to a <code>RTL_INV</code> gate, which produces <code>y33_i_0</code>.</li> <li><code>x1</code> is connected to a <code>RTL_AND</code> gate, which takes <code>x0</code> and <code>x1</code> as inputs to produce <code>y22_i_0</code>.</li> <li><code>x2</code> is connected to a <code>RTL_OR</code> gate, which takes <code>x0</code> and <code>x2</code> as inputs to produce <code>y21_i_0</code>.</li> <li><code>x3</code> is connected to a <code>RTL_INV</code> gate, which produces <code>y33_i_1</code>.</li> <li><code>y33_i_0</code> and <code>y33_i_1</code> are combined via an <code>RTL_AND</code> gate to produce <code>y22_i_1</code>.</li> <li><code>x0</code> and <code>x3</code> are combined via an <code>RTL_AND</code> gate to produce <code>y32_i_0</code>.</li> <li><code>x1</code> and <code>x3</code> are combined via an <code>RTL_AND</code> gate to produce <code>y32_i_1</code>.</li> <li><code>x2</code> and <code>x3</code> are combined via an <code>RTL_AND</code> gate to produce <code>y31_i_0</code>.</li> <li><code>x0</code> and <code>x2</code> are combined via an <code>RTL_OR</code> gate to produce <code>y20_i_0</code>.</li> <li><code>x1</code> and <code>x2</code> are combined via an <code>RTL_OR</code> gate to produce <code>y21_i_1</code>.</li> <li><code>x0</code> and <code>x1</code> are combined via an <code>RTL_OR</code> gate to produce <code>y30_i_0</code>.</li> <li><code>y22_i_0</code>, <code>y22_i_1</code>, <code>y21_i_0</code>, <code>y21_i_1</code>, <code>y31_i_0</code>, and <code>y30_i_0</code> are combined via an <code>RTL_OR</code> gate to produce <code>y2_i_0</code>.</li> <li><code>y2_i_0</code> and <code>y33_i_0</code> are combined via an <code>RTL_XOR</code> gate to produce <code>y1_i_0</code>.</li> <li><code>y1_i_0</code> and <code>y33_i_1</code> are combined via an <code>RTL_OR</code> gate to produce <code>y0_i_0</code>.</li> <li><code>y0_i_0</code> is passed through an <code>RTL_INV</code> gate to produce the final output <code>y0</code>.</li> <li><code>y1_i_0</code> is passed through an <code>RTL_OR</code> gate to produce the final output <code>y1</code>.</li> <li><code>y2_i_0</code> is passed through an <code>RTL_OR</code> gate to produce the final output <code>y2</code>.</li> <li><code>y3_i_0</code> is passed through an <code>RTL_OR</code> gate to produce the final output <code>y3</code>.</li> </ul> |

## Code

```
20 // SHIVAM SALVE VLSI 56
21 module gray_code(y3,y2,y1,y0,b3,b2,b1,b0);
22   output y3,y2,y1,y0;
23   input b3,b2,b1,b0;
24   assign y3=b3;
25   assign y2=b3^b2;
26   assign y1=b2^b1;
27   assign y0=b1^b0;
28 endmodule
```

## RTL View



|          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Code     | <pre> 20 // SHIVAM SALVE VLSI 56 21 module mux_2X1(y,a,b,s); 22   input a,b,s; 23   output y; 24   assign y=((~s)&amp;a) (s&amp;b); 25 endmodule </pre>                                                                                                                                                                                                                                                                                                                             |
| RTL View | <pre> graph LR     s((s)) --&gt; y0i_in[ ]     a((a)) --&gt; y0i_in     y0i_in --&gt; y0i[RTL_AND]     y0i --&gt; y0i_out[ ]     b((b)) --&gt; y0i0_in[ ]     y0i0_in --&gt; y0i0[RTL_AND]     y0i0 --&gt; y0i0_out[ ]     y0i_out --&gt; y0i0_in     y0i_out --&gt; y0i0_out     y0i0_out --&gt; y0i[ ]     y0i[ ] --&gt; y0i_out     y0i[ ] --&gt; y0i0_out     y0i0_out --&gt; y0i[ ]     y0i0_out --&gt; y[RTL_OR]     y[RTL_OR] --&gt; y_out[ ]     y_out --&gt; y((y)) </pre> |

|          |                                                                                                                                          |
|----------|------------------------------------------------------------------------------------------------------------------------------------------|
| Code     | <pre> 20 //SHIVAM SALVE VLSI 56 21 module nand_gate (a,b,y); 22 input a, b; 23 output y; 24 assign y = ~(a &amp; b); 25 endmodule </pre> |
| RTL View |                                                                                                                                          |

## EXTRA EXAMPLES TAKEN IN CLASS

|          |                                                                                                                     |
|----------|---------------------------------------------------------------------------------------------------------------------|
| Code     | <pre> 20 //SHIVAM SALVE VLSI 56 21 module test_1(y); 22   output wire y; 23   assign y=1'b1; 24 endmodule 25 </pre> |
| RTL View |                                                                                                                     |

|          |                                                                                                                            |
|----------|----------------------------------------------------------------------------------------------------------------------------|
| Code     | <pre> 20 //SHIVAM SALVE VLSI 56 21 module test_3(y, a); 22   output y; 23   input a; 24   assign y=~a; 25 endmodule </pre> |
| RTL View |                                                                                                                            |

|          |                                                                                                                                                                                                 |
|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Code     | <pre> 20 //SHIVAM SALVE VLSI 56 21 module test_4(p,q,r,s,a,b,c); 22   output p,q,r,s; 23   input a,b,c; 24   assign p=a; 25   assign q=c; 26   assign r=b; 27   assign s=c; 28 endmodule </pre> |
| RTL View |                                                                                                                                                                                                 |

### Design Any Combinational Circuit ( 5 Marks )

```

Code      20 : //SHIVAM SALVE VLSI 56
           21 //DECODER 2TO4
           22 module Dec2to4(a,b,y0,y1,y2,y3);
           23 output y0,y1,y2,y3;
           24 input a,b;
           25 assign y0 = (~a) & (~b);
           26 assign y1 = (~a) & (b);
           27 assign y2 = (a) & (~b);
           28 assign y3 = (a) & (b);
           29 endmodule

```

RTL  
View



## Design combinational design project ( 5 Marks )

|                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|---------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Logic</b>              | <p>Vending Machine with Change<br/>Accepts <b>3 types of coins/currency notes</b>: 10, 20, 50.<br/>Product costs <b>40</b>.<br/>FSM keeps track of balance using states:</p> <ul style="list-style-type: none"> <li>• S10 = balance 10</li> <li>• S20 = balance 20</li> <li>• S30 = balance 30</li> <li>• S40 = balance 40 → Product given (<math>Z=1</math>, no change)</li> <li>• S50, S60, S70, S80 → Product given (<math>Z=1</math>, with change)</li> </ul> <p>After product delivery, FSM goes back to <b>Sin</b>.</p> |
| <b>Gate Level diagram</b> |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

Truth Table

| State | Balance | Z (Product) | Change |
|-------|---------|-------------|--------|
| Sin   | 0       | 0           | 0      |
| S10   | 10      | 0           | 0      |
| S20   | 20      | 0           | 0      |
| S30   | 30      | 0           | 0      |
| S40   | 40      | 1           | 0      |
| S50   | 50      | 1           | 1      |
| S60   | 60      | 1           | 1      |
| S70   | 70      | 1           | 1      |
| S80   | 80      | 1           | 1      |

Kmap And Equations



$$\text{eq: } Z = b_2 \cdot \bar{b}_3 + b_3 \cdot \bar{b}_2 \cdot \bar{b}_1 \cdot b_0$$

K - MAP FOR Change Given (Change)

$$\text{eq: } \text{Change} = \bar{b}_3 \cdot b_2 \cdot b_0 + \bar{b}_3 \cdot b_2 \cdot b_1 + b_3 \cdot \bar{b}_2 \cdot \bar{b}_1 \cdot \bar{b}_0$$

$$\text{Change} = \bar{b}_3 \cdot b_2(b_0 + b_1) + b_3 \cdot \bar{b}_2 \cdot \bar{b}_1 \cdot \bar{b}_0$$

**Code**

```
21 //Shivam Salve VLSI 56 MSPA 1 PROJECT
22 module Vending_machine(
23     input wire clk,
24     input wire reset,
25     input wire [1:0] coin,      // 2-bit coin input
26     output reg Z,           // Product given
27     output reg change_given // Change return
28 );
29
30 parameter Sin  = 4'b0000,    // Initial state
31         S10  = 4'b0001,
32         S20  = 4'b0010,
33         S30  = 4'b0011,
34         S40  = 4'b0100,
35         S50  = 4'b0101,
36         S60  = 4'b0110,
37         S70  = 4'b0111,
38         S80  = 4'b1000;
39
40 parameter ten   = 2'b00,    // 10 Rs coin
41             twenty = 2'b01,    // 20 Rs coin
42             fifty  = 2'b10;    // 50 Rs coin
43
44 req [3:0] state, next state;
45
46 // ----- State Update -----
47 always @(posedge clk or posedge reset) begin
48     if (reset)
49         state <= Sin;
50     else
51         state <= next_state;
52 end
53
54 // ----- Next State Logic -----
55 always @(*) begin
56     case (state)
57         Sin: begin
58             if (coin == ten)      next_state = S10;
59             else if (coin == twenty) next_state = S20;
60             else if (coin == fifty) next_state = S50;
61             else next_state = Sin;
62         end
63
64         S10: begin
65             if (coin == ten)      next_state = S20;
66             else if (coin == twenty) next_state = S30;
67             else if (coin == fifty) next_state = S60;
68             else next_state = S10;
69         end
70
71         S20: begin
72             if (coin == ten)      next_state = S30;
73             else if (coin == twenty) next_state = S40;
74             else if (coin == fifty) next_state = S70;
75             else next_state = S20;
76         end
77
78         S30: begin
79             if (coin == ten)      next_state = S40;
80             else if (coin == twenty) next_state = S50;
81             else if (coin == fifty) next_state = S80;
82             else next_state = S30;
83         end
84
85         S40, S50, S60, S70, S80: next state = Sin;
```

```

86
87         default: next_state = Sin;
88     endcase
89 end
90
91 // ----- Output Logic -----
92 always @(*) begin
93     case (state)
94         Sin, S10, S20, S30: begin
95             Z = 0; change_given = 0;
96         end
97
98         S40: begin
99             Z = 1; change_given = 0; // Product delivered, no change
100        end
101        S50, S60, S70, S80: begin
102            Z = 1; change_given = 1; // Product delivered, change returned
103        end
104
105        default: begin
106            Z = 0; change_given = 0;
107        end
108    endcase
109 end
110
111 endmodule

```

Evaluation by faculty (Dr. P.P. Zode )

| <b>5 Marks</b> | <b>5 Marks</b> | <b>5 Marks</b> | <b>15 Marks</b> |
|----------------|----------------|----------------|-----------------|
|                |                |                |                 |