

```
Half Adder.v
module halfadder(sout,cout,a,b);
output sout,cout;
input a,b;
assign sout=a^b;
assign cout=(a&b);
endmodule
```

Half Adder\_TB.v

```
module halfadder_tb; //test batch  
reg ta, tb;  
wire tcout, tsum;  
halfadder u1 (.a(ta), .b(tb), .cout(tcout), .sum(tsum)); //name  
association
```

initial

initial  
begin

```
ta = 0; tb = 0;  
#10; ta = 0; tb = 1  
#10;  
ta = 1; tb = 0;  
#10;  
ta = 1; tb = 1;  
#10 $stop;
```

| endmodule |   |                  |     |
|-----------|---|------------------|-----|
| Inputs    |   | Outputs          |     |
| A         | B | C <sub>out</sub> | Sum |
| 0         | 0 | 0                | 0   |
| 0         | 1 | 0                | 1   |
| 1         | 0 | 0                | 1   |
| 1         | 1 | 1                | 1   |

Logic Equations



```
Full Adder.v
module fulladder(sout,cout,a,b,cin);
output sout,cout;
input a,b,cin;
assign sout=(a^b^cin);
assign cout=((a&b)|(a&cin)|(b&cin));
endmodule
```

Full Adder TB.v

```
module fulladder_tb;
reg a, b, cin;
wire cout, sum;
fulladder u3(.a(a), .b(b), .cin(cin), .cout(cout), .sum(sum));
initial
begin
```

```

a = 0; b = 0; cin = 0;
#10 a = 0; b = 0; cin = 1;
#10 a = 0; b = 1; cin = 0;
#10; a = 0; b = 1; cin = 1;
#10; a = 1; b = 0; cin = 0;
#10; a = 1; b = 0; cin = 1;
#10; a = 1; b = 1; cin = 0;
#10; a = 1; b = 1; cin = 1;
#10 $stop;

```

```
end  
endmodule
```

| Inputs |   |                 | Outputs          |     |
|--------|---|-----------------|------------------|-----|
| A      | B | C <sub>in</sub> | C <sub>out</sub> | Sum |
| 0      | 0 | 0               | 0                | 0   |
| 0      | 0 | 1               | 0                | 1   |
| 0      | 1 | 0               | 0                | 1   |
| 0      | 1 | 1               | 1                | 0   |
| 1      | 0 | 0               | 0                | 1   |
| 1      | 0 | 1               | 1                | 0   |
| 1      | 1 | 0               | 1                | 0   |

Logic Equations:  
 $\text{Sum} = A \oplus B \oplus C_{in}$   
 $C_{out} = (A \oplus B) C_{in} + A \& B$



```

Multiply4bits.v
module multiply4bits(pro,a,b);
output [7:0]pro;
input [3:0]a;
input [3:0]b;
assign pro[0]=(a[0] & b[0]);
wire x1,x2,x3,x4,x5,x6,x7,x8,x9,x10,x11,x12,x13,x14,x15,x16,x17
halfadder halfadder1{pro[1],x1,[a[1] & b[1]],(a[0] & b[1])};
fulladder fulladder1{x2,x3,a[1]&b[1],(a[0]&b[2]),x1};
fulladder fulladder2{x4,x5,a[1]&b[2],(a[0]&b[3]),x3};
halfadder halfadder2{x6,x7,a[1]&b[3],x5};
halfadder halfadder3{pro[2],x15,x2,(a[2]&b[0])};
fulladder fulladder4{x14,x16,x6,(a[2]&b[1]),x15};
fulladder fulladder4{x13,x17,x6,(a[2]&b[2]),x16};
fulladder fulladder3{x9,x8,x7,(a[2]&b[3]),x17};
halfadder halfadder4{pro[3],x12,x14,(a[3]&b[0])};
fulladder fulladder8{pro[4],x11,x13,(a[3]&b[1]),x12};
fulladder fulladder7{pro[5],x10,x9,(a[3]&b[2]),x11};
fulladder fulladder6{pro[6],x7,x8,(a[3]&b[3]),x10};
endmodule

Multiply4bits_TB.v
module multiply4bits_tb();
reg [3:0]a;
reg [3:0]b;
wire [7:0]pro;
multiply4bits u1(.a(a), .b(b), .pro(pro));
initial
begin
    a = 4'b0000; b = 4'b0000;
    #10;
    a = 4'b0001; b = 4'b0001;
    #10;
    a = 4'b0010; b = 4'b0010;
    #10;
    a = 4'b0011; b = 4'b0011;
    #10;
    a = 4'b0100; b = 4'b0100;
    #10;
    a = 4'b0101; b = 4'b0101;
    #10;
    a = 4'b0110; b = 4'b0110;
    #10;
    a = 4'b0111; b = 4'b0111;
    #10;
    a = 4'b1000; b = 4'b1000;
    #10;
    a = 4'b1001; b = 4'b1001;
    #10;
    a = 4'b1010; b = 4'b1010;
    #10;
    a = 4'b1011; b = 4'b1011;
    #10;
    a = 4'b1100; b = 4'b1100;
    #10;
    a = 4'b1101; b = 4'b1101;
    #10;
    a = 4'b1110; b = 4'b1110;
    #10;
    a = 4'b1111; b = 4'b1111;
    #10; $stop;

```

| Inputs |        | Outputs   |
|--------|--------|-----------|
| A[3:0] | B[3:0] | Prod[7:0] |
| 0000   | 0000   | 00000000  |
| 0001   | 0001   | 00000001  |
| 0010   | 0010   | 00000100  |
| 0011   | 0011   | 00001001  |
| 0100   | 0100   | 00010000  |
| 0101   | 0101   | 00011001  |
| 0110   | 0110   | 00110000  |
| 0111   | 0111   | 00110001  |
| 1000   | 1000   | 01000000  |
| 1001   | 1001   | 01010001  |
| 1010   | 1010   | 01100100  |
| 1011   | 1011   | 01110101  |
| 1100   | 1100   | 10010000  |
| 1101   | 1101   | 10101001  |
| 1110   | 1110   | 11000100  |
| 1111   | 1111   | 11100001  |

Use Verilog to design a finite state machine to recognize the sequence 0110.

### **Analysis:**

S\_idle: does not detect anything

### S1: detect 0

S2: detect 01

### 34. Delete C

| Current State     | A | Next state        | Y |
|-------------------|---|-------------------|---|
| S <sub>idle</sub> | 0 | S <sub>1</sub>    | 0 |
|                   | 1 | S <sub>idle</sub> | 0 |
| S <sub>1</sub>    | 0 | S <sub>1</sub>    | 0 |
|                   | 1 | S <sub>2</sub>    | 0 |
| S <sub>2</sub>    | 0 | S <sub>1</sub>    | 0 |
|                   | 1 | S <sub>3</sub>    | 0 |
| S <sub>3</sub>    | 0 | S <sub>4</sub>    | 1 |
|                   | 1 | S <sub>idle</sub> | 0 |
| S <sub>4</sub>    | 0 | S <sub>1</sub>    | 0 |
|                   | 1 | S <sub>2</sub>    | 0 |

## Final Solution State Diagram



```

module fsm_detector(reset, clk, a, y);
input reset, a, clk;
output y;
reg y;
parameter s_0idle = 3'b000, s1=3'b001, s2=3'b010, s3=3'b011, s4=3'b100;
reg [2:0] cs, ns;
always@ (posedge clk or posedge reset)
begin
    if(reset) cs <= s_0idle;
    else cs <= ns;
end
always@ (cs or a)
begin
    case(cs)
        s_0idle: if(a) ns = s_0idle;
        else ns = s1;
        s1: if(a) ns = s2;
        else ns = s1;
        s2: if(a) ns = s3;
        else ns = s1;
        s3: if(~a) ns = s4;
        else ns = s_0idle;
        s4: if(a) ns = s2;
        else ns = s1;
        default: ns = s_0idle;
    endcase
end
always@ (cs or a)
begin
    case(cs)
        s_0idle: y = 0;
        s1: y=0;
        s2: y=0;
        s3: if(~a)=y=1;
        else y=0;
        s4: y=0;
        default: y = 0;
    endcase
end
endmodule

```

