

Name :- Md Shahbaz Alam

Roll number :- 26

Stream :- CSE .

Enrollment number :- 12020009001123

Paper name :- Computer Organization & Architecture  
laboratory.

Subject Code :- PCC-CS492

Section :- ~~D~~ D

Assignment - I

# Assignment - I

CSE, D, 26

1

Write the VHDL programs to implement all the basic gates :-

(i)

OR Gate

Library IEEE;

use IEEE. std\_logic\_1164.all;

entity OR\_gate is

port (A: in std\_logic;

B: in std\_logic;

Y: out std\_logic;

end OR\_gate;

architecture orLogic of OR\_gate is

begin

Y <= A OR B;

end orLogic;

Simulation result



## (ii) AND Gate

Library IEEE;

use IEEE. std-logic-1164.all;

entity AND-gate is

port (A : in std-logic ;

B : in std-logic ;

Y : out std-logic );

end AND-gate ;

architecture ANDlogic of AND-gate is

begin

Y &lt;= A AND B ;

end ANDlogic ;

## (iii) Simulation result



(iii)  
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 NOT logic of NOT_gate is
begin
  Y <= not(A);
end NOT logic;

```

Simulation result



2. Write the VHDL programs to implement universal gate :-

i) NAND

```

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);
begin Architecture end
end NAND_gate;
architecture NAND logic of NAND_gate is
begin
Y <= A NAND B;
end NAND;

```

Simulation result



(??)

NOR

```

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 NOR logic of NOR\_gate is

begin

```
Y <= not(A OR B);
```

end NOR logic;

Simulation result

3) Write the VHDL programs to implement  
i) XOR

```
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);
```

```
begin
end XOR_gate;
architecture XORlogic of XOR_gate is
begin
  Y <= A XOR B;
```



(ii) XNOR

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 XNOR logic of XNOR-gate is

begin

$$Y \leq \text{not } (A \text{ XOR } B);$$

end XNOR logic;

## Simulation result



4 Design i) Half adder using VHDL

(i) Library IEEE;  
 use IEEE. std-logic-1164.all ;  
 entity half-adder is  
 port (A : in bit ;  
 B : in bit ;  
 Y : out bit ;  
 X : out bit ) ;  
 end half-adder ;  
 architecture ~~half-adder~~<sup>data</sup> of half-adder is  
 begin  
 $Y \leftarrow A \text{ XOR } B ;$   
 $X \leftarrow A \text{ AND } B ;$   
 end data ;

Simulation result



(ii) Full adder using VHDL

```

Library IEEE;
use IEEE.STD_LOGIC_1164.all;

entity full-adder is
port (A : in bit;
      B : in bit;
      C : in bit;
      Y : out bit;
      X : out bit);
end full-adder;

architecture data of full-adder is
begin
  Y <= A XOR B XOR C;
  X <= ((A AND B) OR (B AND C) OR (A AND C));
end data;

```

Simulation result



5) Design i) half Subtractor using VHDL.

```

library IEEE;
use IEEE. std_logic_1164.all;
entity half_subtractor is
port ( A : in bit;
       B : in bit;
       Y : out bit;
       X : out bit);
end half_subtractor;
architecture data of half_subtractor is
begin
    Y <= A XOR B;
    X <= ((not A) AND B);
end data;

```

Simulation result



## (91) Full Subtractor using VHDL

Library use IEEE;  
 IEEE · std\_logic\_1164.all;  
 entity full\_subtractor is  
 port (A : in bit;  
 B : in bit;  
 C : in bit;  
 Y : out bit;  
 X : out bit);

end full\_subtractor;

architecture data of half\_adder is

begin

$$Y \leftarrow A \text{ XOR } B \text{ XOR } C;$$

$$X \leftarrow ((B \text{ AND } C) \text{ OR } ((\text{not } A) \text{ AND } C) \text{ OR } ((\text{not } A) \text{ AND } B));$$

end data;

Simulation result



## Assignment -2.

1. Write the VHDL Programs to implement multiplexers: 2:1, 4:1, 8:1 and 16:1 (using when / if-else / vector / testbench)

→ • 2:1 mux

```
library IEEE;  
use IEEE.STD-LOGIC-1164.ALL;  
entity test_2to1mux is
```

```
Port ( a: in STD-LOGIC;  
      b: in STD-LOGIC;  
      s: in STD-LOGIC;  
      y: out STD-LOGIC);
```

