# Міністерство освіти і науки України Національний університет «Львівська політехніка»

Кафедра ЕОМ



до лабораторної роботи № 3

з дисципліни «Моделювання комп'ютерних систем» на тему:

«Поведінковий опис цифрового автомата Перевірка роботи автомата за допомогою стенда Elbert V2 – Spartan 3A FPGA»

Варіант №18

Виконав: ст. гр. КІ-201 Луцик Н. І. Прийняв: ст. викладач каф. ЕОМ Козак Н. Б. **Мета роботи:** На базі стенда реалізувати цифровий автомат для обчислення значення виразів.

## Завдання:

| BAPIAHT(KI-201) | ВИРАЗ                         |
|-----------------|-------------------------------|
| 18              | ((OP1 + OP2 + 10) * 2) << OP2 |

# Задані числа:

 $OP1 = 0000\ 0001(2) = 1(10)$ 

 $OP2 = 0000\ 0010(2) = 2(10)$ 

**Результат** =  $0110\ 1000\ (2)\ = 104(10)$ 

# Виконання завдання:



Puc.1 – Top Level

### Файл ACC.vhd

library IEEE;

use IEEE.STD\_LOGIC\_1164.ALL;

entity ACC is

```
Port (WR: in STD_LOGIC;
     RESET: in STD_LOGIC;
     CLK: in STD_LOGIC;
     INPUT : in STD_LOGIC_VECTOR (7 downto 0);
     OUTPUT: out STD_LOGIC_VECTOR (7 downto 0));
end ACC;
architecture ACC_arch of ACC is
  signal DATA: STD_LOGIC_VECTOR (7 downto 0);
begin
  process (CLK)
  begin
    if rising_edge(CLK) then
      if RESET = '1' then
        DATA \ll (others \gg '0');
      elsif WR = '1' then
        DATA <= INPUT;
      end if;
    end if;
  end process;
  OUTPUT <= DATA;
end ACC_arch;
Файл ALU.vhd
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
use IEEE.NUMERIC_STD.ALL;
use IEEE.STD_LOGIC_UNSIGNED.ALL;
```

```
Port ( A : in STD_LOGIC_VECTOR(7 downto 0);
      B: in STD_LOGIC_VECTOR(7 downto 0);
      OP: in STD_LOGIC_VECTOR(1 downto 0);
      OUTPUT: out STD_LOGIC_VECTOR(7 downto 0);
                    OVERFLOW: out STD_LOGIC);
end ALU;
architecture ALU_Behavioral of ALU is
      signal ALUR: STD_LOGIC_VECTOR(15 downto 0) := (others => '0');
      signal Carry: STD_LOGIC := '0';
begin
      process(A, B, OP)
      begin
             case (OP) is
                   when "01" \Rightarrow ALUR \iff ("00000000" & A) + ("00000000" & B);
                   when "10" => ALUR <=
std_logic_vector(to_unsigned((to_integer(unsigned(("00000000" & A))) *
to_integer(unsigned(("00000000" & B)))),16));
                   when "11" => ALUR <= std_logic_vector(unsigned(("00000000" & A)) sll
to_integer(unsigned(B))) and x"00FF";
                   when others \Rightarrow ALUR \iff ("00000000" & B);
             end case:
      end process;
      OUTPUT <= ALUR(7 downto 0);
      OVERFLOW <= ALUR(8) OR ALUR(9) OR ALUR(10) OR ALUR(11) OR ALUR(12)
OR ALUR(13) OR ALUR(14) OR ALUR(15);
end ALU_Behavioral;
Файл MUX.vhd
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
```

entity ALU is

```
entity MUX is
      PORT(
            SEL: in STD_LOGIC_VECTOR(1 downto 0);
            CONST: in STD_LOGIC_VECTOR(7 downto 0);
            --CONST1: in STD_LOGIC_VECTOR()
            DATA_IN0: in STD_LOGIC_VECTOR(7 downto 0);
            DATA_IN1: in STD_LOGIC_VECTOR(7 downto 0);
            OUTPUT: out STD_LOGIC_VECTOR(7 downto 0)
      );
end MUX;
architecture Behavioral of MUX is
begin
      process (SEL, DATA_IN0, DATA_IN1, CONST)
      begin
            if (SEL = "00") then
                  OUTPUT <= DATA_IN0;
            elsif (SEL = "01") then
                  OUTPUT <= DATA_IN1;
            else
                  OUTPUT <= CONST;
            end if:
      end process;
end Behavioral;
Файл RAM.vhd
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
use IEEE.NUMERIC_STD.ALL;
use IEEE.STD_LOGIC_UNSIGNED.ALL;
```

