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

Кафедра ЕОМ



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

3 дисципліни "Моделювання комп'ютерних систем"

На тему: "Поведінковий опис цифрового автомата. Перевірка роботи автомата за допомогою стенда"

### Варіант – 12

Виконав: ст. гр. КІ-201 Костюк І. В. Прийняв: Козак Н. Б.

Львів 2023

**Мета роботи :** На базі стенда Elbert V2 — Spartan 3A FPGA, реалізувати цифровий автомат для обчислення значення виразу дотримуючись наступних вимог:

- 1. Функціонал пристрою повинен бути реалізований згідно отриманого варіанту завдання. Дивись розділ ЗАВДАННЯ:.
- 2. Пристрій повинен бути ітераційним (АЛП (ALU) повинен виконувати за один такт одну операцію), та реалізованим згідно наступної структурної схеми (Малюнок 1):



Малюнок 1 - Структурна схема автомата.

12

((OP1 xor OP2) + OP2) - 1

```
Виконання роботи:
Файл CU.vhd:
-- Company:
-- Engineer:
-- Create Date:
               16:27:31 04/27/2023
-- Design Name:
-- Module Name:
                 CU - Behavioral
-- Project Name:
-- Target Devices:
-- Tool versions:
-- Description:
-- Dependencies:
-- Revision:
-- Revision 0.01 - File Created
-- Additional Comments:
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;
use IEEE.STD_LOGIC_UNSIGNED.ALL;
-- Uncomment the following library declaration if instantiating
-- any Xilinx primitives in this code.
--library UNISIM;
--use UNISIM.VComponents.all;
entity CU_intf is
     port(CLOCK
                            : IN STD_LOGIC;
            RESET
                            : IN STD_LOGIC;
            ENTER_OP1
                            : IN STD_LOGIC;
            ENTER_OP2
                            : IN STD_LOGIC;
            CALCULATE : IN STD_LOGIC;
```

RAM\_WR: OUT STD\_LOGIC;

RAM\_ADDR\_BUS : OUT STD\_LOGIC\_VECTOR(1 downto 0);

```
CONSTANT_BUS
                                  : OUT STD_LOGIC_VECTOR(7 downto 0):=
"00000001":
             ACC_WR : OUT STD_LOGIC;
            ACC_RST: OUT STD_LOGIC;
            IN SEL: OUT STD LOGIC VECTOR(1 downto 0);
            OP CODE BUS: OUT STD LOGIC VECTOR(1 downto 0)
end CU intf;
architecture CU arch of CU intf is
type cu_state_type is (cu_rst, cu_idle, cu_load_op1, cu_load_op2, cu_run_calc0,
cu_run_calc1, cu_run_calc2, cu_run_calc3, cu_finish);
signal cu_cur_state : cu_state_type;
signal cu_next_state : cu_state_type;
begin
CONSTANT_BUS
                        <= "00000001":
CU_SYNC_PROC: process (CLOCK)
 begin
   if (rising_edge(CLOCK)) then
     if (RESET = '1') then
       cu_cur_state <= cu_rst;</pre>
     else
       cu_cur_state <= cu_next_state;
     end if;
   end if;
 end process;
      CUNEXT_STATE_DECODE: process (cu_cur_state, ENTER_OP1,
ENTER OP2, CALCULATE)
 begin
   --declare default state for next state to avoid latches
   cu_next_state <= cu_cur_state; --default is to stay in current state
   --insert statements to decode next state
   --below is a simple example
           case(cu cur state) is
                 when cu_rst
                       cu next state <= cu idle;
                 when cu idle
                       if (ENTER\_OP1 = '1') then
                             cu_next_state <= cu_load_op1;
                       elsif (ENTER_OP2 = '1') then
                             cu_next_state <= cu_load_op2;</pre>
                       elsif (CALCULATE = '1') then
                             cu_next_state <= cu_run_calc0;</pre>
                       else
```

