# Assignment 1

IT<sub>451</sub>: COA LAB

# ANINDYA KUNDU

IT, 4<sup>th</sup> Semester ID: 510817020 (Hx-19)

## Question 1

Design and Simulate the Behavioral Model of basic gate (AND, OR, NOT), universal gates, XOR, XNOR gates

mod gates.vhd

```
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
entity mod_gates is
    Port (A, B
                               : in STD_LOGIC;
           Yand, Yor, NotA : out STD LOGIC;
           Ynand, Ynor : out STD LOGIC;
           Yxor, Yxnor : out STD LOGIC);
end mod_gates;
architecture Behavioral of mod_gates is
begin
      Yand <= '1' when (A = '1' and B = '1') else '0';
            <= '0' when (A = '0' and B = '0') else '1';
      NotA <= '1' when (A = '0')
                                               else '0';
      Ynand <= '0' when (A = '1' and B = '1') else '1';
      Ynor <= '1' when (A = '0' and B = '0') else '0';</pre>
      Yxor <= '0' when ((A = '0' and B = '0') or (A = '1' and B = '1')) else '1';
      Yxnor <= '1' when ((A = '0') \text{ and } B = '0') \text{ or } (A = '1') \text{ and } B = '1')) else '0';
end Behavioral;
```

#### RTL Schematic:

VHDL Module:



#### VHDL Test Bench: tb\_gates.vhd

```
LIBRARY ieee;
USE ieee.std_logic_1164.ALL;
ENTITY tb gates IS
END tb gates;
ARCHITECTURE behavior OF tb_gates IS
   COMPONENT mod_gates
   PORT(
                 : IN std logic;
                 : IN std logic;
                 : OUT std logic;
        Yand
        Yor
                 : OUT std_logic;
        NotA
                 : OUT std_logic;
        Ynand : OUT std_logic;
                 : OUT std_logic;
        Ynor
                 : OUT std logic;
        Yxor
        Yxnor
                 : OUT std logic
       );
   END COMPONENT;
   signal A : std logic := '0';
  signal B : std logic := '0';
   signal Yand
                 : std logic;
  signal Yor
                 : std logic;
  signal NotA
                 : std_logic;
   signal Ynand
                 : std_logic;
  signal Ynor
                 : std_logic;
  signal Yxor
                 : std_logic;
  signal Yxnor
                 : std_logic;
BEGIN
  uut: mod_gates PORT MAP (
                 => A,
         Α
                 => B,
         В
         Yand
                 => Yand,
         Yor
                 => Yor,
         NotA
                => NotA,
         Ynand => Ynand,
         Ynor
                 => Ynor,
         Yxor
                 => Yxor,
```

```
Yxnor => Yxnor
);

process
begin
    A <= '0', '1' after 400ns, '0' after 800ns;
    B <= '0', '1' after 200ns, '0' after 400ns, '1' after 600ns, '0' after 800ns;
    wait;
end process;
END;</pre>
```



## **Discussions:**

Components that can be designed based on another existing component is connected accordingly, e.g. an inverter on an AND gate produces NAND gate.

# Question 2

Design and Simulate the Behavioral Model of a 1-bit Magnitude Comparator. It should accept two input bits and give three output lines (greater, less, equal).

```
VHDL Module: mod_magComp1Bit.vhd
```

```
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
entity mod magComp1Bit is
      Port (A, B
                    : in STD LOGIC;
            eq, ls, gr : out STD_LOGIC);
      end mod_magComp1Bit;
architecture Behavioral of mod_magComp1Bit is
begin
      process(A, B)
      begin
           gr <= '0'; eq <= '0'; ls <= '0';
            if (A > B) then gr <= '1';
           elsif (A = B) then eq <= '1';</pre>
                              ls <= '1';
            else
           end if;
      end process;
end Behavioral;
```

## **Schematic:**





LUT for Equal Case

LUT for Greater/Less Case

#### 

```
LIBRARY ieee;
USE ieee.std logic 1164.ALL;
ENTITY tb magComp1Bit IS
END tb magComp1Bit;
ARCHITECTURE behavior OF tb_magComp1Bit IS
    COMPONENT mod_magComp1Bit
    PORT(
         A : IN std logic;
         B : IN std logic;
         eq : OUT std_logic;
         ls : OUT std logic;
         gr : OUT std_logic
        );
    END COMPONENT;
   signal a : std logic := '0';
   signal b : std_logic := '0';
   signal eq : std logic;
   signal ls : std_logic;
   signal gr : std_logic;
BEGIN
   uut: mod magComp1Bit PORT MAP (
          A \Rightarrow a
          B \Rightarrow b,
          eq => eq,
          ls => ls,
          gr => gr
        );
   process
   begin
      a <= '0', '1' after 400ns, '0' after 800ns;
      b <= '0', '1' after 200ns, '0' after 400ns , '1' after 600ns, '0' after
      800ns;
      wait;
   end process;
END;
```



# **Discussions:**

A XNOR gate operation is used to device the Equal Case while an AND gate operation with one of its inputs inverted is used to device the Greater than and Less than Cases. In either case, the alternating inputs are inverted.

# **Question 3**

Design the Behavioral Model (with process statement) of a 4-bit Magnitude Comparator and Simulate.

```
VHDL Module:
                       mod MagComp 4bit.vhd
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
entity mod_MagComp_4bit is
      Port ( A, B : in STD_LOGIC_VECTOR (3 downto 0);
            Gr, Eq, Ls : out STD_LOGIC);
end mod MagComp 4bit;
architecture Behavioral of mod_MagComp_4bit is
begin
      process(A, B)
      begin
           Gr <= '0'; Eq <= '0'; Ls <= '0';
           if (A > B) then Gr <= '1';
            elsif (A = B) then Eq <= '1';</pre>
           elsif (A < B) then Ls <= '1';</pre>
           end if;
      end process;
end Behavioral;
```