```
entity RAM is
      port(
                  WR: IN STD_LOGIC;
                  ADDR: IN STD_LOGIC_VECTOR(1 DOWNTO 0);
                  DATA: IN STD_LOGIC_VECTOR(7 DOWNTO 0);
                  CLOCK: IN STD_LOGIC;
                  OUTPUT: OUT STD_LOGIC_VECTOR(7 DOWNTO 0)
                  );
end RAM;
architecture RAM_arch of RAM is
      type ram_type is array (3 downto 0) of STD_LOGIC_VECTOR(7 downto 0);
      signal UNIT : ram_type;
begin
      process(ADDR, CLOCK, UNIT)
      begin
            if(rising_edge(CLOCK)) then
                  if (WR = '1') then
                        UNIT(conv_integer(ADDR)) <= DATA;</pre>
                  end if;
            end if;
            OUTPUT <= UNIT(conv_integer(ADDR));
      end process;
end RAM_arch;
Файл SEG_DECODER.vhd
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
use IEEE.STD_LOGIC_ARITH.ALL;
use IEEE.STD_LOGIC_UNSIGNED.ALL;
```

```
entity SEG_DECODER is
     port( CLOCK : IN STD_LOGIC;
                 RESET: IN STD_LOGIC;
                 ACC_DATA_OUT_BUS: IN STD_LOGIC_VECTOR(7 DOWNTO 0);
                 COMM_ONES
                                              : OUT STD_LOGIC;
                 COMM_DECS
                                        : OUT STD_LOGIC;
                 COMM_HUNDREDS : OUT STD_LOGIC;
                 SEG_A
                             : OUT STD_LOGIC;
                 SEG_B
                             : OUT STD_LOGIC;
                 SEG_C
                             : OUT STD_LOGIC;
                 SEG_D
                             : OUT STD_LOGIC;
                 SEG E
                             : OUT STD_LOGIC;
                 SEG_F : OUT STD_LOGIC;
                 SEG G
                             : OUT STD_LOGIC;
                 DP
                             : OUT STD_LOGIC);
end SEG_DECODER;
architecture Behavioral of SEG_DECODER is
      signal ONES_BUS: STD_LOGIC_VECTOR(3 downto 0) := "0000";
      signal DECS_BUS : STD_LOGIC_VECTOR(3 downto 0) := "0001";
     signal HONDREDS_BUS: STD_LOGIC_VECTOR(3 downto 0) := "0000";
begin
     BIN_TO_BCD : process (ACC_DATA_OUT_BUS)
    variable hex_src : STD_LOGIC_VECTOR(7 downto 0) ;
    variable bcd : STD_LOGIC_VECTOR(11 downto 0);
  begin
    bcd
           := (others => '0');
           := ACC_DATA_OUT_BUS;
    hex_src
    for i in hex_src'range loop
      if bcd(3 downto 0) > "0100" then
```

```
bcd(3 downto 0) := bcd(3 downto 0) + "0011";
    end if;
    if bcd(7 downto 4) > "0100" then
      bcd(7 downto 4) := bcd(7 downto 4) + "0011";
    end if;
    if bcd(11 downto 8) > "0100" then
      bcd(11 downto 8) := bcd(11 downto 8) + "0011";
    end if;
    bcd := bcd(10 downto 0) & hex_src(hex_src'left); -- shift bcd + 1 new entry
    hex_src := hex_src(hex_src'left - 1 downto hex_src'right) & '0'; -- shift src + pad with 0
  end loop;
  HONDREDS_BUS
                      <= bcd (11 downto 8);
  DECS_BUS
                 <= bcd (7 downto 4);
  ONES_BUS
                <= bcd (3 downto 0);
end process BIN_TO_BCD;
    INDICATE : process(CLOCK)
          type DIGIT_TYPE is (ONES, DECS, HUNDREDS);
          variable CUR DIGIT : DIGIT TYPE := ONES;
          variable DIGIT_VAL
                                     : STD_LOGIC_VECTOR(3 downto 0) := "0000";
                                     : STD_LOGIC_VECTOR(6 downto 0) := "0000000";
          variable DIGIT_CTRL
          variable COMMONS_CTRL: STD_LOGIC_VECTOR(2 downto 0) := "000";
          begin
                 if (rising_edge(CLOCK)) then
                       if(RESET = '0') then
                              case CUR_DIGIT is
                                    when ONES =>
                                            DIGIT_VAL := ONES_BUS;
```

