

33) Write down VHDL code for following:

⇒ a) AND gate:

-- Header file declaration

library IEEE;

use IEEE.std\_logic\_1164.all;

-- Entity declaration

entity andgate is

port(A: in std\_logic; -- A input  
B: in std\_logic; -- B input  
Y: out std\_logic); -- Output

end andgate;

Architecture andlogic of andgate is

begin

Y <= A AND B;

end andlogic;

⇒ "--" is used to comment.

b) OR gate:

→ library IEEE;  
use IEEE.std\_logic\_1164.all

entity ~~OR~~ OrGate is

port(A: in std\_logic;  
B: in std\_logic;  
Y: out std\_logic);  
end OrGate;

architecture ~~OrGate~~ of orLogic of OrGate is  
begin

Y <= A OR B;  
end orLogic;

c) NOT gate:

→ library IEEE;

use IEEE.std\_logic\_1164.all;

entity not-gate is

port (A: in std\_logic;  
Y: out std\_logic);

end not-gate;

architecture notLogic of not-gate is

begin

Y <= not(A);  
end notLogic;

### d) NOR Gate:

→ Library IEEE;  
use IEEE.STD\_LOGIC\_1164.all;  
entity nor\_gate is  
port(A: in STD\_LOGIC;  
B: in STD\_LOGIC;  
Y: out STD\_LOGIC);  
end nor\_gate;  
architecture norlogic of nor\_gate is  
begin  
$$Y \leftarrow \text{not}(A \text{ OR } B)$$
  
end norlogic;

### e) NAND Gate:

→ Library IEEE;  
use IEEE.STD\_LOGIC\_1164.all;  
entity nand\_gate is  
port(A: in STD\_LOGIC;  
B: in STD\_LOGIC;  
Y: out STD\_LOGIC);  
end nand\_gate;  
architecture nandlogic of nand\_gate is  
begin  
$$Y \leftarrow \text{not}(A \text{ and } B);$$
  
end nandlogic;

### f) XOR Gate:

```

→ library IEEE;
use IEEE.std_logic_1164.all;
entity XOR_gate is
port(A: in std_logic;
     B: in std_logic;
     Y: out std_logic);
end XOR_gate;
architecture XORLogic of XOR_gate is
begin
    Y <= A XOR B;
end XORLogic;

```

### g) XNOR Gate:

~~Task~~

```

→ library IEEE;
use IEEE.std_logic_1164.all;
entity xnor_gate is
port(A: in std_logic;
     B: in std_logic;
     Y: out std_logic);
end xnor_gate;
architecture xnorLogic of xnor_gate is
begin
    Y <= not (A XOR B);
end xnorLogic;

```

### b) Half adder:

→ library IEEE;  
 use IEEE.std\_logic\_1164.all;  
 entity H-adder is  
 port (A : in std\_logic;  
 B : in std\_logic;  
 sum : out std\_logic;  
 carryout : out std\_logic);  
 end H-adder;  
 architecture flow of H-adder is  
 begin  
 sum  $\leftarrow A \text{ xor } B$ ;  
 carryout  $\leftarrow A \text{ and } B$ ;  
 end flow;

### c) full adder:

→ library IEEE;  
 use IEEE.std\_logic\_1164.all;  
 entity full\_adder is  
 port (A, B, carry\_in : in std\_logic;  
 sum, carry\_out : out std\_logic);  
 end full\_adder;

architecture flow of full-adder is  
 component half\_adder is

port (A, B : in std\_logic;  
 sum, carryout : out std\_logic);  
 end component;

component OR-gate is

port (A, B : in std\_logic;  
 Y : out std\_logic);

end component;

signal T1, T2, T3: std\_logic;

begin

half-adder1: half-adder port map

( A => A, B => B, sum => T1, carryout => T2);

half-adder2: half-adder port map

( A => T1, B => carry\_in, sum => sum,  
carryout => T3);

or-gate1: or-gate port map (A => T3, B => T2,

Y => carry\_out);

end flow;

Half subtractor:

library IEEE;

use IEEE.std\_logic\_1164.all;

entity half\_sub is

port (A,B: in std\_logic;  
diff, borrow: out std\_logic);

end half\_sub;

architecture flow of half\_sub is

begin

diff <= A xor B;

borrow <= not(A) and B;

end flow;

## k) Full Subtractors:

→ library IEEE;  
use IEEE.std\_logic\_1164.all;

entity full\_sub is

port(A, B, borrow\_in: in std\_logic;  
diff, borrow\_out: out std\_logic);

end full\_sub;

architecture flow of full\_sub is

component half\_sub is

port(A, B: in std\_logic;

diff, borrow: out std\_logic);

end component;

component or\_gate is

port(A, B: in std\_logic;

Y: out std\_logic);

end component;

signal T1, T2, T3: std\_logic;

begin

half\_sub1: half\_sub port map

(A  $\Rightarrow$  A, B  $\Rightarrow$  B, diff  $\Rightarrow$  T1, borrow  $\Rightarrow$  T2);

half\_sub2: half\_sub port map