#### **Schematic:**



#### VHDL Test Bench:

```
LIBRARY ieee;
USE ieee.std logic 1164.ALL;
USE ieee.numeric std.ALL;
ENTITY tb MagComp 4bit IS
END tb_MagComp_4bit;
ARCHITECTURE behavior OF tb_MagComp_4bit IS
      COMPONENT mod MagComp 4bit
          PORT(
               A : IN std_logic_vector(3 downto 0);
               B : IN std logic vector(3 downto 0);
               Gr : OUT std_logic;
               Eq : OUT std_logic;
               Ls : OUT std_logic
              );
      END COMPONENT;
signal a : std logic vector(3 downto 0) := (others => '0');
signal b : std logic vector(3 downto 0) := (others => '0');
signal gr : std_logic;
signal eq : std logic;
signal ls : std_logic;
BEGIN
      uut: mod MagComp 4bit PORT MAP (
          A \Rightarrow a
          B \Rightarrow b,
          Gr => gr,
          Eq => eq,
          Ls => ls
        );
      proc_A: process
      begin
            a <= "0100";
            while a >= "0000" loop
                  wait for 100ns;
                  a <= std logic vector(unsigned(a) + 1);</pre>
            end loop;
            wait;
      end process;
```



## Question 4

Design and Simulate the Behavioral Model of a 1-bit Full Adder.

**VHDL** Module: mod fullAdder.vhd library IEEE; use IEEE.STD\_LOGIC\_1164.ALL; entity mod\_fullAdder is Port ( Cin, A, B : in STD\_LOGIC; Sum, Crr : out STD\_LOGIC); end mod fullAdder; architecture Behavioral of mod\_fullAdder is begin process(Cin, A, B) begin if(Cin = '0') then if((A = '0' and B = '0') or (A = '1' and B = '1')) then Sum <= '0';else Sum <= '1'; end if; if(A = '1' and B = '1') then Crr <= '1'; else Crr <= '0'; end if; else if((A = '0' and B = '0') or (A = '1' and B = '1')) then Sum <= '1';else Sum <= '0'; end if; if(A = '0' and B = '0') then Crr <= '0'; else Crr <= '1'; end if; end if; end process; end Behavioral;

# RTL Schematic:



# <u>Technology Schematic:</u>



#### VHDL Test Bench: tb\_fullAdder.vhd

```
LIBRARY ieee;
USE ieee.std logic 1164.ALL;
ENTITY tb fullAdder IS
END tb fullAdder;
ARCHITECTURE behavior OF tb fullAdder IS
   COMPONENT mod fullAdder
   PORT(
        Cin
              : IN std logic;
                 : IN std logic;
               : IN std logic;
               : OUT std logic;
        Crr
               : OUT std_logic
       );
   END COMPONENT;
   signal cin : std logic := '0';
                 : std logic := '0';
   signal a
              : std logic := '0';
   signal b
   signal sum : std logic;
   signal crr : std_logic;
BEGIN
   uut: mod fullAdder PORT MAP (
         Cin
               => cin,
         Α
                 => a,
         В
                => b,
         Sum
                => sum,
               => crr
         Crr
       );
   stim proc: process
   begin
     cin <= '0', '1' after 400ns, '0' after 800ns;</pre>
     a <= '0', '1' after 200ns, '0' after 400ns, '1' after 600ns, '0' after 800ns;
     b <= '0', '1' after 100ns, '0' after 200ns, '1' after 300ns, '0' after 400ns, '1'
     after 500ns, '0' after 600ns, '1' after 700ns, '0' after 800ns;
     wait:
   end process;
END;
```



## **Discussions:**

Full adder isn't composed of smaller unit components, i.e. half adders in this case. Two components are generated: one for sum and the other for carry. The sum component produces sum of any three input bits, not necessarily inputs of a full adder. The same goes for the carry component.

## Question 5

Design the Structural Model of a Full Adder using Half Adder as a component.

#### VHDL Module:

#### mod\_halfAdder.vhd

```
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
entity mod halfAdder is
      Port (A, B
                   : in STD LOGIC;
            Sum, Crr : out STD_LOGIC);
      end mod_halfAdder;
architecture Behavioral of mod_halfAdder is
begin
      process(A, B)
      begin
            if((A = '0' \text{ and } B = '0') \text{ or } (A = '1' \text{ and } B = '1')) \text{ then } Sum <= '0';
            else Sum <= '1';
            end if;
            if(A = '1' and B = '1') then Crr <= '1';
            else Crr <= '0';
            end if;
      end process;
end Behavioral;
                               mod fullAdder.vhd
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
entity mod fullAdder is
      Port ( Cin, A, B : in STD LOGIC;
            Sum, Crr : out STD_LOGIC);
end mod_fullAdder;
architecture Structural of mod fullAdder is
      component mod halfAdder is
            Port (A, B
                         : in STD LOGIC;
                   Sum, Crr : out STD LOGIC);
      end component;
signal S1, C1, C2 : STD LOGIC ;
```

```
begin
     HA1 : mod_halfAdder port map(A, B, S1, C1);
     HA2 : mod_halfAdder port map(S1, Cin, Sum, C2);
     Crr <= C1 or C2;
end Structural;</pre>
```

## RTL Schematic:



Half Adder Component