```
COMMONS CTRL := "001";
      when DECS =>
             DIGIT_VAL := DECS_BUS;
            CUR_DIGIT := HUNDREDS;
             COMMONS_CTRL := "010";
     when HUNDREDS =>
            DIGIT_VAL := HONDREDS_BUS;
            CUR_DIGIT := ONES;
             COMMONS_CTRL := "100";
     when others =>
             DIGIT_VAL := ONES_BUS;
            CUR_DIGIT := ONES;
            COMMONS CTRL := "000";
end case;
case DIGIT_VAL is
                       --abcdefg
     when "0000" => DIGIT_CTRL := "1111110";
     when "0001" => DIGIT_CTRL := "0110000";
      when "0010" => DIGIT\_CTRL := "1101101";
      when "0011" => DIGIT_CTRL := "1111001";
      when "0100" => DIGIT_CTRL := "0110011";
     when "0101" => DIGIT CTRL := "1011011";
     when "0110" => DIGIT_CTRL := "1011111";
     when "0111" => DIGIT_CTRL := "1110000";
      when "1000" => DIGIT CTRL := "11111111";
      when "1001" => DIGIT_CTRL := "1111011";
      when others => DIGIT_CTRL := "0000000";
end case;
DIGIT_VAL := ONES_BUS;
CUR_DIGIT := ONES;
COMMONS_CTRL := "000";
```

else

CUR DIGIT := DECS;

```
end if;
```

end Behavioral;

Файл CPU.vhd

library IEEE;

entity CPU is

```
COMM_ONES <= not COMMONS_CTRL(0);
                      COMM_DECS
                                        <= not COMMONS_CTRL(1);
                      COMM_HUNDREDS <= not COMMONS_CTRL(2);
                      SEG_A <= not DIGIT_CTRL(6);
                      SEG_B <= not DIGIT_CTRL(5);
                      SEG_C <= not DIGIT_CTRL(4);
                      SEG_D <= not DIGIT_CTRL(3);
                      SEG_E <= not DIGIT_CTRL(2);</pre>
                      SEG_F <= not DIGIT_CTRL(1);
                      SEG_G <= not DIGIT_CTRL(0);
                      DP
                           <= '1';
                 end if;
     end process INDICATE;
use IEEE.STD_LOGIC_1164.ALL;
     port( ENTER_OP1 : IN STD_LOGIC;
                 ENTER_OP2 : IN STD_LOGIC;
                 CALCULATE: IN STD_LOGIC;
                 RESET: IN STD_LOGIC;
                 CLOCK: IN STD_LOGIC;
                 RAM_WR: OUT STD_LOGIC;
                 RAM_ADDR: OUT STD_LOGIC_VECTOR(1 DOWNTO 0);
```

```
CONST: OUT STD LOGIC VECTOR(7 DOWNTO 0);
                 ACC_WR: OUT STD_LOGIC;
                 ACC_RST: OUT STD_LOGIC;
                 IN_SEL : OUT STD_LOGIC_VECTOR(1 downto 0);
                 OP: OUT STD_LOGIC_VECTOR(1 DOWNTO 0));
end CPU;
architecture CPU_arch of CPU is
type STATE_TYPE is (RST, IDLE, LOAD_OP1, LOAD_OP2, RUN_CALC0, RUN_CALC1,
RUN_CALC2, RUN_CALC3, RUN_CALC4, FINISH);
signal CUR_STATE : STATE_TYPE;
signal NEXT_STATE: STATE_TYPE;
begin
     SYNC_PROC: process (CLOCK)
 begin
   if (rising_edge(CLOCK)) then
    if (RESET = '1') then
      CUR STATE <= RST;
    else
      CUR_STATE <= NEXT_STATE;
    end if;
   end if;
 end process;
     NEXT_STATE_DECODE: process (CLOCK, ENTER_OP1, ENTER_OP2, CALCULATE)
 begin
   NEXT_STATE <= CUR_STATE;</pre>
           case(CUR_STATE) is
                 when RST =>
```