```

D-Flip-Flop
module dffa #( reset, clk, load, da, qa);
input reset, clk, load;
input [3:0] da;
output [3:0] qa;
reg [3:0] qa;
always@(posedge clk or posedge reset)
begin
    if (reset)
        qa <= 4'b0000;
    else if (load)
        qa <= da;
end
endmodule
`timescale 1ns / 1ps
module dffa_tb;
    // Inputs
    reg reset;
    reg clk;
    reg load;
    reg [3:0] da;
    // Outputs
    wire [3:0] qa;
    // Instantiate the Unit Under Test (UUT)
    dffa uut (
        .reset(reset),
        .clk(clk),
        .load(load),
        .da(da),
        .qa(qa));

```

```

    );
//continuous 20 sec clk
always
begin
    clk = 1'b1;
#10;
    clk = 1'b0;
#10;
end
initial begin
    // Initialize Inputs
    load = 1'b1;
    da = 1'b1;
    reset = 1'b0;
#20;
    load = 1'b0;
    da = 1'b0;
    reset = 1'b1;
#20;
    load = 1'b0;
    da = 1'b0;
    reset = 1'b0;
#20;
    load = 1'b0;
    da = 1'b1;
    reset = 1'b1;
#20;
    load = 1'b1;
    da = 1'b1;
    reset = 1'b0;
#20
// Wait 100 ns for global reset to finish
$stop;
// Add stimulus here
end
endmodule

```

Complete the waveform for the hardware design below

```
assign temp1 = a & b;
assign c = temp1;
assign d = a | b;
always@(posedge clk)
begin
  <<=d;
end
Solution:
```



Write Verilog Program & TB for this circuit.



```
module program (clk, d, rst, y0);
input clk, d, rst;
output y;
wire m;
assign m = d & (~y);
always@ (posedge clk or negedge rst)
begin
  if(~rst)
    begin
      n <= 0; y <= 0;
    end
  else
    begin
      n <= m; y <= n;
    end
end
endmodule
```

```
module program_tb;
reg clk, d, rst;
wire y;
program uut(clk, d, rst, y);
initial clk = 0;
always #10 clk = ~clk;
initial
begin
  rst = 0; d = 0;
  #16 rst = 1;
  #10 d = 1;
  #30 d = 0;
  #200 $stop;
end
endmodule
```



Describe the following circuit in Verilog.



```
module decoder (e1, e2, e3, a, b, c, y);
input a, b, c, e1, e2, e3;
output [7:0] y;
wire m;
assign m = ~e1 & e2 & e3;
assign y[0] = ~((~c & ~b & ~a) & m);
```

```
assign y[1] = ~((c & ~b & a) & m);
assign y[2] = ~((~c & b & ~a) & m);
assign y[3] = ~((c & b & a) & m);
assign y[4] = ~((c & ~b & ~a) & m);
assign y[5] = ~((c & b & ~a) & m);
assign y[6] = ~((c & b & a) & m);
assign y[7] = ~((c & b & a) & m);
endmodule
```

```
/////////////////////////////
```

```
module decoder_tb;
```

```
reg e1, e2, e3, a, b, c;
wire [7:0] y;
```

```
decoder uut(e1, e2, e3, a, b, c, y);
```

```
initial
```

```
begin
```

```
  {e1, e2, e3} = 3'b111;
```

```
  {c, b, a} = 3,b111;
```

```
  #10 {e1, e2, e3} = 3'b011;
```

```
  {c, b, a} = 3'b000;
```

```
  #10 {c, b, a} = 3'b001;
```

```
  #10 {c, b, a} = 3'b010;
```

```
  #10 {c, b, a} = 3'b011;
```

```
  #10 {c, b, a} = 3'b100;
```

```
  #10 {c, b, a} = 3'b101;
```

```
  #10 {c, b, a} = 3'b110;
```

```
  #10 {c, b, a} = 3'b111;
```

```
  #50 $stop;
```

```
end
```

```
endmodule
```



Design 3-bit Ripple Carry Adder

```
module fulladder(a, b, cin, cout, s);
input a, b, cin;
output cout, s;
assign s = a ^ b ^ cin;
assign cout = ((a&b)&cin) | (a&b);
endmodule
```

```
/////////////////////////////
```

```
module ripplecarryadder3(a, b, cin, cout, s);
input [2:0] a, b;
input cin;
output [2:0] s;
output cout;
wire [1:0] m;
fulladder g1.a(a[0]), .b(b[0]), .cin(cin), .cout(m[0]), .s(s[0]);
fulladder g2.a(a[1]), .b(b[1]), .cin(m[0]), .cout(m[1]), .s(s[1]);
fulladder g3.a(a[2], b[2], m[1], cout, s[2]);
endmodule
```

```
/////////////////////////////
```

```
module ripplecarryadder3_tb;
reg [2:0] a, b;
reg cin;
wire [2:0] s;
wire cout;
ripplecarryadder3 uut(a, b, cin, cout, s);
initial
begin
```

```
  a = 0; b = 0; c = 0;
```

```
  #10 a = 4; b = 5;
```

```
  #10 a = 6; b = 6;
```

```
  #10 a = 0; b = 2; cin = 1;
```

```
  #10 a = 3; b = 3;
```

```
  #10 a = 5; b = 2;
```

```
  #20 $stop;
```

```
end
```

```
endmodule
```



Design 4-bit left shift registers in Verilog with serial data input and serial data output.

```
module shift_L4(clk, din, dout);
input clk, din; output dout;
reg [3:0] q; assign dout = q[3];
always@(posedge clk)
begin
  //q <= {q[2:0], din };
  q[3] <= q[2];
  q[2]<= q[1];
  q[1]<= q[0];
  q[0] <= din;
end
endmodule
```

//Right shift//

```
module shift_R4(clk, din, dout);
input clk, din;
output dout;
reg [3:0] q;
assign dout = q[0];
always@(posedge clk)
begin
  q <= { din, q[3:1] };
end
endmodule
```

Design the following finite state machine (mealy)



```
module fsm(clk, reset, a, y);
```

```
input clk, reset, a;
```

```
output y; reg y;
```

```
parameter s0 = 2'b00, s1=2'b01, s2=2'b10;
```

```
reg [1:0] cs, ns;
```

```
always@ (posedge clk or posedge reset)
```

```
begin
```

```
  if(reset) cs <= s0;
```

```
  else cs <= ns;
```

```
end
```

```
always@ (cs or a)
```

```
begin
```

```
  case(cs) s0: if(a) ns = s1;
```

```
  else ns = s0; s1: if(~a) ns = s2;
```

```
  else ns = s0; s2: if(a) ns = s2;
```

```
  else ns = s1; default: ns = s0;
```

```
endcase
```

```
end
```

```
always@ (cs or a)
```

```
begin
```

```
  case(cs) s0: y = 0;
```

```
  s1: if(a) y = 1; else y = 0;
```

```
  s2: y = 1;
```

```
  default: y = 0;
```

```
endcase
```

```
end
```

```
endmodule
```

Design the following finite state machine (moore)



```
module fsm ( clk, reset, a, y );
```

```
input clk, reset, a;
```

```
output [1:0] y;
```

```
reg [1:0] y;
```

```
parameter s0 = 3'b000, s1=3'b001, s2=3'b010, s3=3'b011,
```

```
s4=3'b100; reg [2:0] cs, ns;
```

```
always@ (posedge clk or negedge reset)
```

```
begin
```

```
  if(~reset) cs <= s0;
```

```
  else cs <= ns;
```

```
end
```

```
always@ (cs or a)
```

```
begin
```

```
  case(cs) s0: if(a) ns = s1;
```

```
  else ns = s0; s1: if(~a) ns = s2;
```

```
  else ns = s0; s2: if(a) ns = s3;
```

```
  else ns = s0; s3: if(a) ns = s4;
```

```
  else ns = s2; s4: if(a) ns = s1;
```

```
  else default:
```

```
endcase
```

```
end
```

```
always@ (cs)
```

```
begin
```

```
  ns = s2; ns = s0;
```

```
  case(cs)
```

```
  s0: y = 2'b00;
```

```
  s1: y = 2'b11;
```

```
  s2: y = 2'b01;
```

```
  s3: y = 2'b11;
```

```
  s4: y = 2'b10;
```

```
  default: y = 2'b00;