#### VHDL Test Bench: tb\_fullAdder.vhd

```
LIBRARY ieee;
USE ieee.std logic 1164.ALL;
ENTITY tb fullAdder IS
END tb fullAdder;
ARCHITECTURE behavior OF tb fullAdder IS
   COMPONENT mod_fullAdder
         PORT(
              Cin
                   : IN std logic;
                     : IN std logic;
              Α
                     : IN std logic;
                     : OUT std logic;
              Sum
              Crr
                     : OUT std_logic
             );
   END COMPONENT;
  signal cin : std logic := '0';
  signal a
                : std logic := '0';
  signal b
              : std logic := '0';
  signal sum : std logic;
  signal crr : std_logic;
BEGIN
  uut: mod fullAdder PORT MAP (
         Cin
                => cin,
         Α
                => a,
         В
                => b,
         Sum
               => sum,
         Crr
             => crr
       );
  stim proc: process
  begin
     cin <= '0', '1' after 400ns, '0' after 800ns;</pre>
     a <= '0', '1' after 200ns, '0' after 400ns, '1' after 600ns, '0' after 800ns;
     b <= '0', '1' after 100ns, '0' after 200ns, '1' after 300ns, '0' after 400ns,
     '1' after 500ns, '0' after 600ns, '1' after 700ns, '0' after 800ns;
     wait:
  end process;
END;
```



#### Discussions:

Here, two half adders are used as components to generate the full adder which is reflected in the design as well. The Sum of the first adder serves as an input of the second adder along with the carry around. The Carry is a disjunction of the carry outs of the two adders.

In comparison with the previous question, this is modular and implements reusability of pre-generated components (half adder module in this case).

## **Question 6**

Design a 4-bit Binary Parallel Adder using Structural Design Flow hierarchically.

#### VHDL Module:

```
Copy of Source <u>mod_fullAdder.vhd</u> added from Question 5
Copy of Source <u>mod_halfAdder.vhd</u> added from Question 5

<u>mod_BPA_4bit.vhd</u>
```

```
library IEEE;
use IEEE.STD LOGIC 1164.ALL;
entity mod BPA 4bit is
   Port ( Cin
                 : in STD_LOGIC;
          A, B : in STD_LOGIC_VECTOR (3 downto 0);
          Sum : out STD LOGIC VECTOR (3 downto 0);
          Cout : out STD LOGIC);
end mod BPA 4bit;
architecture Structural of mod BPA 4bit is
      component mod fullAdder is
           Port ( Cin, A, B : in STD LOGIC;
                  Sum, Crr : out STD LOGIC);
     end component;
signal C0, C1, C2 : STD_LOGIC;
begin
     FA1 : mod fullAdder port map(Cin, A(0), B(0), Sum(0), C0);
      FA2 : mod fullAdder port map(Cin, A(1), B(1), Sum(1), C1);
      FA3 : mod fullAdder port map(Cin, A(2), B(2), Sum(2), C2);
      FA4 : mod fullAdder port map(Cin, A(3), B(3), Sum(3), Cout);
end Structural;
```

# <u>Technology Schematic:</u>



#### VHDL Test Bench: tb\_BPA\_4bit.vhd

```
LIBRARY ieee;
USE ieee.std logic 1164.ALL;
USE ieee.numeric std.ALL;
ENTITY tb BPA 4bit IS
END tb BPA 4bit;
ARCHITECTURE behavior OF tb BPA 4bit IS
    COMPONENT mod BPA 4bit
         PORT(
              Cin : IN std logic;
                       : IN std_logic_vector(3 downto 0);
                       : IN std logic vector(3 downto 0);
                      : OUT std_logic_vector(3 downto 0);
              Cout
                       : OUT std logic
              );
    END COMPONENT;
signal cin : std logic := '0';
signal a : std logic vector(3 downto 0) := (others => '0');
signal b : std logic vector(3 downto 0) := (others => '0');
signal sum : std logic vector(3 downto 0);
signal cout : std logic;
BEGIN
  uut: mod BPA 4bit PORT MAP (
         Cin
               => cin,
          Α
                 => a,
          В
                 => b,
          Sum
                => sum,
         Cout => cout
        );
  cin <= '0', '1' after 700ns;</pre>
   proc_A: process
   begin
     a <= "0100";
     while a >= "0000" loop
           wait for 100ns;
           a <= std logic vector(unsigned(a) + 1);</pre>
     end loop;
     wait;
   end process;
```

```
proc_B: process
begin
    b <= "0000";
    while b >= "0000" loop
        wait for 100ns;
        b <= std_logic_vector(unsigned(b) + 4);
    end loop;
    wait;
    end process;
END;</pre>
```



#### **Discussions:**

Four full adders output the same bit of four respective bits of the two inputs. In each case, the carry is carried up and added as an input to the next significant bit's adder. The last carry is the final carry out of the ripple adder.

#### Question 7 - a

Design the structural model of a BCD adder using previously designed BPA model as a component.

#### VHDL Module:

```
Copy of Source <u>mod_BPA_4bit.vhd</u> added from Question 6
Copy of Source <u>mod_fullAdder.vhd</u> added from Question 5
Copy of Source <u>mod_halfAdder.vhd</u> added from Question 5
```

#### mod BCDAdder.vhd