```
end 2to1mux;
```

```
architecture Behavioral of 2to1mux is
```

```
begin  
  y <= a when s = '0' else  
        b;
```

```
end Behavioral;
```

Stimulation Waveform :-



## 4:1 Mux

```
library ieee;
use ieee std_logic_1164.all;
entity 4to1 mux is
Port (a,b,c,d, s1,s0 : in STD-LOGIC;
      y: out STD-LOGIC);
end 4 to 1-mux;
architecture Behavioral of 4to1-mux is
Signal s: std-logic-vector (1 downto 0);
begin
  S <= s1 & s0 ;
  with S select
    y <= a when "00",
              b when "01",
              c when "10",
              d when "11";
    'Z' when others;
end Behavioral;
```

Stimulation Waveform :-



## 8:1 mux

```
library ieee;
use ieee.std_logic_1164.all;
use ieee.std_logic_arith.all;
use ieee.std_logic_unsigned.all;
entity 8to1mux is
```

```
Port ( d: in std_logic_vector(7 downto 0);
       s: in std_logic_vector(2 downto 0);
       y: out std_logic);
```

```
end 8to1mux;
```

Architecture Behavioural of 8to1mux is  
begin

```
y <= d(0) when s = "000" else
              d(1) when s = "001" else
              d(2) when s = "010" else
              d(3) when s = "011" else
              d(4) when s = "100" else
              d(5) when s = "101" else
              d(6) when s = "110" else
              d(7);
```

```
end Behavioral;
```

## Stimulation Waveform :-



## 16: 1 mux

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

entity mux16 is
    Port (x: in std_logic_vector (15 downto 0);
          s: in std_logic_vector (3 downto 0);
          y: out std_logic);
end mux16;

architecture mux of mux16 is
begin
    process(x, s)
        begin
            if (s = "0000") then
                y <= x(0);
            else if (s = "0001") then
                y <= x(1);
            elsif (s = "0010") then
                y <= x(2);
            else if (s = "0011") then
                y <= x(3);
            else if (s = "0100") then
                y <= x(4);
            else if (s = "0101") then
                y <= x(5);
            end if;
        end;
    end process;
end;
```

```
elseif (s = "0110") then  
    y <= x(6);  
elseif (s = "0111") then  
    y <= x(7);  
elseif (s = "1000") then  
    y <= x(8);  
elseif (s = "1001") then  
    y <= x(9);  
elseif (s = "1010") then  
    y <= x(10);  
elseif (s = "1011") then  
    y <= x(11);  
elseif (s = "1100") then  
    y <= x(12);  
elseif (s = "1101") then  
    y <= x(13);  
elseif (s = "1110") then  
    y <= x(14);  
else  
    y <= x(15);  
end if;  
end process;  
end mux;
```

2. Write the VHDL program to implement de-multiplexers 1:2, 1:4, 2:8 and 1:16 (using when/if-else/vector testbench).

• 1:2 de-mux

```
library ieee;
use ieee.std_logic_1164.all;
use ieee.std_logic_arith.all;
use ieee.std_logic_unsigned.all;
entity Demux1to2 is
Port ( I,S : in std_logic;
       O1,O2 : out std_logic);
end Demux1to2;
```

```
architecture dataflow of Demux1to2 is
begin
  O1 <= I and (not S);
  O2 <= I and S;
end dataflow;
```

Stimulation Waveform:-



## 1:4 de-mux

library ieee;

use ieee.std\_logic\_1164.all

entity demux\_1to4 is

Port( F : in std\_logic;

SO, S1 : in std\_logic;

A, B, C, D : out std\_logic );

end demux\_1to4;

architecture bhv of demux\_1to4 is

begin

Process (F, SO, S1) is

begin

if ( SO = '0' and S1 = '0' ) then

A <= F;

else if ( SO = '1' and S1 = '0' ) then

B <= F;

else if ( SO = '0' and S1 = '1' ) then

C <= F;

else

D <= F;

end process;

end bhv;

## Stimulation Waveform:-



## 1:8 de-mux

library ieee;

use ieee.std\_logic\_1164.all

entity demux\_1to8 is

Port ( i: in std\_logic;

s: in std\_logic\_vector (0 to 2);

o: out std\_logic\_vector (0 to 7);

end demux\_1to8;

architecture demux\_arch of demux\_1x8 is

begin

process (i,s)

begin

o <= "00000000";

case s is

when "000" => o(0) <= i;

when "001" => o(1) <= i;

when "010" => o(2) <= i;

when "011" => o(3) <= i;

when "100" => o(4) <= i;

when "101" => o(5) <= i;

when "110" => o(6) <= i;

when "111" => o(7) <= i;

when others => o <= "00000000";

end case;

end process;

end demux\_arch;

## Stimulation Waveform:



## 1:16 de-mux

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

entity demux16 is
    port (x : in std_logic_vector;
          s : in std_logic(3 downto 0);
          y : out std_logic_vector(15 downto 0));
end demux16;
```