```
NEXT STATE <= IDLE;
      when IDLE
                         =>
            if (ENTER\_OP1 = '1') then
                  NEXT_STATE <= LOAD_OP1;</pre>
            elsif (ENTER_OP2 = '1') then
                  NEXT_STATE <= LOAD_OP2;</pre>
            elsif (CALCULATE = '1') then
                  NEXT_STATE <= RUN_CALCO;</pre>
            else
                  NEXT_STATE <= IDLE;</pre>
            end if;
      when LOAD OP1 =>
            NEXT_STATE <= IDLE;</pre>
      when LOAD_OP2 =>
            NEXT_STATE <= IDLE;</pre>
      when RUN_CALC0 =>
            NEXT_STATE <= RUN_CALC1;</pre>
      when RUN_CALC1 =>
            NEXT_STATE <= RUN_CALC2;
      when RUN_CALC2 =>
            NEXT_STATE <= RUN_CALC3;</pre>
      when RUN_CALC3 =>
            NEXT_STATE <= RUN_CALC4;</pre>
      when RUN_CALC4 =>
            NEXT_STATE <= FINISH;
      when FINISH =>
            NEXT_STATE <= FINISH;</pre>
      when others
            NEXT_STATE <= IDLE;</pre>
end case;
```

end process;

```
case (CUR_STATE) is
      when RST =>
            RAM_WR <= '0';
            RAM_ADDR <= "00";
            CONST <= "00000000";
            ACC_WR <= '0';
            ACC_RST <= '1';
            IN_SEL <= "00";
            OP \le "00";
      when LOAD_OP1 =>
            RAM_WR <= '1';
            RAM_ADDR <= "00";
            CONST <= "00000000";
            ACC_WR <= '0';
            ACC_RST <= '1';
            IN_SEL <= "00";
            OP <= "00";
      when LOAD_OP2 =>
            RAM_WR <= '1';
            RAM\_ADDR \le "01";
            CONST <= "00000000";
            ACC_WR <= '0';
            ACC_RST <= '1';
            IN_SEL <= "00";
            OP <= "00";
      when RUN_CALC0 =>
            RAM_WR \le 0';
            RAM_ADDR <= "00";
            CONST <= "00000000";
            ACC_WR <= '1';
            ACC_RST <= '0';
            IN_SEL <= "01";
```

```
OP \le "00";
when RUN_CALC1 =>
      RAM_WR <= '0';
     RAM_ADDR <= "01";
      CONST <= "00000000";
      ACC_WR <= '1';
      ACC_RST <= '0';
     IN_SEL <= "01";
      OP <= "01";
when RUN_CALC2 =>
     RAM_WR <= '0';
     RAM_ADDR <= "01";
      CONST <= "00001010";
     ACC_WR <= '1';
      ACC_RST <= '0';
     IN_SEL <= "10";
      OP <= "01";
when RUN_CALC3 =>
      RAM_WR <= '0';
      RAM_ADDR <= "01";
      CONST <= "00000010";
      ACC_WR <= '1';
      ACC_RST <= '0';
      IN_SEL <= "10";
      OP <= "10";
when RUN_CALC4 =>
      RAM_WR <= '0';
      RAM\_ADDR \le "01";
      CONST <= "00000000";
      ACC_WR <= '1';
      ACC_RST <= '0';
      IN_SEL <= "01";
      OP <= "11";
```

```
when IDLE =>
                        RAM_WR <= '0';
                        RAM_ADDR <= "00";
                         CONST <= "00000000";
                         ACC_WR <= '0';
                         ACC_RST <= '0';
                        IN_SEL <= "00";
                         OP <= "00";
                  when others =>
                         RAM_WR <= '0';
                        RAM_ADDR <= "00";
                         CONST <= "00000000";
                         ACC_WR <= '0';
                         ACC_RST <= '0';
                        IN_SEL <= "00";
                        OP <= "00";
            end case;
 end process;
end CPU_arch;
```