```
library IEEE;
use IEEE.STD LOGIC 1164.ALL;
entity mod BCDAdder is
      Port ( Cin : IN STD LOGIC;
                  : IN STD LOGIC VECTOR (3 downto 0);
                 : IN STD LOGIC VECTOR (3 downto 0):
             Sum : OUT STD LOGIC VECTOR (3 downto 0);
             Cout : INOUT STD LOGIC);
      end mod BCDAdder;
architecture Structural of mod BCDAdder is
      Component mod BPA 4bit
            Port ( Cin : IN STD_LOGIC;
                   A, B : IN STD LOGIC VECTOR (3 downto 0);
                   Sum : OUT STD LOGIC VECTOR(3 downto 0);
                   Cout : OUT STD LOGIC);
      end Component;
      signal S1, H : STD LOGIC VECTOR(3 downto 0);
      signal C1, P : STD LOGIC;
begin
      BPA1 : mod_BPA_4bit port map(Cin, A, B, S1, C1);
      Cout <= C1 or (S1(3) and S1(2)) or (S1(3) and S1(1));
           <= "0110" when (Cout = '1') else "0000";
      BPA2 : mod BPA 4bit port map('0', H, S1, Sum, P);
end Structural;
```

# RTL Schematic:



#### VHDL Test Bench: tb\_BCDAdder.vhd

```
LIBRARY ieee;
USE ieee.std logic 1164.ALL;
USE ieee.numeric std.ALL;
ENTITY tb BCDAdder IS
END tb BCDAdder;
ARCHITECTURE behavior OF tb BCDAdder IS
   COMPONENT mod BCDAdder
         PORT(
              Cin : IN std logic;
                      : IN std_logic_vector(3 downto 0);
                      : IN std logic vector(3 downto 0);
                     : OUT std_logic_vector(3 downto 0);
              Cout
                       : INOUT std_logic
             );
   END COMPONENT;
  signal cin : std_logic := '0';
   signal a
               : std logic vector(3 downto 0) := (others => '0');
                 : std logic vector(3 downto 0) := (others => '0');
   signal b
  signal sum
                 : std logic vector(3 downto 0);
   signal cout : std_logic;
BEGIN
  uut: mod BCDAdder PORT MAP (
         Cin => cin,
               => a,
         Α
                => b,
         В
         Sum => sum,
         Cout
                => cout
       );
   cin <= '0', '1' after 700ns;</pre>
   proc_A: process
   begin
     a <= "0100";
     while a >= "0000" loop
           wait for 100ns:
           a <= std logic vector(unsigned(a) + 1);</pre>
     end loop;
     wait;
```

```
end process;

proc_B: process
begin
    b <= "0000";
    while b >= "0000" loop
        wait for 100ns;
        b <= std_logic_vector(unsigned(b) + 4);
    end loop;
    wait;
    end process;

END;</pre>
```



# **Question 7 - b**

Design the BCD adder without using BPA (behavioral model to be used).

```
VHDL Module:
                        mod BCDAdder.vhd
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
use IEEE.numeric_std.all;
entity mod_BCDAdder is
    Port ( Cin
                 : in STD LOGIC;
                  : in unsigned (3 downto 0);
                : in unsigned (3 downto 0);
                 : out unsigned (3 downto 0);
           Sum
           Cout : out STD_LOGIC);
end mod_BCDAdder;
architecture Behavioral of mod_BCDAdder is
begin
      process(Cin, A, B)
      variable S : unsigned (4 downto 0);
      begin
            S := ('0' \& A) + ('0' \& B) + ("0000" \& Cin);
            if(S > 9) then
                  Cout <= '1';
                  Sum <= resize((S + "00110"), 4);</pre>
            else
                  Cout <= '0';
                  Sum <= S(3 downto 0);</pre>
            end if;
      end process;
end Behavioral;
```

# RTL Schematic:



#### VHDL Test Bench: tb\_BCDAdder.vhd

```
LIBRARY ieee;
USE ieee.std logic 1164.ALL;
USE ieee.numeric std.ALL;
ENTITY tb BCDAdder IS
END tb BCDAdder;
ARCHITECTURE behavior OF tb BCDAdder IS
   COMPONENT mod BCDAdder
         PORT(
              Cin : IN std logic;
                     : IN unsigned(3 downto 0);
                      : IN unsigned(3 downto 0);
                     : OUT unsigned(3 downto 0);
              Cout
                     : OUT std logic
             );
   END COMPONENT;
  signal cin : std_logic := '0';
  signal a
               : unsigned(3 downto 0) := (others => '0');
  signal b
                 : unsigned(3 downto 0) := (others => '0');
  signal sum : unsigned(3 downto 0);
  signal cout : std_logic;
BEGIN
  uut: mod BCDAdder PORT MAP (
         Cin => cin,
         Α
                => a,
                => b,
         В
         Sum => sum,
         Cout
               => cout
       );
  cin <= '0', '1' after 700ns;</pre>
  proc_A: process
  begin
     a <= "0100";
     while a >= "0000" loop
           wait for 100ns;
           a <= a + 1;
     end loop;
     wait;
```

```
end process;

proc_B: process
begin
    b <= "0000";
    while b >= "0000" loop
        wait for 100ns;
        b <= b + 4;
    end loop;
    wait;
    end process;

END;</pre>
```



#### **Discussions:**

In part a of the question, the BCD adder is constructed using two Binary Parallel Adders, which are in turn constituted by Full Adders in Parallel. However, in this part of the question, yet again two adders are implemented but the operations are split by bits. Each component for the purpose contains two full adders, a comparator and a multiplexer.

# **Question 8**

Design and simulate the behavioral model of a T flip-flop.

Simulate for all possible input combinations. Note down the synthesis report.