architecture demux of demux16 is

begin

process(x, s)

begin

case s is

when '0000' =>

y(0) <= x;

when '0001' =>

y(1) <= x;

when '0010' =>

y(2) <= x;

when '0011' =>

y(3) <= x;

when '0100' =>

y(4) <= x;

when '0101' =>

y(5) <= x;

when '0110' =>

y(6) <= x;

when '0111' =>

y(7) <= x;

when "1000" =>

$y(8) \leq x;$

when "1001" =>

$y(9) \leq x;$

when "1010" =>

$y(10) \leq x;$

when "1100" =>

$y(12) \leq x;$

when "1011" =>

$y(11) \leq x;$

when "1101" =>

$y(13) \leq x;$

when "1110" =>

$y(14) \leq x;$

when others =>

$y(15) \leq x;$

end case;

end process;

end demux;

3. Write the VHDL program to implement encoder circuit : 8:3 , 4:2 and parity encoder

### 8:3 encoder

```
library ieee;
use ieee. std_logic_1164.all;
entity encoder_8x3 is
Port (d: in std_logic vector (7 downto 0);
      a,b,c : out std_logic);
end encoder_8x3;
architecture encode_8x3_arch of encoder_8x3 is
begin
process(d)
begin
  a<= d(4) or d(5) or d(6) or d(7);
  b<= d(2) or d(3) or d(6) or d(7);
  c<= d(1) or d(3) or d(5) or d(7);
end process;
end encoder_arch;
```

### Stimulation Waveform:-



## 4:2 Encoder

```
library ieee;
use ieee.std_logic_1164.all;
entity encoder2 is
port ( a: in std_logic_vector (3downto0);
       b: out std_logic_vector (1downto0));
end encoder2;
architecture bhv of encoder2 is
begin
  b(0) <= a(1) or a(2);
  b(1) <= a(1) or a(3);
end bhv;
```

## Stimulation Waveform :-



## • Priority Encoder 4:2

library ieee;

use ieee.std\_logic\_1164.all;

entity priority\_encoder is

Port ( io : in std\_logic;

i1 : in std\_logic;

i2 : in std\_logic;

i3 : in std\_logic;

i2\_not : inout std\_logic;

out0 : out std\_logic;

out1 : out std\_logic;

out2 : out std\_logic);

end Priority\_encoder;

architecture Dataflow of priority\_encoder is

begin

process(i2)

begin

if i2 = '0' then

i2\_not <= '1';

else

i2\_not <= '0';

end if;

end process;

out2 <= io OR i1 OR i2 OR i3;

out1 <= (i1 AND i2\_not) OR i3;

out0 <= i2 OR i3;

end Dataflow;

## Stimulation Waveform:-



5. Write a VHDL program to implement magnitude comparator circuit.

```
library ieee;
use ieee.std_logic_1164.all;
entity mag-comp is
end mag-comp;

architecture beh of mag-comp is

component mag-comp
port ( a,b : in std_logic_vector (3 downto 0);
       ag, bg, eq : out std_logic);
end component;

signal a_s, b_s : std_logic_vector (3 downto 0);
signal ag_s, bg_s, eq_s : std_logic;

begin -- beh
    u1 : mag-comp port map (
        a => a_s,
        b => b_s,
        ag => ag_s,
        eq => eq_s,
        bg => bg_s);

    tst-p: process
    begin
        a_s <= "1111";
        b_s <= "0000";
        wait for 100 ns;
        a_s <= "1010";
        b_s <= "1100";
        wait for 100 ns;
        a_s <= "1001";
        b_s <= "0011";
    end process;

```