# Часові діаграми:



Рис. 2 – Часова діаграма АСС

| Name            | Value    |          | 1 ps     | 2 ps | 3 ps  | 4 ps | 5 ps     | 6 ps | 7 ps | 8 ps     | 9 ps |
|-----------------|----------|----------|----------|------|-------|------|----------|------|------|----------|------|
| > 😽 a[7:0]      | 11111111 | 00000000 |          | 0000 | 1111  |      | 1000     | 1111 | Х    | 11111111 |      |
| ⊳ 😽 b[7:0]      | 00000001 | 00000000 |          | 0111 | 10000 |      | 1111     | 0000 | Х    | 00000001 |      |
| > = op[1:0]     | 01       |          | 00       |      | X     |      |          | 01   |      |          |      |
| > = output[7:0] | 00000000 | 11111111 | 10000000 |      | 0111  | 1111 | 01111111 |      | X    | 00000000 |      |
| U overflow      | 1        |          |          |      |       |      |          |      |      |          |      |
|                 |          |          |          |      |       |      |          |      |      |          |      |
|                 |          |          |          |      |       |      |          |      |      |          |      |
|                 |          |          |          |      |       |      |          |      |      |          |      |
|                 |          |          |          |      |       |      |          |      |      |          |      |

Рис. 3 – Часова діаграма ALU



Рис. 4 – Часова діаграма МИХ



Puc. 5 – Часова діаграма RAM



Рис. 6 – Часова діаграма SEG\_DECODER



Puc. 7 – Часова діаграма TopLevel

### Файл TopLevelTest.vhd

LIBRARY ieee;

USE ieee.std\_logic\_1164.ALL;

USE ieee.numeric\_std.ALL;

LIBRARY UNISIM;

USE UNISIM. Vcomponents. ALL;

ENTITY TopLevel\_TopLevel\_sch\_tb IS

END TopLevel\_sch\_tb;

ARCHITECTURE behavioral OF TopLevel\_TopLevel\_sch\_tb IS

#### COMPONENT TopLevel

PORT( CLOCK : IN STD\_LOGIC;

RESET: IN STD\_LOGIC;

ENTER\_OP1 : IN STD\_LOGIC;

ENTER\_OP2 : IN STD\_LOGIC;

CALCULATE: IN STD\_LOGIC;

DATA\_IN : IN STD\_LOGIC\_VECTOR (7 DOWNTO 0);

COMMON\_0\_OUT : OUT STD\_LOGIC;

COMMON\_1\_OUT : OUT STD\_LOGIC;

COMMON\_2\_OUT : OUT STD\_LOGIC;

TEST: OUT STD\_LOGIC\_VECTOR(7 downto 0);

A\_OUT: OUT STD\_LOGIC;

B\_OUT: OUT STD\_LOGIC;

C\_OUT: OUT STD\_LOGIC;

D\_OUT: OUT STD\_LOGIC;

E\_OUT: OUT STD\_LOGIC;

F\_OUT: OUT STD\_LOGIC;

G\_OUT: OUT STD\_LOGIC;

DP\_OUT : OUT STD\_LOGIC;

RAMOUT: OUT STD\_LOGIC\_VECTOR(7 downto 0);

ALUOUT: OUT STD\_LOGIC\_VECTOR(7 downto 0);

RAMA: OUT STD\_LOGIC\_VECTOR(1 downto 0);

RAMWR: OUT STD\_LOGIC;

OVERFLOW: OUT STD\_LOGIC);

END COMPONENT;

SIGNAL CLOCK : STD\_LOGIC := '0';

SIGNAL RESET : STD\_LOGIC;

SIGNAL ENTER\_OP1 : STD\_LOGIC;

SIGNAL ENTER\_OP2 : STD\_LOGIC;

SIGNAL CALCULATE : STD\_LOGIC;

SIGNAL DATA\_IN : STD\_LOGIC\_VECTOR (7 DOWNTO 0);

SIGNAL COMMON\_0\_OUT : STD\_LOGIC;

SIGNAL COMMON\_1\_OUT : STD\_LOGIC;

SIGNAL COMMON\_2\_OUT : STD\_LOGIC;

SIGNAL A\_OUT : STD\_LOGIC;