```
VHDL Module:
                      mod T FF.vhd
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
entity mod T FF is
     Port ( Pre, Clr : in STD_LOGIC;
            Clk, T : in STD_LOGIC;
            Q, Qc : inout STD_LOGIC);
end mod_T_FF;
architecture Behavioral of mod_T_FF is
begin
     process(Pre, Clr, Clk, T)
     begin
           if(Pre = '1') then
                 Q <= '1'; Qc <= '0';
           elsif(Clr = '1') then
                 Q <= '0'; Qc <= '1';
           elsif(rising_edge(Clk)) then
                 if(T = '1') then
                       Q <= not Q;
                       Qc <= not Qc;
                 end if;
           end if;
     end process;
end Behavioral;
```

# RTL Schematic:



#### VHDL Test Bench: tb\_T\_FF.vhd

```
LIBRARY ieee;
USE ieee.std logic 1164.ALL;
ENTITY tb T FF IS
END tb T FF;
ARCHITECTURE behavior OF tb_T_FF IS
   COMPONENT mod_T_FF
         PORT(
              Pre : IN std_logic;
              Clr : IN std_logic;
              Clk : IN std logic;
              T : IN std logic;
              Q : INOUT std_logic;
              Qc : INOUT std_logic
             );
    END COMPONENT;
signal pre : std_logic := '0';
signal clr : std_logic := '0';
signal clk : std logic := '0';
            : std_logic := '0';
signal t
signal q
                 : std_logic;
signal qc : std_logic;
constant clk period : time := 50 ns;
BEGIN
  uut: mod_T_FF PORT MAP (
         Pre => pre,
         Clr
               => clr,
         Clk => clk,
         Τ
               => t,
         Q
               => q,
         Qc
                => qc
       );
  clk_process: process
  begin
     clk <= '1';
     wait for clk period/2;
     clk <= '0';
```

```
wait for clk_period/2;
   end process;
   set_process: process
   begin
      pre <= '1'; clr <= '0';</pre>
      wait for 200ns;
      pre <= '0'; clr <= '1';
      wait for 200ns;
      pre <= '0'; clr <= '0';</pre>
      wait for 400ns;
      pre <= '1'; clr <= '1';
   end process;
   stm process: process
   begin
      while(t >= '0') loop
            t <= '0'; wait for 50ns;
            t <= '1'; wait for 50ns;
      end loop;
      wait;
   end process;
END;
```



#### Discussions:

The two outputs: Q and Q' come from two different repeating components, unlike the simplified circuit of a flip flop.

# <u>Synthesis Report:</u>

Advanced HDL Synthesis Report

| *                                                                                                                                                                               | HDL Parsing                                                      | ======================================= | *                                                    |            |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------|-----------------------------------------|------------------------------------------------------|------------|
| <pre>into library work Parsing entity <mod_t< pre=""></mod_t<></pre>                                                                                                            | ======================================                           |                                         | <br>-T-Flip-FLop\mod_T <sub>.</sub>                  | _FF . vhd" |
| *                                                                                                                                                                               | HDL Elaboration                                                  |                                         | *<br>====================================            |            |
| Elaborating entity <m< td=""><td>od_T_FF&gt; (architecture</td><td><pre><behavioral>)</behavioral></pre></td><td>from library <work< td=""><td>&lt;&gt;.</td></work<></td></m<> | od_T_FF> (architecture                                           | <pre><behavioral>)</behavioral></pre>   | from library <work< td=""><td>&lt;&gt;.</td></work<> | <>.        |
| *                                                                                                                                                                               | HDL Synthesis                                                    |                                         | *<br>                                                |            |
| FLop\mod_T_FF.vhd".  Found 1-bit regist  Found 1-bit regist  Summary:                                                                                                           | file is "D:\IT ter for signal <qc>. ter for signal <q>.</q></qc> | Labs\IT451-CO                           | A\Assignment-1\Q08                                   | -T-Flip-   |
| HDL Synthesis Report                                                                                                                                                            | ============                                                     | ==========                              |                                                      |            |
| Macro Statistics # Registers 1-bit register                                                                                                                                     | =======================================                          | : 2<br>: 2                              | 2                                                    |            |
| *                                                                                                                                                                               | Advanced HDL Synthe                                              | :=======                                |                                                      |            |

```
Macro Statistics
# Registers
                            : 2
Flip-Flops
                            : 2
______
______
             Low Level Synthesis
______
List of register instances with asynchronous set and reset:
  Q in unit <mod T FF>
  Qc in unit <mod T FF>
Optimizing unit <mod_T_FF> ...
Mapping all equations...
Building and optimizing final netlist ...
Found area constraint ratio of 100 (+ 5) on block mod T FF, actual ratio is 0.
Final Macro Processing ...
_______
Final Register Report
Macro Statistics
# Registers
                            : 4
Flip-Flops
                            : 4
______
_____
              Partition Report
______
Partition Implementation Status
_____
 No Partitions were found in this design.
______
```

Design Summary

\*

\_\_\_\_\_\_

#### **Clock Information:**

-----

|           | ock buffer(FF name)   Load  <br>    |
|-----------|-------------------------------------|
| Clr   IBU | JF+BUFG   1   FGP   4   JF+BUFG   1 |

## Asynchronous Control Signals Information:

-----

No asynchronous control signals found in this design

#### Timing Summary:

-----

Speed Grade: -2

Minimum period: 1.683ns (Maximum Frequency: 594.177MHz)

Minimum input arrival time before clock: 3.596ns
Maximum output required time after clock: 5.363ns
Maximum combinational path delay: No path found

\_\_\_\_\_\_

Process "Synthesize - XST" completed successfully

# **Question 9**

Design and simulate the behavioral model of a D flip-flop.

Simulate for all possible input combinations. Note down the synthesis report.