(A  $\Rightarrow$  T1, B  $\Rightarrow$  borrow\_in, diff  $\Rightarrow$  diff,  
borrow  $\Rightarrow$  T3);

or\_gate1: or\_gate port map (A  $\Rightarrow$  T3, B  $\Rightarrow$  T2,  
Y  $\Rightarrow$  borrow\_out);

end flow;

# 1) 4x1 multiplexer;

→ library ieee;

use ieee.std\_logic\_1164.all;

use ieee.std\_logic\_arith.all;

entity mux\_tb

use ieee.std\_logic\_unsigned.all;

entity MUX\_SOURCE is

Port (S: in std\_logic\_vector (1 downto 0);

I: in std\_logic\_vector (3 downto 0);

Y: out std\_logic);

end MUX\_SOURCE

architecture Behavioral of MUX\_SOURCE is

begin

process (S, I)

begin

if (S <= "00") then

Y <= I(0);

elsif (S <= "01") then

Y <= I(1);

elsif (S <= "10") then

Y <= I(2);

else

Y <= I(3);

end if;

end process;

end Behavioral;

m) 1x4 demultiplexers:

→ library IEEE;  
use IEEE.std\_logic\_1164.all;

entity Demultiplexer1x4 is  
port (

A: in std\_logic;

S: in std\_logic\_vector(1 downto 0);

F, G, H, I: out std\_logic);

end entity Demultiplexer1x4;

architecture Behavioral of Demultiplexer1x4 is  
begin

with S select

F <= A when "00",

'0' when others;

with S select

G <= A when "01",

'0' when others;

with S select

H <= A when "10",

'0' when others;

with S select

I <= A when "11",

'0' when others;

with S select

I <= A when "11",

'0' when others;

end architecture Behavioral;

## 7) 8x3 encoder:

→ library ieee;  
use ieee.std\_logic\_1164.all;

entity Encoder8x3 is

port

A, B, C, D, E, F, G, H: in std\_logic;

Y: out std\_logic\_vector(2 downto 0);

end entity Encoder8x3;

architecture Behavioral of Encoder8x3 is

begin

Y <= "000" when A = '1' else

"001" when B = '1' else

"010" when C = '1' else

"011" when D = '1' else

"100" when E = '1' else

"101" when F = '1' else

"110" when G = '1' else

"111" when H = '1'

"000";

end architecture Behavioral;

# o) 3x8 decoder:

→ library ieee;

use ieee.std\_logic\_1164.all;

entity Decoder3x8 is  
port(

A, B, C: in std\_logic;

Y: Out std\_logic\_vector(7 down to 0));

end entity Decoder3x8;

architecture Behavioral of Decoder3x8 is  
begin

~~Y<="00000001"  
"00000010"  
"00000011"  
"00000100"  
"00000101"  
"00000110"  
"00000"  
"~~

~~Y<="00000001" when (A='0' and  
B='0' and C='0') else~~

~~"00000010" when(A='0'  
and B='0' and C='1') else~~

~~"00000100" when(A='0'  
and B='1' and C='0') else~~

"00001000" when(A='0' and B='1' and C='1') else  
"00010000" when(A='1' and B='0' and C='0') else  
"00100000" when(A='1' and B='0' and C='1') else  
"01000000" when(A='1' and B='1' and C='0') else  
"10000000" when(A='1' and B='1' and C='1') else  
"00000000";

end architecture Behavioral;

## p) SR flip flop:

→ library ieee;

use ieee.std\_logic\_1164.all;

entity SR\_FlipFlop is

port (

S, R: in std\_logic;

Q, Qbar: out std\_logic);

end entity SR\_FlipFlop;

architecture Behavioral of SR\_FlipFlop is

signal Q\_int, Qbar\_int: std\_logic;

begin

process (S, R)

begin

if (R = '1') then

Q\_int <= '0';

Qbar\_int <= '1';

elsif (S = '1') then

Q\_int <= '1';

Qbar\_int <= '0';

endif;

end process;

Q\_L = Q\_int;

Qbar\_L = Qbar\_int;

end architecture Behavioral;

## q) JK Flipflop:

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

```
entity JK_FF is  
PORT (J, K, CLOCK: in std_logic;  
Q, QB: out std_logic);  
end JK_FF;
```

Architecture behavioral of JK\_FF is

```
begin  
PROCESS (CLOCK)  
variable TMP: std_logic;  
begin  
if (CLOCK='1' and CLOCK'EVENT) then  
    if (J='0' and K='0') then  
        TMP := TMP;  
    elsif (J='1' and K='1') then  
        TMP := not TMP;  
    elsif (J='0' and K='1') then  
        TMP := '0';  
    else  
        TMP := '1';  
    end if;  
    end if;  
    Q := TMP;  
    QB := not TMP;  
end process;  
end behavioral;
```

x) T flip flop:

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

entity T_FF is
port (T: in std_logic;
      clock: in std_logic;
      Q: out std_logic);
end T_FF;
```

architecture behavioral of T\_FF is

```
signal tmp: std_logic;
begin
process (clock)
begin
  if Clock'event and clock = '1' then
    if T = '0' then
      tmp := tmp;
    elsif T = '1' then
      tmp := not (tmp);
    end if;
  end if;
  end process;
  Q < tmp;