```

```
endcase
```

```
end
```

```
endmodule
```

Design the following finite state machine (moore)

|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <pre>process(a, b, sel) begin   if (sel = '1')   then     c &lt;= a;   else     c &lt;= b;   end if; end process;</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | <p><b>Draw the synthesized schematic for the VHDL code.</b></p> <p><b>Solution:</b></p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | <pre>process(clock) begin   if (rising_edge(clock))   then     if(sel = '1') then       c &lt;= a;     else       c &lt;= b;     end if;   end if; end process;</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | <p><b>Draw the synthesized schematic for the VHDL code.</b></p> <p><b>Solution:</b></p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | <p><b>Left Shift Register</b></p> <pre>library IEEE; use IEEE.STD_LOGIC_1164.ALL; use IEEE.STD.LOGIC_UNSIGNED.ALL; use IEEE.STD.LOGIC_ARITH.ALL; entity leftshiftregister is   Port (clk : STD_LOGIC;         rst : STD_LOGIC;         random_sequence : out STD_LOGIC_VECTOR (3 downto 0)); end leftshiftregister; architecture Behavioral of leftshiftregister is begin   signal d1f: std_logic;   signal d2f: std_logic;   signal d3f: std_logic;   signal d4f: std_logic;   begin     process(clk, rst)     begin       if(rst = '1') then         d1f &lt;= '1';         d2f &lt;= '0';         d3f &lt;= '1';         d4f &lt;= '1';       elsif rising_edge(clk) then         d4f &lt;= d3f;         d3f &lt;= d2f;         d2f &lt;= d1f xor d4f;         d1f &lt;= d4f;       end if;     end process;     random_sequence &lt;= (df4, df3, df2, df1);   end Behavioral;</pre> |
| <pre>process (a , b , sel) begin   case (sel) is     when '0'=&gt; c &lt;= ~b;     when '1' =&gt; c &lt;= a;   end case; end process;</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | <p><b>Draw the synthesized schematic for the VHDL code.</b></p> <p><b>Solution:</b></p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | <pre>process (clock ) begin   if (rising_edge(clock))   then     m1 &lt;= din;     m2 &lt;= m1;     m3 &lt;= m2;   end if; end process;</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | <p><b>Draw the synthesized schematic for the VHDL code.</b></p> <p><b>Solution:</b></p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | <p><b>8-bit Shift-Left Register with Positive-Edge Clock, Asynchronous Parallel Load, Serial In, and Parallel Out</b></p> <pre>library ieee; use ieee.std_logic_1164.all; entity shift_left_register is   port(     C, SI, ALOAD : in std_logic;     D : in std_logic_vector(7 downto 0);     PO : out std_logic_vector(7 downto 0)); end shift_left_register; architecture archi of shift_left_register is   signal tmp: std_logic_vector(7 downto 0); begin   begin     if(ALOAD='1') then       tmp &lt;= SI;     elsif(C'event and C='1') then       tmp &lt;= tmp(6 downto 0) &amp; SI;     end if;     process;       begin         PO &lt;= tmp;       end process;   end; end architecture;</pre>                                                                                                                                                                               |
| <pre>process ((sl , s0 , a , b , c) begin   if (sl ='1') then     d &lt;= a;   elsif(s0 ='0') then     d &lt;= b;   else     d &lt;= c;   end if; end process;</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | <p><b>Draw the synthesized schematic for the VHDL code.</b></p> <p><b>Solution:</b></p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | <p><b>Test bench for Left shift Register</b></p> <pre>LIBRARY ieee; USE ieee.std_logic_1164.ALL; ENTITY leftshiftregister_tb IS END leftshiftregister_tb; ARCHITECTURE behavior OF leftshiftregister_tb IS -- Component Declaration for the Unit Under Test (UUT) COMPONENT leftshiftregister PORT(   clk : IN std_logic;   rst : IN std_logic;   random_sequence : OUT std_logic_vector(3 downto 0)   ); END COMPONENT; --Inputs signal clk : std_logic := '0'; signal rst : std_logic := '0'; --Outputs signal random_sequence : std_logic_vector(3 downto 0); -- Clock period definitions constant clk_period : time := 65 ns; BEGIN   -- Instantiate the Unit Under Test (UUT)   uut:leftshiftregister PORT MAP (     clk=&gt;clk,     rst=&gt;rst,     random_sequence=&gt;random_sequence     );   -- Clock process definitions   clk_process:process   begin     clk &lt;='0';     wait for clk_period/2;     clk &lt;='1';     wait for clk_period/2;   end process;   -- Stimulus process   stim_proc:process   begin     -- hold reset state for 100 ns.     rst &lt;='1';     wait for clk_period/2;     rst &lt;='0';     wait for clk_period/2;     -- wait for clk_period*10;     -- insert stimulus here     wait;   end process;   BEGIN     -- Instantiate the Unit Under Test (UUT)     uut:leftshiftregister PORT MAP (       clk=&gt;clk,       rst=&gt;rst,       random_sequence=&gt;random_sequence       );     -- Clock process definitions     clk_process:process     begin       clk &lt;='0';       wait for clk_period/2;       clk &lt;='1';       wait for clk_period/2;     end process;     -- Stimulus process     stim_proc:process     begin       -- hold reset state for 100 ns.       rst &lt;='1';       wait for clk_period/2;       rst &lt;='0';       wait for clk_period/2;       -- wait for clk_period*10;       -- insert stimulus here       wait;     end process;   END;</pre> | <p><b>Hamming code Test Bench</b></p> <pre>LIBRARY ieee; USE ieee.std_logic_1164.ALL; -- Uncomment the following library declaration if using -- arithmetic functions with Signed or Unsigned values --USE ieee.numeric_std.ALL; ENTITY parity_generator_tb IS END parity_generator_tb; ARCHITECTURE behavior OF parity_generator_tb IS -- Component Declaration for the Unit Under Test (UUT) COMPONENT Parity_Generator PORT(   d4 : IN std_logic;   d3 : IN std_logic;   d2 : IN std_logic;   d1 : IN std_logic;   Ham_code : OUT std_logic_vector(6 downto 0)   ); END COMPONENT; --Inputs signal clk : std_logic := '0'; signal d4 : std_logic := '1'; signal d3 : std_logic := '0'; signal d2 : std_logic := '1'; signal d1 : std_logic := '1'; --Outputs signal Ham_code : std_logic_vector(6 downto 0); -- Clock period definitions constant clock_period : time := 10 ns; BEGIN   -- Instantiate the Unit Under Test (UUT)   uut:Parity_Generator PORT MAP (     d4=&gt;d4,     d3=&gt;d3,     d2=&gt;d2,     d1=&gt;d1,     Ham_code=&gt;Ham_code     );   -- Clock process definitions   clock_process:process   begin     clk &lt;='0';     wait for clock_period/2;     clk &lt;='1';     wait for clock_period/2;   end process;   -- Stimulus process   stim_proc:process   begin     -- hold reset state for 100 ns.     wait for 100 ns;     -- insert stimulus here     wait;   end process;   BEGIN     -- Instantiate the Unit Under Test (UUT)     uut:Parity_Generator PORT MAP (       d4=&gt;d4,       d3=&gt;d3,       d2=&gt;d2,       d1=&gt;d1,       Ham_code=&gt;Ham_code       );     -- Clock process definitions     clock_process:process     begin       clk &lt;='0';       wait for clock_period/2;       clk &lt;='1';       wait for clock_period/2;     end process;     -- Stimulus process     stim_proc:process     begin       -- hold reset state for 100 ns.       wait for 100 ns;       -- insert stimulus here       wait;     end process;   END;</pre> | <p><b>8-bit Shift-Left Register with Negative-Edge Clock, Clock Enable, Serial In, and Serial Out</b></p> <pre>library ieee; use ieee.std_logic_1164.all; entity shift_left_register is   port(     C, SI, CE : in std_logic;     SO : out std_logic     ); end shift_left_register; architecture archi of shift_left_register is   signal tmp: std_logic_vector(7 downto 0); begin   begin     if(C'event and C='0') then       if(CE='1') then         for i in 0 to 6 loop           tmp(i+1) &lt;= tmp(i);         end loop;         tmp(0) &lt;= SI;       end if;     end if;     process;       begin         SO &lt;= tmp;       end process;   end; end architecture;</pre>                                                                                                                                                                                                    |
| <p><b>Counter</b></p> <pre>library ieee; use ieee.std_logic_1164.all; use ieee.std_logic_unsigned.all; entity new_cnt is   port(osc:in std_logic; -- 50MHz        load,updown:in std_logic;        sw:in std_logic_vector(3 downto 0);        dout:out std_logic_vector(3 downto 0);        clkref:out std_logic       ); end; begin   new_cnt:process(osc)   begin     if(rising_edge(osc)) then       if(cnt10 = 9) then         cnt10 &lt;= (others =&gt; '0');         clk &lt;='1';       elsif(cnt10 &lt; 4) then         cnt10 &lt;= cnt10 + 1;         clk &lt;='1';       else         cnt10 &lt;= cnt10 + 1;         clk &lt;='0';       end if;     end if;     process(clk,load,updown)     begin       if(rising_edge(clk)) then         if(load = '1') then           cnt &lt;= sw;         else           if(updown = '1') then             if(cnt = 9) then               cnt &lt;= "0000";             else               cnt &lt;= cnt + 1;             end if;           else             if(cnt = 0) then               cnt &lt;= "1001";             else               cnt &lt;= cnt - 1;             end if;           end if;         end if;         if(cnt &lt;= cnt_be);       end if;     end process;   end; end;</pre> | <p><b>Finite State Machine</b></p> <pre>library IEEE; use IEEE.std_logic_1164.all; entity fsm is port (   clk,reset,x1 : IN std_logic;   outp : OUT std_logic   ); END fsm; architecture beh1 of fsm is type state_type is (s1,s2,s3,s4); signal state,next_state:state_type; begin   state&lt;=next_state;   state_type; begin   process(x1,reset) begin   if(reset='1') then     state&lt;=s1;   elsif(x1='1' and clk'event) then     state&lt;=s4;   end if;   end process;   -- Stimulus process   stim_proc:process   begin     -- hold reset state for 100 ns.     wait for 100 ns;     -- insert stimulus here     wait;   end process;   BEGIN     -- Instantiate the Unit Under Test (UUT)     uut:fsm PORT MAP (       clk=&gt;clk,       reset=&gt;reset,       x1=&gt;x1,       outp=&gt;outp       );     -- Clock process definitions     clk_process:process     begin       clk &lt;='0';       wait for clk_period/2;       clk &lt;='1';       wait for clk_period/2;     end process;     -- Stimulus process     stim_proc:process     begin       -- hold reset state for 100 ns.       wait for 100 ns;       -- insert stimulus here       wait;     end process;   END;</pre> | <p><b>Asynchronous Reset is used in this example:</b></p> <p><b>Hamming code</b></p> <p><b>Hamming code Test Bench</b></p> <pre>library ieee; use ieee.std_logic_1164.all; entity hamming_code is   port(     d4 : IN std_logic;     d3 : IN std_logic;     d2 : IN std_logic;     d1 : IN std_logic;     Ham_code : OUT std_logic_vector(6 downto 0)     ); END hamming_code; architecture archi of hamming_code is begin   begin     if(C'event and C='0') then       if(CE='1') then         for i in 0 to 6 loop           tmp(i+1) &lt;= tmp(i);         end loop;         tmp(0) &lt;= SI;       end if;     end if;     process;       begin         Ham_code &lt;= tmp;       end process;   end; end architecture;</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | <p><b>Flip-flop with Positive-Edge Clock</b></p> <pre>library ieee; use ieee.std_logic_1164.all; entity flop is   port(     CLK, D : in std_logic;     Q : out std_logic     ); end flop; architecture archi of flop is begin   begin     if(CLK'event and CLK='1') then       if(rising_edge(CLK)) then         if(D='1') then           Q &lt;= D;         end if;       end if;     end if;     process;       begin         Q &lt;= D;       end process;   end; end architecture;</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | <p><b>Flip-flop with Negative-Edge Clock and Asynchronous Clear</b></p> <pre>library ieee; use ieee.std_logic_1164.all; entity flop is   port(     CLK, D, CLR : in std_logic;     Q : out std_logic     ); end flop; architecture archi of flop is begin   begin     if(CLK'event and CLK='0') then       if(falling_edge(CLK)) then         if(CLR='1') then           Q &lt;= '0';         elsif(C'event and C='0') then           if(D='1') then             Q &lt;= D;           end if;         end if;       end if;     end if;     process;       begin         Q &lt;= D;       end process;   end; end architecture;</pre>                                                                                                                                                                                                                                                   |



Complete the following waveform:

#### Testbench Solution:

```
Library ieee;
Use ieee.std_logic_1164.all;
entity prob1_tb
end prob1_tb;
architecture beh of prob1_tb is
component prob1 (a, b, reset: in std_logic;
q1, q2: out std_logic);
end component;
signal a, b, reset: std_logic;
signal q1, q2: std_logic;
begin
a: std_logic := '1';
begin
ut: prob1 port map(a, b, reset, q1, q2);
process
begin
reset <= '1';
wait for 5 ns;
reset <= '0';
wait for 100 ns;
wait;
end process;
b <= not a;
process
begin
a <= '1';
wait for 10 ns;
a <= '0';
wait for 5 ns;
a <= '1';
wait for 5 ns;
a <= '0';
wait for 5 ns;
a <= '1';
process
begin
clk <= a nand m;
m <= b nand clk;
d1 <= not t2;
process (clk, reset)
begin
if (reset='1') then
t1 <= '0';
elsif(rising_edge(clk)) then
t1 <= d1;
end if;
end process;
process (clk, reset)
begin
if (reset='1') then
t2 <= '0';
elsif(rising_edge(clk)) then
t2 <= t1;
end if;
end process;
q1 <= t1;
q2 <= t2;
end circuit;
```

#### Complete VHDL Design:

You are not allowed to use hierarchical design method in this question.

#### Solution:

```
Library ieee;
Use ieee.std_logic_1164.all;
entity prob1 (
a, b, reset: in std_logic;
q1, q2: out std_logic);
end prob1;
architecture circuit of prob1 is
signal clk, m, d1, t1, t2: std_logic;
begin
clk <= a nand m;
m <= b nand clk;
d1 <= not t2;
process (clk, reset)
begin
if (reset='1') then
t1 <= '0';
elsif(rising_edge(clk)) then
t1 <= d1;
end if;
end process;
process (clk, reset)
begin
if (reset='1') then
t2 <= '0';
elsif(rising_edge(clk)) then
t2 <= t1;
end if;
end process;
q1 <= t1;
q2 <= t2;
end circuit;
```



```
library ieee;
Use ieee.std_logic_1164.all;
entity prob2_fsm (w, Reset, Clk: in std_logic;
M, N: out std_logic);
End prob2_fsm;
Architecture beh of prob2_fsm is
type st is ( SA, SB, SC );
signal cs, ns: st;
begin
```

process (w, cs)

```
begin
case (cs) is
when SA=> if(w='0') then
ns <= SA;
else
ns <= SB;
end if;
when SB=> if(w='0') then
ns <= SA;
else
ns <= SC;
end if;
```

```
when SC=> if(w='0') then
ns <= SA;
else
ns <= SC;
end if;
```

```
when others=> ns <= SA;
```

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

```
process (Clk, Reset)
```

```
begin
if(Reset='1') then
```

```
cs <= SA;
elsif(rising_edge(Clk)) then
```

```
cs <= ns;
```

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

```
M <= '1' when (cs=SC) else '0';
N <= w when (cs=SB) else '0';
end beh;
```



#### CRC Error Detection

Message 110101

Generating Polynomial = 101



Message with CRC = 11010111

#### Clock Division

```
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
use IEEE.STD_LOGIC_UNSIGNED.ALL;
use IEEE.STD_LOGIC_ARITH.ALL;
entity clkdiv is
Port (clk : in STD_LOGIC;
rst : in STD_LOGIC;
clk2 : out STD_LOGIC);
end clkdiv;
architecture Behavioral of clkdiv is
signal cnt_div: std_logic_vector (26 downto 0);
begin
process (clk, rst)
begin
if(rst='1') then
cnt_div <= (others=>'0');
clk2 <= '0';
elsif(rising_edge(clk)) then
if(cnt_div=49999999) then
cnt_div <= (others=>'0');
clk2 <= '1';
elsif(cnt_div<24999999) then
cnt_div <= cnt_div + 1;
clk2 <= '1';
else
cnt_div <= cnt_div + 1;
clk2 <= '0';
end if;
end if;
end process;
end Behavioral;
```

#### Hamming Code

```
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
use IEEE.STD_LOGIC_UNSIGNED.ALL;
use IEEE.STD_LOGIC_ARITH.ALL;
entity Parity_Generator is
Port (d4 : in STD_LOGIC;
d3 : in STD_LOGIC;
d2 : in STD_LOGIC;
d1 : in STD_LOGIC;
Ham_code: out STD_LOGIC_VECTOR (6 downto 0);
end Parity_Generator;
architecture Behavioral of Parity_Generator is
signal p1: std_logic;
signal p2: std_logic;
signal p3: std_logic;
begin
p3 <= d4 xor d3 xor d2;
p2 <= d4 xor d3 xor d1;
p1 <= d4 xor d2 xor d1;
Ham_code <= (d4, d3, d2, p3, d1, p2, p1);
end Behavioral;
```

| Data<br>D1,D2,D3,D4 | Hamming(7,4)                        |  |  |  | Diagram |
|---------------------|-------------------------------------|--|--|--|---------|
|                     | Transmitted<br>P1,P2,D1,P3,D2,D3,D4 |  |  |  |         |
| 0000                | 0000000                             |  |  |  |         |
| 1000                | 1110000                             |  |  |  |         |
| 0100                | 1001100                             |  |  |  |         |
| 1100                | 0111100                             |  |  |  |         |
| 0010                | 0101010                             |  |  |  |         |
| 1010                | 1011010                             |  |  |  |         |
| 0110                | 1100110                             |  |  |  |         |
| 1110                | 0010110                             |  |  |  |         |
| 0001                | 1101001                             |  |  |  |         |
| 1001                | 0011001                             |  |  |  |         |
| 0101                | 0100101                             |  |  |  |         |
| 1101                | 1010101                             |  |  |  |         |
| 0011                | 1000011                             |  |  |  |         |
| 1011                | 0110011                             |  |  |  |         |
| 0111                | 0001111                             |  |  |  |         |
| 1111                | 1111111                             |  |  |  |         |

1. [28 points] Fill out the blanks shown below.

- [1]. Given the following VHDL statement,  
 $\text{rst} \leq '0', '1' \text{ after } 100 \text{ ns}, '0' \text{ after } 200 \text{ ns};$   
 rst is    at time zero,    at time 50 ns,    at time 100 ns;  
   at time 150 ns,    at time 200 ns,    at time 300 ns;

- [2]. Each of the D2, D1, D0 signals is std\_logic type,  
 signal D2, D1, D0: std\_logic;  
 signal D3: std\_logic\_vector(2 downto 1);

Given the following codes:

```
D2 <= '0'; D1 <= '1'; D0 <= '1';
D3 <= (D2 xor D1) & (D1 nor D0);
```

What is binary value for D3?

D3       10

- [3]. (7,4) hamming code construction diagram is shown below.

If d4 d3 d2 d1 = "1100", the constructed 7-bit hamming code is:

Bit 7:    Bit 6:    Bit 5:    Bit 4:    Bit 3:    Bit 2:    Bit 1:   



2. [32 points]

Design the following circuit in VHDL. This circuit is required to be loaded with value Q4 Q3 Q2 Q1 = "1100" if the asynchronous reset control signal is logic '1'.



```
library ieee;
use ieee.std_logic_1164.all;
entity flop is port(
    CLK, reset : in std_logic;
    Q4, Q3, Q2, Q1 : out std_logic);
end flop;
architecture archi of flop is
begin
    process (CLK, reset)
    begin
        if (reset = '1') then
            Q4 <= '1';
            Q3 <= '1';
            Q2 <= '0';
            Q1 <= '0';
        else
            if (rising_edge(CLK)) then
                t1 <= t2;
                t2 <= t3 xor t1;
                t3 <= t4;
                t4 <= t1;
            end if;
        end if;
    end process;
end;
```

- (2). Design VHDL testbench for the above circuit.

```
library ieee;
use ieee.std_logic_1164.all;
entity flop_tb is
begin
    process
        variable Q4, Q3, Q2, Q1 : std_logic;
        signal CLK, D, reset : std_logic;
        begin
            CLK <= '0';
            D <= '0';
            reset <= '1';
            wait for 5ns;
            reset <= '0';
            wait for 5ns;
            CLK <= '1';
            wait for 5ns;
            CLK <= '0';
            wait for 5ns;
            report "MISSING CLK" severity error;
            end process;
    end;
```

MISSING CLK X

3

- (3). The above circuits are preloaded with value Q4Q3Q2Q1 = "1100".

What are the output values after two clock cycles and reset signal is logic '0'?

Your answer: Q4 =   , Q3 =   , Q2 =   , Q1 =   .

3. [16 points] Draw the synthesized schematic for the VHDL code.

signal a, b, c, d, sel: std\_logic;

...

```
process (a, b, c, d, sel)
begin
    case (sel) is
        when '0' => y <= a or b;
        when '1' => y <= c and d;
    end case;
end process;
```

Draw the synthesized schematic for the VHDL code.

Solution:



signal a, b, c: std\_logic;
signal f1, f2, f3;

...

f1 <= a nand b;

```
process (clock)
begin
    if (rising_edge(clock)) then
        if (s = '1') then
            f2 <= f1;
        else
            f2 <= not c;
        end if;
        f3 <= f2;
    end if;
end process;
```

Draw the synthesized schematic for the VHDL code.

Solution:



4. [24 points] Draw ASM Chart for the finite state machine and complete the waveform.

|                              |  |
|------------------------------|--|
| Library ieee;                |  |
| Use ieee.std_logic_1164.all; |  |
| entity asm_chart (           |  |
| a, reset, clk: in std_logic; |  |
| y: out std_logic);           |  |
| end asm_chart;               |  |

|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                               |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <pre> architecture beh of fsm_chart is type st is (S1, S2, S3, S4); signal cs, ns, st; begin process (x, cs) begin case (x) is when S1=&gt; if (a = '0') then     ns &lt;= S2;     y &lt;= '0'; else     ns &lt;= S4;     y &lt;= '1'; end if; when S2=&gt; if (a = '0') then     ns &lt;= S4;     y &lt;= '1'; else     ns &lt;= S3;     y &lt;= '0'; end if; when S3=&gt; if (a = '0') then     ns &lt;= S1;     y &lt;= '0'; else     ns &lt;= S2;     y &lt;= '1'; end if; when S4=&gt; if (a = '0') then     ns &lt;= S1;     y &lt;= '1'; else     ns &lt;= S2;     y &lt;= '0'; end if; when others=&gt; ns &lt;= S4;     y &lt;= '0'; end case; end process;  process ( clk, reset) begin if( reset = '1') then     cs &lt;= S1; elsif (rising_edge(clk)) then     cs &lt;= ns; end if; end process; end beh; </pre> | <p>1. Draw ASM Chart for the finite state machine.</p> <p>Your Solution:</p> <p>MISSING → 3</p> <p>2. Complete the following waveform for signals cs, ns, y.</p> <p>1 / 7</p> |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

## //BlockRAM Memory

```
library ieee;
use ieee.std_logic_1164.all;
use ieee.std_logic_unsigned.all;
use ieee.std_logic_arith.all;

entity ram is
port (
    address :in std_logic_vector ( 3 downto 0 );
    data : inout std_logic_vector ( 7 downto 0 );
    cs :in std_logic;
    we :in std_logic;
    oe :in std_logic );
end ram;
```

## architecture beh\_ram of ram is

```
type memory is array (0 to 15)of std_logic_vector (7 downto 0);
signal mem : memory ;
begin
-- Memory Write Block
process (address, data, cs, we)
begin
    if (cs = '1' and we = '1') then
        mem(conv_integer(address)) <= data;
    end if;
end process;
-- Memory Read Block
process (address, cs, we, oe, mem)
begin
    if (cs = '1' and we = '0' and oe = '1') then
        data <= mem(conv_integer(address));
    else
        data <= (others => 'Z');
    end if;
end process;
end beh_ram;
```

## //555Timer



Figure 1 shows the 555 Timer chip is connected with two external resistors R1, R2 and one external capacitor C. The output voltage Vout oscillates between 0.3 Vcc and 2.7 Vcc and the output waveform Vout oscillates between logic 0 and logic 1.



Figure 2 illustrates Vout and its waveform of the output voltage Vout.

## //SRAM

| Pin Configuration                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Pin Description | Truth Table |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-------------|
| A0-A12<br>AD1-A2<br>AD2-D27<br>AD3-D28<br>AD4-D29<br>AD5-D30<br>AD6-D31<br>AD7-D32<br>AD8-D33<br>AD9-D34<br>AD10-D35<br>AD11-D36<br>AD12-D37<br>DQ1-D12<br>DQ15-D24<br>DQ16-D25<br>DQ17-D26<br>DQ18-D27<br>DQ19-D28<br>DQ20-D29<br>DQ21-D30<br>DQ22-D31<br>DQ23-D32<br>DQ24-D33<br>DQ25-D34<br>DQ26-D35<br>DQ27-D36<br>DQ28-D37<br>DQ29-D38<br>DQ30-D39<br>DQ31-D40<br>DQ32-D41<br>DQ33-D42<br>DQ34-D43<br>DQ35-D44<br>DQ36-D45<br>DQ37-D46<br>DQ38-D47<br>DQ39-D48<br>DQ40-D49<br>DQ41-D50<br>DQ42-D51<br>DQ43-D52<br>DQ44-D53<br>DQ45-D54<br>DQ46-D55<br>DQ47-D56<br>DQ48-D57<br>DQ49-D58<br>DQ50-D59<br>DQ51-D60<br>DQ52-D61<br>DQ53-D62<br>DQ54-D63<br>DQ55-D64<br>DQ56-D65<br>DQ57-D66<br>DQ58-D67<br>DQ59-D68<br>DQ60-D69<br>DQ61-D70<br>DQ62-D71<br>DQ63-D72<br>DQ64-D73<br>DQ65-D74<br>DQ66-D75<br>DQ67-D76<br>DQ68-D77<br>DQ69-D78<br>DQ70-D79<br>DQ71-D80<br>DQ72-D81<br>DQ73-D82<br>DQ74-D83<br>DQ75-D84<br>DQ76-D85<br>DQ77-D86<br>DQ78-D87<br>DQ79-D88<br>DQ80-D89<br>DQ81-D90<br>DQ82-D91<br>DQ83-D92<br>DQ84-D93<br>DQ85-D94<br>DQ86-D95<br>DQ87-D96<br>DQ88-D97<br>DQ89-D98<br>DQ90-D99<br>DQ91-D100<br>DQ92-D101<br>DQ93-D102<br>DQ94-D103<br>DQ95-D104<br>DQ96-D105<br>DQ97-D106<br>DQ98-D107<br>DQ99-D108<br>DQ100-D109<br>DQ101-D110<br>DQ102-D111<br>DQ103-D112<br>DQ104-D113<br>DQ105-D114<br>DQ106-D115<br>DQ107-D116<br>DQ108-D117<br>DQ109-D118<br>DQ110-D119<br>DQ111-D120<br>DQ112-D121<br>DQ113-D122<br>DQ114-D123<br>DQ115-D124<br>DQ116-D125<br>DQ117-D126<br>DQ118-D127<br>DQ119-D128<br>DQ120-D129<br>DQ121-D130<br>DQ122-D131<br>DQ123-D132<br>DQ124-D133<br>DQ125-D134<br>DQ126-D135<br>DQ127-D136<br>DQ128-D137<br>DQ129-D138<br>DQ130-D139<br>DQ131-D140<br>DQ132-D141<br>DQ133-D142<br>DQ134-D143<br>DQ135-D144<br>DQ136-D145<br>DQ137-D146<br>DQ138-D147<br>DQ139-D148<br>DQ140-D149<br>DQ141-D150<br>DQ142-D151<br>DQ143-D152<br>DQ144-D153<br>DQ145-D154<br>DQ146-D155<br>DQ147-D156<br>DQ148-D157<br>DQ149-D158<br>DQ150-D159<br>DQ151-D160<br>DQ152-D161<br>DQ153-D162<br>DQ154-D163<br>DQ155-D164<br>DQ156-D165<br>DQ157-D166<br>DQ158-D167<br>DQ159-D168<br>DQ160-D169<br>DQ161-D170<br>DQ162-D171<br>DQ163-D172<br>DQ164-D173<br>DQ165-D174<br>DQ166-D175<br>DQ167-D176<br>DQ168-D177<br>DQ169-D178<br>DQ170-D179<br>DQ171-D180<br>DQ172-D181<br>DQ173-D182<br>DQ174-D183<br>DQ175-D184<br>DQ176-D185<br>DQ177-D186<br>DQ178-D187<br>DQ179-D188<br>DQ180-D189<br>DQ181-D190<br>DQ182-D191<br>DQ183-D192<br>DQ184-D193<br>DQ185-D194<br>DQ186-D195<br>DQ187-D196<br>DQ188-D197<br>DQ189-D198<br>DQ190-D199<br>DQ191-D200<br>DQ192-D201<br>DQ193-D202<br>DQ194-D203<br>DQ195-D204<br>DQ196-D205<br>DQ197-D206<br>DQ198-D207<br>DQ199-D208<br>DQ200-D209<br>DQ201-D210<br>DQ202-D211<br>DQ203-D212<br>DQ204-D213<br>DQ205-D214<br>DQ206-D215<br>DQ207-D216<br>DQ208-D217<br>DQ209-D218<br>DQ210-D219<br>DQ211-D220<br>DQ212-D221<br>DQ213-D222<br>DQ214-D223<br>DQ215-D224<br>DQ216-D225<br>DQ217-D226<br>DQ218-D227<br>DQ219-D228<br>DQ220-D229<br>DQ221-D230<br>DQ222-D231<br>DQ223-D232<br>DQ224-D233<br>DQ225-D234<br>DQ226-D235<br>DQ227-D236<br>DQ228-D237<br>DQ229-D238<br>DQ230-D239<br>DQ231-D240<br>DQ232-D241<br>DQ233-D242<br>DQ234-D243<br>DQ235-D244<br>DQ236-D245<br>DQ237-D246<br>DQ238-D247<br>DQ239-D248<br>DQ240-D249<br>DQ241-D250<br>DQ242-D251<br>DQ243-D252<br>DQ244-D253<br>DQ245-D254<br>DQ246-D255<br>DQ247-D256<br>DQ248-D257<br>DQ249-D258<br>DQ250-D259<br>DQ251-D260<br>DQ252-D261<br>DQ253-D262<br>DQ254-D263<br>DQ255-D264<br>DQ256-D265<br>DQ257-D266<br>DQ258-D267<br>DQ259-D268<br>DQ260-D269<br>DQ261-D270<br>DQ262-D271<br>DQ263-D272<br>DQ264-D273<br>DQ265-D274<br>DQ266-D275<br>DQ267-D276<br>DQ268-D277<br>DQ269-D278<br>DQ270-D279<br>DQ271-D280<br>DQ272-D281<br>DQ273-D282<br>DQ274-D283<br>DQ275-D284<br>DQ276-D285<br>DQ277-D286<br>DQ278-D287<br>DQ279-D288<br>DQ280-D289<br>DQ281-D290<br>DQ282-D291<br>DQ283-D292<br>DQ284-D293<br>DQ285-D294<br>DQ286-D295<br>DQ287-D296<br>DQ288-D297<br>DQ289-D298<br>DQ290-D299<br>DQ291-D300<br>DQ292-D301<br>DQ293-D302<br>DQ294-D303<br>DQ295-D304<br>DQ296-D305<br>DQ297-D306<br>DQ298-D307<br>DQ299-D308<br>DQ300-D309<br>DQ301-D310<br>DQ302-D311<br>DQ303-D312<br>DQ304-D313<br>DQ305-D314<br>DQ306-D315<br>DQ307-D316<br>DQ308-D317<br>DQ309-D318<br>DQ310-D319<br>DQ311-D320<br>DQ312-D321<br>DQ313-D322<br>DQ314-D323<br>DQ315-D324<br>DQ316-D325<br>DQ317-D326<br>DQ318-D327<br>DQ319-D328<br>DQ320-D329<br>DQ321-D330<br>DQ322-D331<br>DQ323-D332<br>DQ324-D333<br>DQ325-D334<br>DQ326-D335<br>DQ327-D336<br>DQ328-D337<br>DQ329-D338<br>DQ330-D339<br>DQ331-D340<br>DQ332-D341<br>DQ333-D342<br>DQ334-D343<br>DQ335-D344<br>DQ336-D345<br>DQ337-D346<br>DQ338-D347<br>DQ339-D348<br>DQ340-D349<br>DQ341-D350<br>DQ342-D351<br>DQ343-D352<br>DQ344-D353<br>DQ345-D354<br>DQ346-D355<br>DQ347-D356<br>DQ348-D357<br>DQ349-D358<br>DQ350-D359<br>DQ351-D360<br>DQ352-D361<br>DQ353-D362<br>DQ354-D363<br>DQ355-D364<br>DQ356-D365<br>DQ357-D366<br>DQ358-D367<br>DQ359-D368<br>DQ360-D369<br>DQ361-D370<br>DQ362-D371<br>DQ363-D372<br>DQ364-D373<br>DQ365-D374<br>DQ366-D375<br>DQ367-D376<br>DQ368-D377<br>DQ369-D378<br>DQ370-D379<br>DQ371-D380<br>DQ372-D381<br>DQ373-D382<br>DQ374-D383<br>DQ375-D384<br>DQ376-D385<br>DQ377-D386<br>DQ378-D387<br>DQ379-D388<br>DQ380-D389<br>DQ381-D390<br>DQ382-D391<br>DQ383-D392<br>DQ384-D393<br>DQ385-D394<br>DQ386-D395<br>DQ387-D396<br>DQ388-D397<br>DQ389-D398<br>DQ390-D399<br>DQ391-D400<br>DQ392-D401<br>DQ393-D402<br>DQ394-D403<br>DQ395-D404<br>DQ396-D405<br>DQ397-D406<br>DQ398-D407<br>DQ399-D408<br>DQ400-D409<br>DQ401-D410<br>DQ402-D411<br>DQ403-D412<br>DQ404-D413<br>DQ405-D414<br>DQ406-D415<br>DQ407-D416<br>DQ408-D417<br>DQ409-D418<br>DQ410-D419<br>DQ411-D420<br>DQ412-D421<br>DQ413-D422<br>DQ414-D423<br>DQ415-D424<br>DQ416-D425<br>DQ417-D426<br>DQ418-D427<br>DQ419-D428<br>DQ420-D429<br>DQ421-D430<br>DQ422-D431<br>DQ423-D432<br>DQ424-D433<br>DQ425-D434<br>DQ426-D435<br>DQ427-D436<br>DQ428-D437<br>DQ429-D438<br>DQ430-D439<br>DQ431-D440<br>DQ432-D441<br>DQ433-D442<br>DQ434-D443<br>DQ435-D444<br>DQ436-D445<br>DQ437-D446<br>DQ438-D447<br>DQ439-D448<br>DQ440-D449<br>DQ441-D450<br>DQ442-D451<br>DQ443-D452<br>DQ444-D453<br>DQ445-D454<br>DQ446-D455<br>DQ447-D456<br>DQ448-D457<br>DQ449-D458<br>DQ450-D459<br>DQ451-D460<br>DQ452-D461<br>DQ453-D462<br>DQ454-D463<br>DQ455-D464<br>DQ456-D465<br>DQ457-D466<br>DQ458-D467<br>DQ459-D468<br>DQ460-D469<br>DQ461-D470<br>DQ462-D471<br>DQ463-D472<br>DQ464-D473<br>DQ465-D474<br>DQ466-D475<br>DQ467-D476<br>DQ468-D477<br>DQ469-D478<br>DQ470-D479<br>DQ471-D480<br>DQ472-D481<br>DQ473-D482<br>DQ474-D483<br>DQ475-D484<br>DQ476-D485<br>DQ477-D486<br>DQ478-D487<br>DQ479-D488<br>DQ480-D489<br>DQ481-D490<br>DQ482-D491<br>DQ483-D492<br>DQ484-D493<br>DQ485-D494<br>DQ486-D495<br>DQ487-D496<br>DQ488-D497<br>DQ489-D498<br>DQ490-D499<br>DQ491-D500<br>DQ492-D501<br>DQ493-D502<br>DQ494-D503<br>DQ495-D504<br>DQ496-D505<br>DQ497-D506<br>DQ498-D507<br>DQ499-D508<br>DQ500-D509<br>DQ501-D510<br>DQ502-D511<br>DQ503-D512<br>DQ504-D513<br>DQ505-D514<br>DQ506-D515<br>DQ507-D516<br>DQ508-D517<br>DQ509-D518<br>DQ510-D519<br>DQ511-D520<br>DQ512-D521<br>DQ513-D522<br>DQ514-D523<br>DQ515-D524<br>DQ516-D525<br>DQ517-D526<br>DQ518-D527<br>DQ519-D528<br>DQ520-D529<br>DQ521-D530<br>DQ522-D531<br>DQ523-D532<br>DQ524-D533<br>DQ525-D534<br>DQ526-D535<br>DQ527-D536<br>DQ528-D537<br>DQ529-D538<br>DQ530-D539<br>DQ531-D540<br>DQ532-D541<br>DQ533-D542<br>DQ534-D543<br>DQ535-D544<br>DQ536-D545<br>DQ537-D546<br>DQ538-D547<br>DQ539-D548<br>DQ540-D549<br>DQ541-D550<br>DQ542-D551<br>DQ543-D552<br>DQ544-D553<br>DQ545-D554<br>DQ546-D555<br>DQ547-D556<br>DQ548-D557<br>DQ549-D558<br>DQ550-D559<br>DQ551-D560<br>DQ552-D561<br>DQ553-D562<br>DQ554-D563<br>DQ555-D564<br>DQ556-D565<br>DQ557-D566<br>DQ558-D567<br>DQ559-D568<br>DQ560-D569<br>DQ561-D570<br>DQ562-D571<br>DQ563-D572<br>DQ564-D573<br>DQ565-D574<br>DQ566-D575<br>DQ567-D576<br>DQ568-D577<br>DQ569-D578<br>DQ570-D579<br>DQ571-D580<br>DQ572-D581<br>DQ573-D582<br>DQ574-D583<br>DQ575-D584<br>DQ576-D585<br>DQ577-D586<br>DQ578-D587<br>DQ579-D588<br>DQ580-D589<br>DQ581-D590<br>DQ582-D591<br>DQ583-D592<br>DQ584-D593<br>DQ585-D594<br>DQ586-D595<br>DQ587-D596<br>DQ588-D597<br>DQ589-D598<br>DQ590-D599<br>DQ591-D600<br>DQ592-D601<br>DQ593-D602<br>DQ594-D603<br>DQ595-D604<br>DQ596-D605<br>DQ597-D606<br>DQ598-D607<br>DQ599-D608<br>DQ600-D609<br>DQ601-D610<br>DQ602-D611<br>DQ603-D612<br>DQ604-D613<br>DQ605-D614<br>DQ606-D615<br>DQ607-D616<br>DQ608-D617<br>DQ609-D618<br>DQ610-D619<br>DQ611-D620<br>DQ612-D621<br>DQ613-D622<br>DQ614-D623<br>DQ615-D624<br>DQ616-D625<br>DQ617-D626<br>DQ618-D627<br>DQ619-D628<br>DQ620-D629<br>DQ621-D630<br>DQ622-D631<br>DQ623-D632<br>DQ624-D633<br>DQ625-D634<br>DQ626-D635<br>DQ627-D636<br>DQ628-D637<br>DQ629-D638<br>DQ630-D639<br>DQ631-D640<br>DQ632-D641<br>DQ633-D642<br>DQ634-D643<br>DQ635-D644<br>DQ636-D645<br>DQ637-D646<br>DQ638-D647<br>DQ639-D648<br>DQ640-D649<br>DQ641-D650<br>DQ642-D651<br>DQ643-D652<br>DQ644-D653<br>DQ645-D654<br>DQ646-D655<br>DQ647-D656<br>DQ648-D657<br>DQ649-D658<br>DQ650-D659<br>DQ651-D660<br>DQ652-D661<br>DQ653-D662<br>DQ654-D663<br>DQ655-D664<br>DQ656-D665<br>DQ657-D666<br>DQ658-D667<br>DQ659-D668<br>DQ660-D669<br>DQ661-D670<br>DQ662-D671<br>DQ663-D672<br>DQ664-D673<br>DQ665-D674<br>DQ666-D675<br>DQ667-D676<br>DQ668-D677<br>DQ669-D678<br>DQ670-D679<br>DQ671-D680<br>DQ672-D681<br>DQ673-D682<br>DQ674-D683<br>DQ675-D684<br>DQ676-D685<br>DQ677-D686<br>DQ678-D687<br>DQ679-D688<br>DQ680-D689<br>DQ681-D690<br>DQ682-D691<br>DQ683-D692<br>DQ684-D693<br>DQ685-D694<br>DQ686-D695<br>DQ687-D696<br>DQ688-D697<br>DQ689-D698<br>DQ690-D699<br>DQ691-D700<br>DQ692-D701<br>DQ693-D702<br>DQ694-D703<br>DQ695-D704<br>DQ696-D705<br>DQ697-D706<br>DQ698-D707<br>DQ699-D708<br>DQ700-D709<br>DQ701-D710<br>DQ702-D711<br>DQ703-D712<br>DQ704-D713<br>DQ705-D714<br>DQ706-D715<br>DQ707-D716<br>DQ708-D717<br>DQ709-D718<br>DQ710-D719<br>DQ711-D720<br>DQ712-D721<br>DQ713-D722<br>DQ714-D723<br>DQ715-D724<br>DQ716-D725<br>DQ717-D726<br>DQ718-D727<br>DQ719-D728<br>DQ720-D729<br>DQ721-D730<br>DQ722-D731<br>DQ723-D732<br>DQ724-D733<br>DQ725-D734<br>DQ726-D735<br>DQ727-D736<br>DQ728-D737<br>DQ729-D738<br>DQ730-D739<br>DQ731-D740<br>DQ732-D741<br>DQ733-D742<br>DQ734-D743<br>DQ735-D744<br>DQ736-D745<br>DQ737-D746<br>DQ738-D747<br>DQ739-D748<br>DQ740-D749<br>DQ741-D750<br>DQ742-D751<br>DQ743-D752<br>DQ744-D753<br>DQ745-D754<br>DQ746-D755<br>DQ747-D756<br>DQ748-D757<br>DQ749-D758<br>DQ750-D759<br>DQ751-D760<br>DQ752-D761<br>DQ753-D762<br>DQ754-D763<br>DQ755-D764<br>DQ756-D765<br>DQ757-D766<br>DQ758-D767<br>DQ759-D768<br>DQ760-D769<br>DQ761-D770<br>DQ762-D771<br>DQ763-D772<br>DQ764-D773<br>DQ765-D774<br>DQ766-D775<br>DQ767-D776<br>DQ768-D777<br>DQ769-D778<br>DQ770-D779<br>DQ771-D780<br>DQ772-D781<br>DQ773-D782<br>DQ774-D783<br>DQ775-D784<br>DQ776-D785<br>DQ777-D786<br>DQ778-D787<br>DQ779-D788<br>DQ780-D789<br>DQ781-D790<br>DQ782-D791<br>DQ783-D792<br>DQ784-D793<br>DQ785-D794<br>DQ786-D795<br>DQ787-D796<br>DQ788-D797<br>DQ789-D798<br>DQ790-D799<br>DQ791-D800<br>DQ792-D801<br>DQ793-D802<br>DQ794-D803<br>DQ795-D804<br>DQ796-D805<br>DQ797-D806<br>DQ798-D807<br>DQ799-D808<br>DQ800-D809<br>DQ801-D810<br>DQ802-D811<br>DQ803-D812<br>DQ804-D813<br>DQ805-D814<br>DQ806-D815<br>DQ807-D816<br>DQ808-D817<br>DQ809-D818<br>DQ810-D819<br>DQ811-D820<br>DQ812-D821<br>DQ813-D822<br>DQ814-D823<br>DQ815-D824<br>DQ816-D825<br>DQ817-D826<br>DQ818-D827<br>DQ819-D828<br>DQ820-D829<br>DQ821-D830<br>DQ822-D831<br>DQ823-D832<br>DQ824-D833<br>DQ825-D834<br>DQ826-D835<br>DQ827-D836<br>DQ828-D837<br>DQ829-D838<br>DQ830-D839<br>DQ831-D840<br>DQ832-D841<br>DQ833-D842<br>DQ834-D843<br>DQ835-D844<br>DQ836-D845<br>DQ837-D846<br>DQ838-D847<br>DQ839-D848<br>DQ840-D849<br>DQ841-D850<br>DQ842-D851<br>DQ843-D852<br>DQ844-D853<br>DQ845-D854<br>DQ846-D855<br>DQ847-D856<br>DQ848-D857<br>DQ849-D858<br>DQ850-D859<br>DQ851-D860<br>DQ852-D861<br>DQ853-D862<br>DQ854-D863<br>DQ855-D864<br>DQ856-D865<br>DQ857-D866<br>DQ858-D867<br>DQ859-D868<br>DQ860-D869<br>DQ861-D870<br>DQ862-D871<br>DQ863-D872<br>DQ864-D873<br>DQ865-D874<br>DQ866-D875<br>DQ867-D876<br>DQ868-D877<br>DQ869-D878<br>DQ870-D879<br>DQ871-D880<br>DQ872-D881<br>DQ873-D882<br>DQ874-D883<br>DQ875-D884<br>DQ876-D885<br>DQ877-D886<br>DQ878-D887<br>DQ879-D888<br>DQ880-D889<br>DQ881-D890<br>DQ882-D891<br>DQ883-D892<br>DQ884-D893<br>DQ885-D894<br>DQ886-D895<br>DQ887-D896 |                 |             |

cnt2 <= cnt;  
end Behavior;

-Antifuses: open-circuits and take on low resistance when programmed

//Transmission Lines

-@Steady state: (transmission line impedance not included)

$$V_{load} = V_{src} * \frac{Z_{load}}{Z_{src} + Z_{load}}$$

-Load Reflection coefficient is:

0 when load impedance = transmission line impedance, no voltage reflection at load node

-1 when load is short circuit, load impedance = 0.

1 when load is open circuit, load impedance is infinity.

-Reflection Coefficient:

$$p = \frac{Z_t - Z_0}{Z_t + Z_0}$$

-Transmission Coefficient:

$$t = \frac{2Z_t}{Z_t + Z_0}$$

-Voltage Delivered to Load

$$p_B = \frac{R_t - Z_0}{R_t + Z_0}$$

-Voltage reflected back to Source

$$p_A = \frac{R_s - Z_0}{R_s + Z_0}$$

-Impedance Match:



Q: Functionality of dedicated recursive 'fish-bone' network used inside Spartan3E FPGA?

A: Used to ensure clock arrives everywhere at same time.

### Motivation for Standard

- \* Bed-of-nails printed circuit board tester gone
  - \* We put components on both sides of PCB & replaced DIPs with flat picks to reduce inductance
    - = Nails would hit components
  - \* Reduced spacing between PCB wires
    - = Nails would short the wires
  - \* PCB Tester must be replaced with built-in test delivery system - JTAG does that
- \* Need standard System Test Port and Bus
- \* Integrate components from different vendors
  - = Test bus identical for various components
- \* One chip has test hardware for other chips

### Bed-of-Nails Tester Concept



### Bed-of-Nails Tester



### Purpose of Standard

- \* Lets test instructions and test data be serially fed into a component-under-test (CUT)
- \* Allows reading out of test results
- \* Allows RUNBIST command as an instruction
  - = Too many shifts to shift in external tests
- \* JTAG can operate at chip, PCB, & system levels
- \* Allows control of tri-state signals during testing
- \* Lets other chips collect responses from CUT
- \* Lets system interconnect be tested separately from components
- \* Lets components be tested separately from wires

### Purpose of Standard

- \* Lets test instructions and test data be serially fed into a component-under-test (CUT)
  - \* Allows reading out of test results
  - \* Allows RUNBIST command as an instruction
    - = Too many shifts to shift in external tests
- \* JTAG can operate at chip, PCB, & system levels
- \* Allows control of tri-state signals during testing
- \* Lets other chips collect responses from CUT
- \* Lets system interconnect be tested separately from components
- \* Lets components be tested separately from wires

### System Test Logic



### Instruction Register Loading with JTAG



### System View of Interconnect



### Boundary Scan Chain View



### Elementary Boundary Scan Cell



### Serial Board / MCM Scan



### Parallel Board / MCM Scan



### Independent Path Board / MCM Scan



### Tap Controller Signals

- \* **Test Access Port (TAP)** includes these signals:
  - \* **Test Clock Input (TCK)** - Clock for test logic
    - = Can run at different rate from system clock
  - \* **Test Mode Select (TMS)** - Switches system from functional to test mode
  - \* **Test Data Input (TDI)** - Accepts serial test data and instructions - used to shift in vectors or one of many test instructions
  - \* **Test Data Output (TDO)** - Serially shifts out test results captured in boundary scan chain (or device ID or other internal registers)
  - \* **Test Reset (TRST)** - Optional asynchronous TAP controller reset