```
VHDL Module:
                      mod D FF.vhd
library IEEE;
use IEEE.STD LOGIC 1164.ALL;
entity mod D FF is
     Port ( Pre, Clr : in STD_LOGIC;
            Clk, D : in STD_LOGIC;
            Q, Qc : inout STD_LOGIC);
end mod_D_FF;
architecture Behavioral of mod_D_FF is
begin
     process(Pre, Clr, Clk, D)
     begin
           if(Pre = '1') then
                 Q <= '1'; Qc <= '0';
           elsif(Clr = '1') then
                 Q <= '0'; Qc <= '1';
           elsif(rising_edge(Clk)) then
                 if(D = '1') then
                      Q <= '1';
                      Qc <= '0';
                 else
                      Q
                           <= '0';
                            <= '1';
                       Qc
                 end if;
           end if;
     end process;
end Behavioral;
```

# RTL Schematic:



## VHDL Test Bench: tb\_D\_FF.vhd

```
LIBRARY ieee;
USE ieee.std logic 1164.ALL;
ENTITY tb D FF IS
END tb D FF;
ARCHITECTURE behavior OF tb_D_FF IS
   COMPONENT mod D FF
         PORT(
              Pre : IN std_logic;
              Clr : IN std_logic;
              Clk : IN std logic;
              D : IN std logic;
              Q : INOUT std_logic;
              Qc : INOUT std_logic
             );
    END COMPONENT;
signal pre : std_logic := '0';
signal clr : std_logic := '0';
signal clk : std_logic := '0';
signal d : std_logic := '0';
signal q : std_logic;
signal qc : std_logic;
constant clk period : time := 50 ns;
BEGIN
   uut: mod_D_FF PORT MAP (
         Pre => pre,
         Clr
                => clr,
         Clk => clk,
         D
               => d,
         Q
               => q,
         Qc
                => qc
       );
   clk_process: process
   begin
     clk <= '1';
     wait for clk period/2;
     clk <= '0';
```

```
wait for clk_period/2;
   end process;
   set_process: process
   begin
      pre <= '1'; clr <= '0';</pre>
      wait for 200ns;
      pre <= '0'; clr <= '1';
      wait for 200ns;
      pre <= '0'; clr <= '0';</pre>
      wait for 400ns;
      pre <= '1'; clr <= '1';
   end process;
   stm process: process
   begin
      while(d >= '0') loop
            d <= '0'; wait for 50ns;</pre>
             d <= '1'; wait for 50ns;</pre>
      end loop;
      wait;
   end process;
END;
```

## **Simulation:**



## **Discussions:**

The two outputs: Q and Q' come from two different repeating components, unlike the simplified circuit of a flip flop.

# <u>Synthesis Report:</u>

Advanced HDL Synthesis Report

| *                                                                                                                                                                                        | HDL Parsing                                                                        | =========                               | *                                         |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------|-----------------------------------------|-------------------------------------------|
| Parsing VHDL file "D: into library work Parsing entity <mod_d_ <<="" architecture="" parsing="" th=""><th>FF&gt;.</th><th></th><th>=======<br/>D-D-Flip-Flop\mod_D_FF.vhd"</th></mod_d_> | FF>.                                                                               |                                         | =======<br>D-D-Flip-Flop\mod_D_FF.vhd"    |
| * ====================================                                                                                                                                                   | HDL Elaboratio                                                                     | :======:::<br>:n<br>:=========          | *<br>==================================== |
| Elaborating entity <mo< td=""><td>od_D_FF&gt; (architecture</td><td><behavioral>)</behavioral></td><td>from library <work>.</work></td></mo<>                                            | od_D_FF> (architecture                                                             | <behavioral>)</behavioral>              | from library <work>.</work>               |
| *                                                                                                                                                                                        | HDL Synthesis                                                                      |                                         | *<br>==================================== |
| Flop\mod_D_FF.vhd".  Found 1-bit regist  Found 1-bit regist  Summary:                                                                                                                    | file is "D:\IT  er for signal <qc>. er for signal <q>. eype flip-flop(s).</q></qc> | Labs\IT451-C0                           | OA\Assignment-1\Q09-D-Flip-               |
| HDL Synthesis Report                                                                                                                                                                     |                                                                                    | ======================================= | ==========                                |
| Macro Statistics # Registers 1-bit register                                                                                                                                              |                                                                                    | : 2<br>: 2                              | 2                                         |
| *                                                                                                                                                                                        | Advanced HDL Synthe                                                                | :======:                                |                                           |

```
Macro Statistics
# Registers
                            : 2
Flip-Flops
                            : 2
______
______
             Low Level Synthesis
______
List of register instances with asynchronous set and reset:
  Q in unit <mod D FF>
  Qc in unit <mod D FF>
Optimizing unit <mod_D_FF> ...
Mapping all equations...
Building and optimizing final netlist ...
Found area constraint ratio of 100 (+ 5) on block mod D FF, actual ratio is 0.
Final Macro Processing ...
_______
Final Register Report
Macro Statistics
# Registers
                            : 4
Flip-Flops
                            : 4
______
_____
              Partition Report
______
Partition Implementation Status
_____
 No Partitions were found in this design.
______
```

Design Summary

\*

\_\_\_\_\_\_

#### **Clock Information:**

-----

| · ·                                         | + |             |  |
|---------------------------------------------|---|-------------|--|
| Clr   IBUF+BUFG Clk   BUFGP Pre   IBUF+BUFG | į | 1<br>4<br>1 |  |

## Asynchronous Control Signals Information:

-----

No asynchronous control signals found in this design