```
wait for 100 ns;  
a-s <= "1000";  
b-s <= "1000";  
wait for 100 ns;  
end process;  
end beh;
```

### Stimulation Waveform :-



6. Write the VHDL programs to implement parity generator and parity checker

• 8-bit parity generator

```
library ieee;
use ieee.std_logic_1164.all;
entity parity is
    Port ( data : in bit_vector (7 downto 0);
           even-p, odd-p : out bit);
end parity;
```

architecture parity-gen of parity is

```
signal temp : bit-vector (5 downto 0);
```

```
begin
```

```
temp(0) <= data(0) xor data(1);
```

```
temp(1) <= temp(0) xor data(2);
```

```
temp(2) <= temp(1) xor data(3);
```

```
temp(3) <= temp(2) xor data(4);
```

```
temp(4) <= temp(3) xor data(5);
```

```
temp(5) <= temp(4) xor data(6);
```

```
even-p <= temp(5) xor data(7);
```

```
odd-p <= not(temp(5) xor data(7));
```

```
end parity-gen;
```

Stimulation Waveform :-



## 8-bit parity checker

library ieee;

use ieee.std\_logic\_1164.all

entity parity\_chk is

Port ( data : in bit\_vector (7 downto 0);

    p : in bit;

    e : out bit);

end parity\_chk;

architecture parity\_arch of parity\_chk is

Signal temp : bit\_vector (6 downto 0);

begin

    temp(0) <= data(0) xor data(1);

    temp(1) <= temp(0) xor data(2);

    temp(2) <= temp(1) xor data(3);

    temp(3) <= temp(2) xor data(4);

    temp(4) <= temp(3) xor data(5);

    temp(5) <= temp(4) xor data(6);

    temp(6) <= temp(5) xor data(7);

    e <= p xor temp(6);

end parity\_arch;

## Simulation Waveform:-



7. Write the VHDL programs to implement flip flop units : SR, JK, D, T.

### SR Flip Flop

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

entity sr is

Port ( r, s, clk, reset: in std\_logic;  
q: out std\_logic );

end sr;

architecture Behavioral of ~~sr~~ sr is

signal p: std\_logic;

begin

process (clk, reset)

begin

if (reset = '1') then

p <= '0';

else if (clk'event and clk = '1') then

if (r = '0' and s = '0') then

p <= p;

elseif (r = '0' and s = '1') then

p <= '0';

else if (r = '1' and s = '0') then

p <= '1';

else if (r = '1' and s = '1') then

p <= '-';

end if;

end if;

q <= p;

end process;

end Behavioral;

## Stimulation Waveform :-



### JK Flip Flop

library ieee;

use ieee.std\_logic\_1164.all

entity jk is

Port ( j,k,clk,reset : in std\_logic;  
q : out STD\_LOGIC);

end jk;

architecture Behavioral of jk is

signal s: std\_logic;

begin

process (clk,reset)

begin

if (reset = '1') then

s <= '0';

else if (clk'event and clk = '1') then

```

if ( j='0' and K='0') then
    S<=S ;
else if ( j='0' and K='1') then
    S<='0';
else if ( j='1' and K='0') then
    S<='1';
else if ( j='1' and K='1') then
    S<=not S ;
end if;
end if;
end process;
end Behavioral;

```

### Stimulation Waveform :-



- D-flip flop

library IEEE;

use IEEE.STD\_LOGIC\_1164.all

entity dff is

Port (d, clk, reset : in STD\_LOGIC;  
q : out STD\_LOGIC);

end dff;

architecture Behavioral of dff is

begin

process (clk)

begin

if (clk'event and clk = '1') then

  if (reset = '1') then

    q <= '0';

  else

    q <= d;

  end if;

end if;

end process;

end Behavioral;

### Stimulation Waveform:-



- T-flip-flop

```
library ieee;
use ieee std_logic_1164.all
entity tff is
  Port ( t, clk, reset : in std_logic;
         q : out std_logic);
end tff;
architecture Behavioral of tff is
  Signals : std_logic;
begin
  process (clk, reset)
    begin
      if (reset = '1') then
        S <= '0';
      elsif (clk'event and clk = '1') then
        if (t = '1') then
          S <= not S;
        else
          S <= S;
        end if;
      end if;
    end process;
  end Behavioral;
```

## Stimulation Waveform:-