```
cu_next_state <= cu_idle;
                    end if;
               when cu_load_op1
                    cu_next_state <= cu_idle;
               when cu_load_op2
                    cu_next_state <= cu_idle;
               when cu_run_calc0 =>
                    cu_next_state <= cu_run_calc1;</pre>
               when cu_run_calc1 =>
                    cu_next_state <= cu_run_calc2;</pre>
               when cu_run_calc2 =>
                    cu_next_state <= cu_run_calc3;</pre>
               when cu_run_calc3 =>
                    cu_next_state <= cu_finish;
               when cu_finish
                               =>
                    cu_next_state <= cu_finish;
               when others
                    cu_next_state <= cu_idle;
         end case;
end process;
CU_OUTPUT_DECODE: process (cu_cur_state)
begin
         case(cu_cur_state) is
               when cu_rst
                    IN_SEL
                                           <= "00";
                    OP_CODE_BUS <= "00";
                                           <= "00";
                    RAM_ADDR_BUS
                    RAM_WR
                                           <= '0';
                                           <= '1';
                    ACC_RST
                    ACC_WR
                                           <= '0';
               when cu_idle
                                     =>
                                           <= "00";
                    IN_SEL
                    OP CODE BUS <= "00";
                                           <= "00";
                    RAM_ADDR_BUS
                    RAM WR
                                           <= '0':
                    ACC_RST
                                           = '0':
                    ACC WR
                                           <= '0';
               when cu_load_op1
                                    =>
                    IN_SEL
                                           <= "00";
                    OP_CODE_BUS <= "00";
                                           <= "00";
                    RAM_ADDR_BUS
                    RAM_WR
                                           <= '1';
                                           <= '0';
                    ACC_RST
                    ACC_WR
                                           <= '1';
               when cu_load_op2
                                   =>
```

```
IN_SEL
                          <= "00";
     OP\_CODE\_BUS <= "00";
                          <= "01";
     RAM ADDR BUS
     RAM_WR
                          <= '1';
     ACC_RST
                          <= '0':
     ACC_WR
                          <= '1';
when cu_run_calc0 =>
     IN_SEL
                          <= "01";
     OP_CODE_BUS <= "00";
     RAM ADDR BUS
                          <= "00";
     RAM_WR
                          <= '0';
     ACC_RST
                          <= '0';
     ACC_WR
                          <= '1';
when cu_run_calc1 =>
     IN_SEL
                          <= "01";
     OP_CODE_BUS <= "11";
     RAM ADDR BUS
                          <= "01";
     RAM_WR
                          <= '0':
     ACC_RST
                          <= '0';
     ACC_WR
                          <= '1':
when cu_run_calc2 =>
     IN SEL
                          <= "01";
     OP_CODE_BUS <= "01";
     RAM ADDR BUS
                          <= "01";
     RAM_WR
                          <= '0';
     ACC_RST
                          <= '0';
     ACC_WR
                          <= '1';
when cu_run_calc3 =>
     IN SEL
                          <= "10";
     OP_CODE_BUS <= "10";
                         <= "00";
     RAM_ADDR_BUS
     RAM_WR
                          <= '0';
     ACC_RST
                          <= '0':
     ACC_WR
                          <= '1';
when cu_finish
               =>
                          <= "00";
     IN_SEL
     OP CODE BUS <= "00";
                          <= "00";
     RAM ADDR BUS
     RAM WR
                          <= '0';
     ACC_RST
                          <= '0';
     ACC_WR
                          <= '0':
when others
                    =>
                          <= "00";
     IN_SEL
     OP\_CODE\_BUS <= "00";
                          <= "00";
     RAM ADDR BUS
     RAM_WR
                          <= '0';
     ACC_RST
                          <= '0';
```