#### Timing Summary:

-----

Speed Grade: -2

Minimum period: No path found

Minimum input arrival time before clock: 3.596ns Maximum output required time after clock: 5.319ns Maximum combinational path delay: No path found

\_\_\_\_\_\_

Process "Synthesize - XST" completed successfully

# Question 10

Design and simulate the behavioral model of a JK flip-flop.

Simulate for all possible input combinations. Note down the synthesis report.

```
VHDL Module:
                      mod JK FF.vhd
library IEEE;
use IEEE.STD LOGIC 1164.ALL;
entity mod JK FF is
     Port ( Pre, Clr : in STD_LOGIC;
            Clk, J, K : in STD LOGIC;
            Q, Qc : inout STD_LOGIC);
end mod_JK_FF;
architecture Behavioral of mod_JK_FF is
begin
     process(Pre, Clr, Clk, J, K)
     begin
           if(Pre = '1') then
                 Q <= '1'; Qc <= '0';
           elsif(Clr = '1') then
                 Q <= '0'; Qc <= '1';
           elsif(rising edge(Clk)) then
                 if(J = '0' and K = '0') then
                       Q
                           <= Q;
                       Qc <= Qc;
                 elsif(J = '0' and K = '1') then
                       Q
                           <= '0';
                       Qc
                            <= '1';
                 elsif(J = '1' and K = '0') then
                       Q
                           <= '1';
                       Qc <= '0';
                 else
                           <= not Q;
                            <= not Qc;
                       Qc
                 end if;
           end if;
     end process;
end Behavioral;
```

# RTL Schematic:



## VHDL Test Bench: tb\_JK\_FF.vhd

```
LIBRARY ieee;
USE ieee.std logic 1164.ALL;
ENTITY tb JK FF IS
END tb JK FF;
ARCHITECTURE behavior OF tb_JK_FF IS
   COMPONENT mod JK FF
         PORT(
              Pre : IN std logic;
              Clr : IN std_logic;
              Clk : IN std logic;
              J : IN std_logic;
              K : IN std_logic;
              Q : INOUT std_logic;
              Qc : INOUT std_logic
             );
   END COMPONENT;
  signal pre : std logic := '0';
  signal clr : std_logic := '0';
   signal clk : std logic := '0';
   signal j : std logic := '0';
   signal k : std_logic := '0';
  signal q : std logic;
  signal qc : std logic;
   constant clk_period : time := 10 ns;
BEGIN
  uut: mod_JK_FF PORT MAP (
         Pre => pre,
         Clr
                => clr,
         Clk
               => clk,
         J
                 => j,
         K
                => k,
         Q
                 => q,
         Qc
                 => qc
       );
```

```
clk_process: process
   begin
      Clk <= '1';
      wait for Clk period/2;
      Clk <= '0';
      wait for Clk period/2;
   end process;
   set_process: process
   begin
      pre <= '1'; clr <= '0';
      wait for 200ns;
      pre <= '0'; clr <= '0';
      wait for 600ns;
      pre <= '0'; clr <= '1';
   end process;
   stm_process: process
   begin
      while(clk >= '0') loop
            j <= '0'; k <= '0'; wait for 100ns;</pre>
            j <= '0'; k <= '1'; wait for 100ns;</pre>
            j <= '1'; k <= '0'; wait for 100ns;</pre>
            j <= '1'; k <= '1'; wait for 100ns;
      end loop;
      wait;
   end process;
END;
```

## **Simulation:**



## **Discussions:**

Racing Condition observed when both J & K are '1'. The output continuously toggles at every clock edge triggering.

## **Synthesis Report:**

```
_____
              HDL Parsing
Parsing VHDL file "D:\IT Labs\IT451-COA\Assignment-1\Q10-JK-Flip-
Flop\mod JK FF.vhd" into library work
Parsing entity <mod_JK_FF>.
Parsing architecture <Behavioral> of entity <mod_jk_ff>.
______
               HDL Elaboration
______
Elaborating entity <mod_JK_FF> (architecture <Behavioral>) from library <work>.
______
               HDL Synthesis
______
Synthesizing Unit <mod JK FF>.
  Related source file is "D:\IT Labs\IT451-COA\Assignment-1\Q10-JK-Flip-
Flop\mod_JK_FF.vhd".
  Found 1-bit register for signal <Qc>.
  Found 1-bit register for signal <Q>.
  Summary:
   inferred 2 D-type flip-flop(s).
   inferred 4 Multiplexer(s).
Unit <mod JK FF> synthesized.
______
HDL Synthesis Report
Macro Statistics
# Registers
                              : 2
1-bit register
# Multiplexers
                              : 4
1-bit 2-to-1 multiplexer
______
______
             Advanced HDL Synthesis
______
```

```
______
Advanced HDL Synthesis Report
Macro Statistics
# Registers
                              : 2
Flip-Flops
                              : 2
# Multiplexers
                              : 4
1-bit 2-to-1 multiplexer
                              : 4
______
______
              Low Level Synthesis
______
List of register instances with asynchronous set and reset:
  Q in unit <mod JK FF>
  Qc in unit <mod JK FF>
Optimizing unit <mod JK FF> ...
Mapping all equations...
Building and optimizing final netlist ...
Found area constraint ratio of 100 (+ 5) on block mod JK FF, actual ratio is 0.
Final Macro Processing ...
______
Final Register Report
Macro Statistics
# Registers
                              : 4
Flip-Flops
                              : 4
______
______
               Partition Report
______
Partition Implementation Status
```

No Partitions were found in this design.

| BUFGP

| IBUF+BUFG

| 4

| 1

