

#### Звіт

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

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

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

## Варіант – 15

Виконав: ст.гр. КІ-202

Мишок Р.В. Перевірив: асистент

Козак Н.Б.

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

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



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

#### Завдання

| 3 | ((OP2 and 5) + OP2) – OP1 |
|---|---------------------------|
|   |                           |

### Виконання роботи:

```
Файл 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):=
"00000101":
             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
                        <= "00000101";
CU_SYNC_PROC: process (CLOCK)
 begin
   if (rising_edge(CLOCK)) then
     if (RESET = '1') then
       cu_cur_state <= cu_rst;
     else
       cu_cur_state <= cu_next_state;</pre>
     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";
                    RAM_ADDR_BUS
                                          <= "00";
                    RAM_WR
                                          <= '1';
                    ACC_RST
                                          <= '0';
                    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
                         <= "01";
     RAM_WR
                         <= '0';
     ACC_RST
                         <= '0';
     ACC_WR
                          <= '1';
when cu_run_calc1 =>
                         <= "10";
     IN_SEL
     OP CODE BUS <= "11";
                         <= "01";
     RAM_ADDR_BUS
     RAM_WR
                          <= '0':
     ACC_RST
                         <= '0';
     ACC_WR
                         <= '1';
when cu_run_calc2 =>
     IN SEL
                         <= "01";
     OP_CODE_BUS <= "01";
                         <= "01";
     RAM_ADDR_BUS
                          = '0';
     RAM_WR
     ACC_RST
                         <= '0';
     ACC_WR
                          <= '1';
when cu_run_calc3 =>
     IN_SEL
                         <= "01";
     OP_CODE_BUS <= "10";
                         <= "00";
     RAM_ADDR_BUS
     RAM_WR
                         <= '0';
     ACC_RST
                         <= '0':
     ACC_WR
                          <= '1';
when cu_finish
               =>
     IN_SEL
                         <= "00";
     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;

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

# CU\_intf

|  | сьоск                | RAM_WR      |  |
|--|----------------------|-------------|--|
|  | DECET                | ACC_WR      |  |
|  | RESET                | ACC_RST     |  |
|  | ENTER_ORAM_ADD       | R_BUS(1:0)  |  |
|  | CONSTAN<br>ENTER OP2 | IT_BUS(7:0) |  |
|  | <del>-</del>         | IN_SEL(1:0) |  |
|  | CALCULATEDP_COD      | E_BUS(1:0)  |  |

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

\_\_\_\_\_

-- Company:

-- Engineer:

--

-- Create Date: 15:06:55 04/27/2023

-- 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(
                                : IN STD_LOGIC_VECTOR(7 downto 0);
           DATA IN
           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;
          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:

-- Company: -- Engineer: -- Create Date: 16:49:14 04/27/2023 -- Design Name: -- Module Name: RAM - 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 RAM_intf is
port(
                                  : IN STD LOGIC:
          RAM WR
                                  : IN STD_LOGIC_VECTOR(1 downto
          RAM_ADDR_BUS
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:
-- Company:
-- Engineer:
-- Create Date: 16:13:46 04/27/2023
-- Design Name:
-- Module Name:
                ALU - 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 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) AND
STD_LOGIC_VECTOR('0' & B);
                ACC_DATA_IN_BUS <= temp(7 downto 0);
          else
                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:                                |   |
| Файл ACC.vhd:                                                                                                                                                       |                                         |   |
| 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;
--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
ACC 120/45/TCA 120/40/TAT 18NU/18/(7/50)(7/<del>: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
SEG_E
                     : OUT STD_LOGIC;
                     : OUT STD_LOGIC;
          SEG_F
SEG_G
                     : OUT STD_LOGIC;
                     : OUT STD LOGIC;
          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" \Rightarrow 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);
COMM DECS
                <= COMMONS CTRL(1);
COMM_HUNDREDS <= COMMONS_CTRL(2);
SEG A <= DIGIT CTRL(6);
SEG_B <= DIGIT_CTRL(5);
SEG_C <= DIGIT_CTRL(4);
SEG_D <= DIGIT_CTRL(3);
```

SEG\_E <= DIGIT\_CTRL(2);
SEG\_F <= DIGIT\_CTRL(1);
SEG\_G <= DIGIT\_CTRL(0);
DP <= '0';</pre>

end if; end process INDICATE; end SEGDEC\_arch; **Елемент SEGDEC:** 

# 050550 : 4



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



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

| #*******      | <***********************************   |
|---------------|----------------------------------------|
| ******        | ************************************** |
| *****         |                                        |
| #<br>#        | 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;
            LOC = P113 | IOSTANDARD = LVCMOS33 | SLEW = SLOW
 NET "D OUT"
|DRIVE = 12;
 NET "E OUT"
            LOC = P112 | IOSTANDARD = LVCMOS33 | SLEW = SLOW
|DRIVE = 12;
 NET "F OUT"
           LOC = P111 | IOSTANDARD = LVCMOS33 | SLEW = SLOW
|DRIVE = 12;
            LOC = P110 | IOSTANDARD = LVCMOS33 | SLEW = SLOW
 NET "G OUT"
|DRIVE = 12;
 NET "DP OUT" LOC = P114 | IOSTANDARD = LVCMOS33 | SLEW =
SLOW \mid 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;
 NET "DATA_IN(3)"
                LOC = P64 | PULLUP | IOSTANDARD =
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;
 NET "DATA_IN(6)"
                   LOC = P59 | PULLUP | IOSTANDARD =
LVCMOS33 | SLEW = SLOW | DRIVE = 12;
                    LOC = P58 | PULLUP | IOSTANDARD =
 NET "DATA_IN(7)"
LVCMOS33 | SLEW = SLOW | DRIVE = 12;
Switches
NET "ENTER OP1"
                     LOC = P80 | PULLUP | IOSTANDARD =
LVCMOS33 | SLEW = SLOW | DRIVE = 12;
                     LOC = P79 | PULLUP | IOSTANDARD =
 NET "ENTER_OP2"
LVCMOS33 | SLEW = SLOW | DRIVE = 12;
                      LOC = P78 | PULLUP | IOSTANDARD =
 NET "CALCULATE"
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;
                  OUT STD_LOGIC:
    DP OUT
    CLOCK
                  IN
                       STD LOGIC:
    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;
                           STD LOGIC;
 SIGNAL ENTER OP1
                           STD_LOGIC;
 SIGNAL ENTER_OP2
                           STD LOGIC;
 SIGNAL CALCULATE
                                STD_LOGIC;
 SIGNAL COMMON_0_OUT
 SIGNAL COMMON 1 OUT
                                STD LOGIC;
                                STD_LOGIC;
 SIGNAL COMMON_2_OUT
 SIGNAL A OUT
                       STD LOGIC:
                       STD_LOGIC;
 SIGNAL B_OUT
 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;
                       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 => 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 \leq (others \Rightarrow '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 <= 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=01010011;
OP2=01101110;
((OP2 \text{ and } 5) + OP2) - OP1 = 000111111;
1) OP2 and 5 = 01101110 and 00000101 = 00000100;
2) (OP2 and 5) + OP2 = 00000100 + 01101110 = 01110010;
3) ((OP2 \text{ and } 5) + OP2) - OP1 = 01110010 - 01010011 = 000111111;
```







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