SIGNAL B\_OUT : STD\_LOGIC;

SIGNAL C\_OUT : STD\_LOGIC;

SIGNAL D\_OUT : STD\_LOGIC;

SIGNAL E\_OUT : STD\_LOGIC;

SIGNAL F\_OUT : STD\_LOGIC;

SIGNAL G\_OUT : STD\_LOGIC;

SIGNAL DP\_OUT: STD\_LOGIC;

SIGNAL OVERFLOW : STD\_LOGIC;

SIGNAL TEST: STD\_LOGIC\_VECTOR(7 downto 0);

SIGNAL TEST2: STD\_LOGIC\_VECTOR(7 downto 0); signal RAMOUT: STD\_LOGIC\_VECTOR(7 downto 0); signal ALUOUT: STD\_LOGIC\_VECTOR(7 downto 0); signal RAMA: STD\_LOGIC\_VECTOR(1 downto 0); signal RAMWR: STD\_LOGIC;

constant CLKP: time := 12ms;

#### **BEGIN**

UUT: TopLevel PORT MAP( CLOCK => CLOCK, RESET => RESET, ENTER\_OP1 => ENTER\_OP1, ENTER\_OP2 => ENTER\_OP2, CALCULATE => CALCULATE,  $DATA_IN \Rightarrow DATA_IN$ , COMMON\_0\_OUT => COMMON\_0\_OUT, COMMON\_1\_OUT => COMMON\_1\_OUT, COMMON\_2\_OUT => COMMON\_2\_OUT,  $A_OUT => A_OUT$ , B OUT => B OUT, $C_{OUT} \Rightarrow C_{OUT}$  $D_OUT \Rightarrow D_OUT$ ,  $E OUT \Rightarrow E OUT$ ,  $F_OUT \Rightarrow F_OUT$ ,  $G_OUT => G_OUT$ ,  $DP_OUT \Rightarrow DP_OUT$ , OVERFLOW => OVERFLOW, TEST => TEST,

RAMOUT => RAMOUT,

ALUOUT => ALUOUT,

```
RAMA \Rightarrow RAMA,
            RAMWR => RAMWR
);
     CLOCK_process: process
begin
            CLOCK <= '0';
            wait for 83ns;
            CLOCK <= '1';
            wait for 83ns;
end process;
tb: PROCESS
BEGIN
            lp1: for i in 1 to 1 loop
                   lp2: for j in 2 to 2 loop
                          TEST2 \leq std_logic_vector(to_unsigned((i + j + 10) * 2, 8) sll j);
                          ENTER_OP1 <= '1';
                          ENTER_OP2 <= '1';
                          CALCULATE <= '1';
                          DATA_IN <= (others => '0');
                          RESET <= '0';
                          wait for CLKP;
                          RESET <= '1';
                          wait for CLKP;
                          DATA_IN <= std_logic_vector(to_unsigned(i, 8));
                          ENTER_OP1 <= '0';
                          wait for CLKP;
                          ENTER_OP1 <= '1';
                          wait for CLKP;
                          DATA_IN <= std_logic_vector(to_unsigned(j, 8));
                          ENTER_OP2 <= '0';
```

```
wait for CLKP;
ENTER_OP2 <= '1';
wait for CLKP;
CALCULATE <= '0';
wait for CLKP* 7;
assert TEST = TEST2 severity FAILURE;
wait for CLKP;</pre>
```

end loop;

end loop;

WAIT;

END PROCESS;

END;



Рис.8 – 7-сегментний індикатор

Переглянемо часову діаграму 7seg decoder.

Бачимо, що для вхідного числа 0110 1000 (2) = 104(10)

Ми отримуємо такі значення (якщо значення не вказане, вважаюмо його за одиницю):

 $COMM_ONES = 0$ : F, G, B, C = 0, що відповідає числу 4

 $COMM_DECS = 0$ : A, B, C, D, E, F = 0, що відповідає числу 0

 $COMM_HUNDREDS = 0$ : В, C = 0, що відповідає числу 1

Отримуємо значення 104, що збігається з даним йому.



Рис.9 – Успішна прошивка

**Висновок:** Виконуючи дану лабораторну роботу я навчився реалізовувати цифровий автомат для обчислення значення виразів використовуючи засоби VHDL.