Asynchronous Control Signals Information:

-----

No asynchronous control signals found in this design

Timing Summary:

Clk

Pre

Speed Grade: -2

Minimum period: 1.683ns (Maximum Frequency: 594.177MHz)

Minimum input arrival time before clock: 3.596ns Maximum output required time after clock: 5.363ns Maximum combinational path delay: No path found

\_\_\_\_\_\_

Process "Synthesize - XST" completed successfully

# Question 11 - a

Design and simulate the behavioral model of a 4-bit UP/DOWN counter.

```
VHDL Module:
                        mod UpDownCounter.vhd
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
use IEEE.NUMERIC_STD.ALL;
entity mod UpDownCounter is
    Port ( Pre, Clr, Clk, UD : in STD LOGIC;
           Q : out STD LOGIC VECTOR (3 downto 0));
end mod UpDownCounter;
architecture Behavioral of mod_UpDownCounter is
      signal 0 : STD LOGIC VECTOR (3 downto 0);
begin
      process(Pre, Clr, Clk, UD)
      begin
            if
                        (Pre = '1') then 0 <= "1111";
            elsif (Clr = '1') then 0 <= "0000";
            elsif (rising_edge(Clk)) then
                  if(UD = '1') then 0 <= std logic vector(unsigned(0) + 1);</pre>
                                    0 <= std logic vector(unsigned(0) - 1);</pre>
                  else
                  end if;
            end if;
      end process;
      Q <= 0;
```

## RTL Schematic:

end Behavioral;



## 

```
LIBRARY ieee;
USE ieee.std logic 1164.ALL;
ENTITY tb UpDownCounter IS
END tb UpDownCounter;
ARCHITECTURE behavior OF tb UpDownCounter IS
    COMPONENT mod UpDownCounter
         PORT(
              Pre : IN std_logic;
              Clr : IN std_logic;
              Clk : IN std logic;
              UD : IN std logic;
              Q : OUT std_logic_vector(3 downto 0)
              );
   END COMPONENT;
   signal pre : std logic := '0';
  signal clr : std logic := '0';
  signal clk : std_logic := '0';
   signal ud : std_logic := '0';
  signal q : std_logic_vector(3 downto 0);
   constant clk_period : time := 100 ns;
BEGIN
   uut: mod_UpDownCounter PORT MAP (
         Pre => pre,
         Clr => clr,
         Clk
                => clk,
         UD
                => ud,
         Q
                 => q
        );
  clk_process: process
   begin
     clk <= '1';
     wait for clk period/2;
     clk <= '0';
     wait for clk period/2;
   end process;
```

```
set_process: process
   begin
      pre <= '0'; clr <= '1';
     wait for 100ns;
      pre <= '0'; clr <= '0';
     wait for 300ns;
      pre <= '1'; clr <= '0';
     wait for 100ns;
      pre <= '0'; clr <= '0';
     wait;
   end process;
   stm_process: process
   begin
      ud <= '1', '0' after 400ns, '1' after 800ns;
      wait;
   end process;
END;
```

## Simulation:



## Discussions:

D Flip-Flops are used as registers for the counter. A Multiplexer operation is used to choose the direction of the counter. Counter counts up for UD = '1' and down for UD = '0'.

# Question 11 - b

Modify the above counter program to make it a DECADE counter.

```
<u>VHDL Module:</u> mod_DecadeCounter.vhd
```

```
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
use IEEE.NUMERIC_STD.ALL;
entity mod DecadeCounter is
    Port ( Clr, Clk : in STD_LOGIC;
           Q : out STD LOGIC VECTOR (3 downto 0));
end mod DecadeCounter;
architecture Behavioral of mod_DecadeCounter is
      signal 0 : STD_LOGIC_VECTOR (3 downto 0);
begin
      process(Clr, Clk)
      begin
            if
                  (Clr = '1')
                                      then 0 <= "0000";
            elsif (rising_edge(Clk)) then
                        (0 /= "1001") then 0 <= std_logic_vector(unsigned(0) + 1);</pre>
                                            0 <= std logic vector(unsigned(0) + 7);</pre>
                  else
                  end if;
            end if;
      end process;
      Q \ll 0;
end Behavioral;
```

## RTL Schematic:



## VHDL Test Bench: tb\_DecadeCounter.vhd

```
LIBRARY ieee;
USE ieee.std logic 1164.ALL;
ENTITY tb DecadeCounter IS
END tb DecadeCounter;
ARCHITECTURE behavior OF tb_DecadeCounter IS
    COMPONENT mod DecadeCounter
          PORT(
               Clr : IN std logic;
               Clk : IN std logic;
               Q : OUT std logic vector(3 downto 0)
              );
    END COMPONENT;
   signal clr : std_logic := '0';
   signal clk : std logic := '0';
   signal q : std logic vector(3 downto 0);
   constant clk period : time := 80 ns;
BEGIN
   uut: mod_DecadeCounter PORT MAP (
          Clr => clr,
          Clk
                => clk,
          Q
              => q
        );
   clk_process: process
   begin
     clk <= '1';
     wait for clk_period/2;
     clk <= '0';
     wait for clk_period/2;
   end process;
   set_process: process
   begin
      clr <= '1'; wait for 50ns;</pre>
      clr <= '0'; wait;</pre>
   end process;
END;
```

# **Simulation:**



# **Discussions:**

Counter starts from 0 ("0000") till 9 ("1001") after which 6 ("0110") is added to the value which becomes 16 ("10000"). Since, the Counter is of 4-bits, the leading '1' is dropped and the value becomes 0 ("0000"), i.e. the initial value.