ACC\_WR <= '0': end case; end process; end CU\_arch; **Елемент СU:** CU\_intf RAM\_WR **CLOCK** ACC\_WR RESET ACC\_RST ENTER\_ORAM\_ADDR\_BUS(1:0) CONSTANT\_BUS(7:0) ENTER\_OP2 IN\_SEL(1:0) CALCULATEDP\_CODE\_BUS(1:0) Файл MUX.vhd: -- Company: -- Engineer: 15:06:55 04/27/2023 -- Create Date: -- Design Name: -- Module Name: MUX - Behavioral -- Project Name: -- Target Devices: -- Tool versions: -- Description: -- Dependencies: -- Revision: -- Revision 0.01 - File Created -- Additional Comments: 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;
use IEEE.STD_LOGIC_UNSIGNED.ALL;
-- Uncomment the following library declaration if instantiating
-- any Xilinx primitives in this code.
--library UNISIM;
--use UNISIM.VComponents.all;
entity MUX_intf is
     port(
           DATA_IN
                               : IN STD_LOGIC_VECTOR(7 downto 0);
           CONSTANT_BUS: IN STD_LOGIC_VECTOR(7 downto 0);
           RAM_DATA_OUT_BUS: IN STD_LOGIC_VECTOR(7 downto 0);
                                     : IN STD_LOGIC_VECTOR(1 downto
           IN SEL
0);
           IN_SEL_OUT_BUS: OUT_std_logic_vector(7 downto 0)
end MUX intf;
architecture MUX_arch of MUX_intf is
begin
INSEL_A_MUX: process(DATA_IN, CONSTANT_BUS,
RAM_DATA_OUT_BUS, IN_SEL)
     begin
          if(IN\_SEL = "00") then
                IN_SEL_OUT_BUS <= DATA_IN;</pre>
          elsif(IN\_SEL = "01") then
               IN_SEL_OUT_BUS <= RAM_DATA_OUT_BUS;</pre>
          else
                IN_SEL_OUT_BUS <= CONSTANT_BUS;</pre>
          end if;
     end process INSEL A MUX;
end MUX_arch;
```

#### Елемент MUX:

| IN_SEL_OUT_BUS(7:0)   |  |
|-----------------------|--|
| IN_SEL(1:0)           |  |
| RAM_DATA_OUT_BUS(7:0) |  |
| CONSTANT_BUS(7:0)     |  |
| DATA_IN(7:0)          |  |

## MUX\_intf

#### Файл RAM.vhd:

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; use IEEE.STD\_LOGIC\_UNSIGNED.ALL;
- -- Uncomment the following library declaration if instantiating
- -- any Xilinx primitives in this code.
- --library UNISIM;
- --use UNISIM.VComponents.all;

```
entity RAM_intf is
port(
          RAM_WR
                                  : IN STD LOGIC;
          RAM_ADDR_BUS
                                  : IN STD_LOGIC_VECTOR(1 downto
0);
          ACC_DATA_IN_BUS : IN STD_LOGIC_VECTOR(7 downto 0);
          RAM_DATA_OUT_BUS: OUT STD_LOGIC_VECTOR(7 downto 0);
          CLOCK
                        : IN STD_LOGIC
          );
end RAM_intf;
architecture RAM_arch of RAM_intf is
type ram_type is array (3 downto 0) of STD_LOGIC_VECTOR(7 downto 0);
signal RAM_UNIT
                             : ram_type;
signal RAM_DATA_IN_BUS: STD_LOGIC_VECTOR(7 downto 0);
begin
     RAM_DATA_IN_BUS <= ACC_DATA_IN_BUS;
     RAM: process(CLOCK, RAM_ADDR_BUS, RAM_UNIT)
     begin
          if (rising_edge(CLOCK)) then
               if (RAM_WR = '1') then
                   RAM_UNIT(conv_integer(RAM_ADDR_BUS)) <=
RAM_DATA_IN_BUS;
               end if;
          end if;
          RAM DATA OUT BUS <=
RAM_UNIT(conv_integer(RAM_ADDR_BUS));
     end process RAM;
end RAM arch;
```

### Елемент RAM:

# RAM\_intf

|                                                                                                                                                                     | RAM_WR                                                                                                                                                                      | RAM_DATA_OUT_BUS(7:0) |  |  |  |  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|--|--|--|--|
|                                                                                                                                                                     | CLOCK                                                                                                                                                                       |                       |  |  |  |  |
|                                                                                                                                                                     | RAM_ADDR_BUS(                                                                                                                                                               | (1:0)                 |  |  |  |  |
|                                                                                                                                                                     | ACC_DATA_IN_BUS(7:0)                                                                                                                                                        |                       |  |  |  |  |
| Фай.                                                                                                                                                                | Файл ALU.vhd:                                                                                                                                                               |                       |  |  |  |  |
| Eng Cre Des Mo Pro Tar Toc Des Deg Rev Rev                                                                                                                          | mpany: gineer: ate Date: 16:13:46 sign Name: dule Name: ALU - ject Name: get Devices: ol versions: scription: pendencies: vision: vision 0.01 - File Creatitional Comments: | Behavioral            |  |  |  |  |
| library IEEE;<br>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; use IEEE.STD_LOGIC_UNSIGNED.ALL; |                                                                                                                                                                             |                       |  |  |  |  |

- -- Uncomment the following library declaration if instantiating
- -- any Xilinx primitives in this code.
- --library UNISIM;
- $\hbox{--use UNISIM.} V Components. all;\\$

```
entity ALU_intf is
port(
          IN_SEL_OUT_BUS: IN STD_LOGIC_VECTOR(7 downto 0);
          ACC_DATA_OUT_BUS: IN STD_LOGIC_VECTOR(7 downto 0);
          OP_CODE_BUS: IN STD_LOGIC_VECTOR(1 downto 0);
          ACC_DATA_IN_BUS: OUT STD_LOGIC_VECTOR(7 downto 0);
          OVER FLOW: OUT STD LOGIC
          --OF - overflow
          );
end ALU_intf;
architecture ALU_arch of ALU_intf is
begin
ALU: process(OP_CODE_BUS, IN_SEL_OUT_BUS, ACC_DATA_OUT_BUS)
          variable A : unsigned(7 downto 0);
          variable B: unsigned(7 downto 0);
          variable temp: std_logic_vector(8 downto 0);
     begin
          A := unsigned(ACC_DATA_OUT_BUS);
          B := unsigned(IN_SEL_OUT_BUS);
          if OP CODE BUS = "00" then
               ACC_DATA_IN_BUS <= STD_LOGIC_VECTOR(B);
          elsif OP_CODE_BUS = "01" then
               temp := STD_LOGIC_VECTOR('0' & A) +
STD_LOGIC_VECTOR('0' & B);
                    if (temp(8) = '1') then
                          OVER FLOW <= '1';
                          else
                               OVER FLOW <= '0';
                               end if:
               ACC_DATA_IN_BUS <= temp(7 downto 0);
          elsif OP_CODE_BUS = "10" then
          temp := STD LOGIC VECTOR('0' & A) - STD LOGIC VECTOR('0'
& B);
                    if (temp(8) = '1') then
                          OVER_FLOW <= '1';
                          else
                               OVER FLOW <= '0';
                               end if:
               ACC_DATA_IN_BUS <= temp(7 downto 0);
          elsif OP_CODE_BUS = "11" then
               temp := STD_LOGIC_VECTOR('0' & A) XOR
STD_LOGIC_VECTOR('0' & B);
               ACC_DATA_IN_BUS <= temp(7 downto 0);
          else
```

```
\label{eq:acc_data_in_bus} ACC\_DATA\_IN\_BUS <= "000000000"; \\ end if; \\ end process ALU;
```

end ALU\_arch;

#### Елемент ALU:

# ALU\_intf

|                                                                                                                                                                                                                                     | IN_SEL_OUT_BUS(7:04)CC_DATA_IN_BUS(7:0) |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|--|
|                                                                                                                                                                                                                                     | ACC_DATA_OUT_BUS(7:0)                   |  |
|                                                                                                                                                                                                                                     | OP_CODE_BUS(1:0)                        |  |
|                                                                                                                                                                                                                                     | OVER_FLOW                               |  |
| Файл                                                                                                                                                                                                                                | ACC.vhd:                                |  |
| Engineer: Create Date: 15:27:57 04/27/2023 Design Name: Module Name: ACC - Behavioral Project Name: Target Devices: Tool versions: Description: Pependencies: Revision: Revision: Revision 0.01 - File Created Additional Comments: |                                         |  |
| library l                                                                                                                                                                                                                           | EEE;<br>E.STD_LOGIC_1164.ALL;           |  |

- -- Uncomment the following library declaration if using
- -- arithmetic functions with Signed or Unsigned values

```
use IEEE.NUMERIC_STD.ALL;
use IEEE.STD_LOGIC_UNSIGNED.ALL;
-- Uncomment the following library declaration if instantiating
-- any Xilinx primitives in this code.
--library UNISIM;
--use UNISIM.VComponents.all;
entity ACC_intf is
port(
          CLOCK
                          : IN STD_LOGIC;
          ACC_RST
                               : IN STD_LOGIC;
          ACC_WR
                                    : IN STD_LOGIC;
          ACC DATA IN BUS: IN STD LOGIC VECTOR(7 downto 0);
          ACC_DATA_OUT_BUS: OUT STD_LOGIC_VECTOR(7 downto 0)
          );
end ACC_intf;
architecture ACC_arch of ACC_intf is
signal ACC_DATA
                               : STD_LOGIC_VECTOR(7 downto 0);
begin
     ACC: process(CLOCK, ACC_DATA)
     begin
          if (rising_edge(CLOCK)) then
               if(ACC_RST = '1') then
                     ACC_DATA <= "00000000";
               elsif (ACC WR = '1') then
                     ACC_DATA <= ACC_DATA_IN_BUS;
               end if;
          end if;
          ACC DATA OUT BUS <= ACC DATA;
     end process ACC;
end ACC_arch;
Елемент АСС:
```

# ACC intf

```
CLOCK
        ACC RST
        ACC WR
<del>ACC</del> | 120/06/TCA | DOAUTAT | BNU 93/(17/95)(7<del>1:0)</del>
Файл SEGDEC.vhd:
```

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; use IEEE.STD\_LOGIC\_UNSIGNED.ALL;
- -- Uncomment the following library declaration if instantiating
- -- any Xilinx primitives in this code.
- --library UNISIM;
- --use UNISIM.VComponents.all;

entity SEGDEC\_intf is port(

> CLOCK : IN STD\_LOGIC;

ACC\_DATA\_OUT\_BUS: IN STD\_LOGIC\_VECTOR(7 downto 0);

RESET : IN STD LOGIC:

OverFlow\_IN: IN STD\_LOGIC;

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; : OUT STD LOGIC; SEG G

DP : OUT STD\_LOGIC; OverFlow OUT : OUT STD LOGIC := '0'

```
end SEGDEC_intf;
architecture SEGDEC_arch of SEGDEC_intf is
signal ONES_BUS: STD_LOGIC_VECTOR(3 downto 0) := "0000";
signal DECS_BUS: STD_LOGIC_VECTOR(3 downto 0) := "0000";
signal HONDREDS_BUS : STD_LOGIC_VECTOR(3 downto 0) := "0000";
begin
OVERFLOW_INDICATE : process(OverFlow_IN, RESET)
     begin
           --if rising_edge(CLOCK) then
           if (RESET = '1') then
                OverFlow_OUT <= '0';
                elsif (RESET = '0' and OverFlow_IN = '1') then
                      OverFlow_OUT <= '1';
                      end if:
                --end if;
     end process OVERFLOW_INDICATE;
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";
          variable DIGIT CTRL
                               : STD LOGIC VECTOR(6 downto 0) :=
"0000000";
          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;
                                     CUR DIGIT := DECS;
                                     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 := "1111111";
                               when "1001" => DIGIT_CTRL := "1111011";
```

```
when others => DIGIT_CTRL := "0000000";
     end case;
else
    DIGIT_VAL := ONES_BUS;
     CUR_DIGIT := ONES;
     COMMONS_CTRL := "000";
end if;
COMM_ONES
                <= COMMONS_CTRL(0);
                <= COMMONS_CTRL(1);
COMM DECS
COMM_HUNDREDS <= COMMONS_CTRL(2);
SEG_A <= DIGIT_CTRL(6);</pre>
SEG B <= DIGIT CTRL(5);
SEG_C <= DIGIT_CTRL(4);</pre>
SEG_D <= DIGIT_CTRL(3);</pre>
SEG_E <= DIGIT_CTRL(2);</pre>
SEG F \leq DIGIT CTRL(1);
SEG_G <= DIGIT_CTRL(0);
DP <= '0';
```

end if; end process INDICATE; end SEGDEC\_arch;

**Елемент SEGDEC:** 

# SEGDEC\_intf

| <br>CLOCK            | COMM_ONES    |  |
|----------------------|--------------|--|
|                      | COMM_DECS    |  |
| COM                  | IM_HUNDREDS  |  |
|                      | SEG_A        |  |
|                      | SEG_B        |  |
|                      | SEG_C        |  |
|                      | SEG_D        |  |
|                      | SEG_E        |  |
|                      | SEG_F        |  |
|                      | SEG_G        |  |
| ACC_DATA_OUT_BUS(7:0 | DP           |  |
| RESET                |              |  |
| OverFlow_IN          | OverFlow_OUT |  |

### Схема для Top Level:



#### Файл Constraints.ucf:

| $H^{\alpha,\alpha,\alpha,\alpha,\alpha,\alpha,\alpha,\alpha,\alpha,\alpha,\alpha,\alpha}$ |                                    |
|-------------------------------------------------------------------------------------------|------------------------------------|
| ******                                                                                    | ********************               |
| *****                                                                                     |                                    |
| #                                                                                         | UCF for ElbertV2 Development Board |
| #                                                                                         |                                    |
| #******                                                                                   | ********************               |
| ******                                                                                    | *********************              |
| *****                                                                                     |                                    |
| CONFIG VCCAUX                                                                             | $\zeta = "3.3"$ ;                  |
|                                                                                           |                                    |

# Clock 12 MHz NET "CLOCK" LOC = P129 | IOSTANDARD = LVCMOS33 | PERIOD = 12MHz;

ŧ LED

```
NET "OVERFLOW"
                  LOC = P46 | IOSTANDARD = LVCMOS33 |
SLEW = SLOW | DRIVE = 12;
Seven Segment Display
NET "A_OUT"
            LOC = P117 | IOSTANDARD = LVCMOS33 | SLEW = SLOW
|DRIVE = 12;
            LOC = P116 | IOSTANDARD = LVCMOS33 | SLEW = SLOW
 NET "B OUT"
|DRIVE = 12;
 NET "C OUT"
            LOC = P115 | IOSTANDARD = LVCMOS33 | SLEW = SLOW
|DRIVE = 12;
 NET "D_OUT"
            LOC = P113 | IOSTANDARD = LVCMOS33 | SLEW = SLOW
|DRIVE = 12;
 NET "E OUT"
           LOC = P112 | IOSTANDARD = LVCMOS33 | SLEW = SLOW
| DRIVE = 12;
 NET "F OUT"
           LOC = P111 | IOSTANDARD = LVCMOS33 | SLEW = SLOW
|DRIVE = 12;
 NET "G OUT"
            LOC = P110 | IOSTANDARD = LVCMOS33 | SLEW = SLOW
|DRIVE = 12;
 NET "DP OUT" LOC = P114 | IOSTANDARD = LVCMOS33 | SLEW =
SLOW | DRIVE = 12;
 NET "COMMON 2 OUT"
                     LOC = P124 | IOSTANDARD = LVCMOS33 |
SLEW = SLOW | DRIVE = 12;
 NET "COMMON 1 OUT"
                     LOC = P121 | IOSTANDARD = LVCMOS33 |
SLEW = SLOW | DRIVE = 12;
 NET "COMMON 0 OUT"
                     LOC = P120 | IOSTANDARD = LVCMOS33 |
SLEW = SLOW | DRIVE = 12;
DP Switches
NET "DATA IN(0)"
                LOC = P70 | PULLUP | IOSTANDARD =
LVCMOS33 | SLEW = SLOW | DRIVE = 12;
 NET "DATA IN(1)"
                LOC = P69 | PULLUP | IOSTANDARD =
LVCMOS33 | SLEW = SLOW | DRIVE = 12;
 NET "DATA_IN(2)"
                LOC = P68 | PULLUP | IOSTANDARD =
LVCMOS33 | SLEW = SLOW | DRIVE = 12;
                LOC = P64 | PULLUP | IOSTANDARD =
 NET "DATA_IN(3)"
LVCMOS33 | SLEW = SLOW | DRIVE = 12;
```

```
LOC = P63 | PULLUP | IOSTANDARD =
 NET "DATA_IN(4)"
LVCMOS33 | SLEW = SLOW | DRIVE = 12;
                   LOC = P60 | PULLUP | IOSTANDARD =
 NET "DATA_IN(5)"
LVCMOS33 | SLEW = SLOW | DRIVE = 12;
                   LOC = P59 | PULLUP | IOSTANDARD =
 NET "DATA_IN(6)"
LVCMOS33 | SLEW = SLOW | DRIVE = 12;
 NET "DATA_IN(7)"
                    LOC = P58 | PULLUP | IOSTANDARD =
LVCMOS33 | SLEW = SLOW | DRIVE = 12;
Switches
NET "ENTER_OP1"
                     LOC = P80 | PULLUP | IOSTANDARD =
LVCMOS33 | SLEW = SLOW | DRIVE = 12;
 NET "ENTER OP2"
                     LOC = P79 | PULLUP | IOSTANDARD =
LVCMOS33 | SLEW = SLOW | DRIVE = 12;
 NET "CALCULATE"
                     LOC = P78 | PULLUP | IOSTANDARD =
LVCMOS33 | SLEW = SLOW | DRIVE = 12;
                  LOC = P75 | PULLUP | IOSTANDARD = LVCMOS33 |
 NET "RESET"
SLEW = SLOW | DRIVE = 12;
Файл TestTopLevel.vhd:
-- Vhdl test bench created from schematic D:\Lab_3_Example\TopLevel.sch - Mon
May 01 21:40:52 2023
-- Notes:
-- 1) This testbench template has been automatically generated using types
-- std_logic and std_logic_vector for the ports of the unit under test.
-- Xilinx recommends that these types always be used for the top-level
-- I/O of a design in order to guarantee that the testbench will bind
-- correctly to the timing (post-route) simulation model.
-- 2) To use this template as your testbench, change the filename to any
-- name of your choice with the extension .vhd, and use the "Source->Add"
-- menu in Project Navigator to import the testbench. Then
-- edit the user defined section below, adding code to generate the
-- stimulus for your design.
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 TopLevel sch tb;
ARCHITECTURE behavioral OF TopLevel_TopLevel_sch_tb IS
 COMPONENT TopLevel
                      STD LOGIC;
 PORT( RESE
                  IN
    ENTER_OP1
                           STD_LOGIC;
                      IN
    ENTER OP2
                      IN
                           STD LOGIC;
                           STD_LOGIC;
    CALCULATE
                      IN
                           OUT STD LOGIC;
    COMMON 0 OUT
    COMMON_1_OUT
                           OUT STD_LOGIC;
    COMMON_2_OUT
                           OUT STD_LOGIC;
    A OUT
                  OUT STD_LOGIC;
    B_OUT
                  OUT STD_LOGIC;
                  OUT STD_LOGIC;
    C_OUT
    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:
    CLOCK
                      STD LOGIC;
                  IN
    DATA IN:
                  IN
                      STD_LOGIC_VECTOR (7 DOWNTO 0);
    OVER FLOW
                      OUT STD LOGIC);
 END COMPONENT;
    signal op1 : STD_LOGIC_VECTOR(7 DOWNTO 0);
    signal op2: STD_LOGIC_VECTOR(7 DOWNTO 0);
 SIGNAL RESE:
                  STD_LOGIC;
 SIGNAL ENTER OP1
                           STD LOGIC;
                           STD_LOGIC;
 SIGNAL ENTER_OP2
 SIGNAL CALCULATE
                           STD LOGIC;
                                STD_LOGIC;
 SIGNAL COMMON_0_OUT
 SIGNAL COMMON 1 OUT
                                STD LOGIC;
 SIGNAL COMMON_2_OUT
                                STD_LOGIC;
 SIGNAL A OUT
                       STD LOGIC:
                      STD_LOGIC;
 SIGNAL B_OUT
 SIGNAL C OUT
                      STD LOGIC;
                      STD LOGIC;
 SIGNAL D OUT
 SIGNAL E OUT
                      STD LOGIC:
 SIGNAL F_OUT
                      STD_LOGIC;
 SIGNAL G_OUT
                      STD_LOGIC;
 SIGNAL DP OUT
                      STD LOGIC;
                      STD_LOGIC;
 SIGNAL CLOCK
                      STD_LOGIC_VECTOR (7 DOWNTO 0);
 SIGNAL DATA IN
 SIGNAL OVER_FLOW
                           STD_LOGIC;