end Behavioral;
```

### s) D FlipFlop:

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

entity D_FF is
PORT (D, CLOCK : in std_logic;
      Q : out std_logic);
end D_FF;

begin
process(CLOCK)
begin
  if(CLOCK='1' and CLOCK'EVENT) then
    Q<=D;
  end if;
end process;
end behavioral;
```

3u) Write down the VHDL code for MODULO 6 counter using a low level of abstraction.

→ library ieee;  
use ieee.std\_logic\_1164.all;

entity mod6 is  
port (V, CLK: in std\_logic;  
q2, q1, q0: buffer std\_logic;  
v2, v1, v0, c: out std\_logic);  
end mod 6;

architecture amod6 of mod6 is  
begin

cct\_mod6: process (q2, q1, q0, V, CLK)  
begin

if # rising edge(CLK) then  
 $q2 \leftarrow (q2 \text{ and } (\text{not } q1) \text{ and } (\text{not } q0)) \text{ or}$   
 $(q2 \text{ and } (\text{not } q1) \text{ and } (\text{not } V)) \text{ or}$   
 $((\text{not } q2) \text{ and } q1 \text{ and } q0 \text{ and } V);$

$q1 \leftarrow ((\text{not } q2) \text{ and } q1 \text{ and } (\text{not } q0)) \text{ or}$   
 $((\text{not } q2) \text{ and } q1 \text{ and } (\text{not } V)) \text{ or}$   
 $((\text{not } q2) \text{ and } (\text{not } q1) \text{ and } q0 \text{ and } V);$

$q0 \leftarrow ((\text{not } q2) \text{ and } (\text{not } q0) \text{ and } V) \text{ or}$   
 $((\text{not } q1) \text{ and } (\text{not } q0) \text{ and } V) \text{ or}$   
 $((\text{not } q2) \text{ and } q0 \text{ and } (\text{not } V)) \text{ or}$   
 $((\text{not } q1) \text{ and } q0 \text{ and } (\text{not } V));$

end if;

$v2 \leftarrow q2;$

```

    V1L= q3;
    V0Z = (q2 and q1) or q0;
    C L = not (q2 or q1 or q0);
end process (ct_mod 6);
end amod6;

```

35) Write a VHDL code for the following combinational circuits.

$$F = AB + A'B'$$

→ library ieee;

use ieee.std\_logic\_1164.all;

entity CombinationalCircuit1 is

port (

A; B: in std\_logic;

F: out std\_logic);

end entity CombinationalCircuit1;

architecture Behavioral of CombinationalCircuit1 is

begin if (A and B) or (not A and not B);

    F := A and B or (not A and not B);

- (6)  $F(x, y, z) = \sum(1, 3, 6, 7) \rightarrow$  sum of product  
 (7)  $F(x, y, z) = \sum(1, 3, 4, 6) \rightarrow$  sum of product  
 (8)  $F(x, y, z) = \prod(0, 2, 5, 7) \rightarrow$  product of sum

~~Solution:~~

(6)

| x | y | z | 00 | 01 | 11 | 10 |
|---|---|---|----|----|----|----|
| 0 |   |   |    | 11 | 11 |    |
| 1 |   |   |    |    | 11 | 11 |

$$F = x'z + xy$$

VHDL code:

```
→ library ieee;
use ieee.std_logic_1164.all;
```

```
entity CombinationalCircuit2 is
```

```
port (
```

```
    A, B : in std_logic; begin
```

```
    F : out std_logic); end
```

```
end entity CombinationalCircuit2;
```

architecture Behavioral of CombinationalCircuit2

is

begin

$F \leftarrow (\text{not } A \text{ and } B) \text{ or } (A \text{ and } B);$

end architecture Behavioral;

~~C) Soln~~

|   | 00 | 01 | 10 | 11 |
|---|----|----|----|----|
| 0 | 0  | 1  | 1  | 0  |
| 1 | 1  | 1  | 0  | 1  |

$$F = X'Z + XZ'$$

VHDL code:

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

```
entity circuit3 is
```

port

```
: A, B : in std_logic;
```

```
      F : out std_logic;
```

```
end entity circuit3;
```

architecture Behavioral of circuit3 is

begin

```
F := (not A and B) or (A and not B)
```

```
end architecture;
```

(A but B) is (A true if and only if

B is false) or (B true if and only if

Q) ~~SOI^n~~

| $x \setminus z$ | 00 | 01 | 11 | 10 |
|-----------------|----|----|----|----|
| 0               | 0  | -1 | 1  | 0  |
| 1               | 1  | 0  | 0  | 1  |

$$(x+z)(x'+z')$$

UHDL code:

→ library ieee;  
use ieee.std\_logic\_1164.all;

entity circuit4 is

port

(A, B: in std\_logic);  
F: out std\_logic);  
end entity circuit4;

architecture Behavioral of circuit4 is  
begin

F := (A or B) and (not A or not B);  
end architecture Behavioral;