```

```
constant CLK_period: time := 1 us; constant TC_period: time := 65536 us;
```

#### **BEGIN**

```
UUT: TopLevel PORT MAP(
          RESE \Rightarrow RESE,
          ENTER_OP1 => ENTER_OP1,
          ENTER_OP2 => ENTER_OP2,
          CALCULATE => CALCULATE,
          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} => C_{OUT}
          D OUT \Rightarrow D OUT
          E_OUT => E_OUT,
          F_OUT => F_OUT,
          G_OUT \Rightarrow G_OUT,
          DP OUT => DP OUT.
          CLOCK => CLOCK,
          DATA IN => DATA IN.
          OVER FLOW => OVER FLOW
 );
CLK_process : process
     begin
          CLOCK <= '1';
          wait for CLK_period/2;
          CLOCK <= '0';
          wait for CLK_period/2;
     end process CLK_process;
     stim_proc: process
     begin
     RESE <= '1';
     ENTER_OP1 <= '0';
     ENTER_OP2 <= '0';
 CALCULATE <= '0';
     DATA_IN <=(others => '0');
     wait for 2*CLK_period;
     RESE <='0';
```

```
wait for 4*TC_period;
     ENTER OP1 <='1';
     DATA_IN \leq op1;
     wait for 2*TC_period;
     ENTER_OP1 <='0';
     wait for 4*TC_period;
     ENTER OP2 <='1';
     DATA_IN \leq op2;
     wait for 2*TC_period;
     ENTER OP2 <='0';
     wait for 4*TC_period;
     CALCULATE <= '1';
     wait for 8*TC_period;
      wait;
     end process stim_proc; --1.835 s
END;
                           Перевірка результату
OP1=01001101;
OP2=00110100;
((OP1 XOR OP2) + OP2) - 1 = 10101110;
1)OP1 XOR OP2 = 01001101 XOR 00110100 = 01111011;
2) (OP1 XOR OP2) + OP2 = 01111011 + 00110100 = 10101111;
3) ((OP1 XOR OP2) + OP2) - 1 = 10101111 - 00000001 = 10101110;
```







**Висновок:** Під час даної лабораторної роботи, я на базі стенда Elbert V2 – Spartan 3A FPGA, реалізував цифровий автомат для обчислення значення заданого виразу.