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

Кафедра ЕОМ



### Звіт

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

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

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

Варіант – 7

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

201

Добош М. I. Перевірив:

асистент

Козак Н.Б.

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

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



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

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

| 6 | ((OP1 + OP2) - 2) << OP2 |
|---|--------------------------|
|   |                          |

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

```
Файл 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):= "00000010";
            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
                       <= "00000010";
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;
    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
```

```
when cu rst
                                   =>
                       cu_next_state <= cu_idle;
                when cu idle
                       if (ENTER\_OP1 = '1') then
                             cu_next_state <= cu_load_op1;</pre>
                       elsif (ENTER_OP2 = '1') then
                             cu_next_state <= cu_load_op2;
                       elsif (CALCULATE = '1') then
                             cu_next_state <= cu_run_calc0;
                       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;</pre>
                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;</pre>
                when cu_finish
                                   =>
                       cu_next_state <= cu_finish;</pre>
                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
                                   =>
                                               <= "00":
                       IN SEL
                       OP_CODE_BUS <= "00";
                       RAM ADDR BUS
                                               <= "00";
                       RAM_WR
                                               <= '0';
                       ACC_RST
                                               <= '1';
                       ACC_WR
                                               <= '0';
```

case(cu\_cur\_state) is

```
when cu_idle
                     =>
     IN SEL
                          <= "00";
     OP_CODE_BUS <= "00";
     RAM ADDR BUS
                          <= "00";
     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';
     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";
                          <= "00";
     RAM ADDR BUS
     RAM_WR
                          <= '0';
     ACC_RST
                          <= '0':
     ACC_WR
                          <= '1';
when cu run calc1 =>
     IN_SEL
                          <= "01";
     OP_CODE_BUS <= "01";
                          <= "01";
     RAM_ADDR_BUS
     RAM_WR
                          <= '0';
     ACC_RST
                          <= '0':
     ACC_WR
                          <= '1';
when cu_run_calc2 =>
     IN_SEL
                          <= "10";
     OP CODE BUS <= "10";
     RAM_ADDR_BUS
                          <= "01";
     RAM WR
                          = '0';
                          <= '0':
     ACC_RST
     ACC_WR
                          <= '1';
when cu_run_calc3 =>
```

```
IN_SEL
                         <= "01";
     OP CODE BUS <= "11";
     RAM ADDR BUS
                         <= "01";
     RAM_WR
                          <= '0';
     ACC_RST
                          <= '0';
     ACC_WR
                          <= '1';
when cu_finish
               =>
                          <= "00":
     IN_SEL
     OP_CODE_BUS <= "00";
     RAM ADDR BUS
                          <= "00";
                          <= '0';
     RAM_WR
     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



Файл 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_SEL
                                        : IN STD_LOGIC_VECTOR(1
downto 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:
-- 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(
          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:
-- 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
                case(B) is --case(B) is
                           when x"00"
                                          => ACC_DATA_IN_BUS
<= STD_LOGIC_VECTOR(A sll 0);
                                          => ACC_DATA_IN_BUS
                           when x"01"
<= STD LOGIC VECTOR(A sll 1);
                           when x"02"
                                          => ACC_DATA_IN_BUS
<= STD LOGIC VECTOR(A sll 2);
                           when x"03"
                                          => ACC_DATA_IN_BUS
<= STD LOGIC VECTOR(A sll 3);
                           when x"04"
                                          => ACC_DATA_IN_BUS
<= STD LOGIC VECTOR(A sll 4);
                           when x"05"
                                          => ACC_DATA_IN_BUS
<= STD LOGIC VECTOR(A sll 5);
                           when x"06"
                                          => ACC_DATA_IN_BUS
<= STD LOGIC VECTOR(A sll 6);
                           when x"07"
                                          => ACC_DATA_IN_BUS
<= STD_LOGIC_VECTOR(A sll 7);
                           when others => ACC DATA IN BUS <=
STD_LOGIC_VECTOR(A sll 0);
                      end case;
          else
               ACC DATA IN BUS <= "000000000";
          end if;
     end process ALU;
end ALU arch;
```

# Елемент ALU:

# ALU\_intf

| ACC_DATA_OUT_BUS(7:0)  OP_CODE_BUS(1:0)  OVER_FLOW  Файл ACC.vhd:  Company: Engineer: Create Date: 15:27:57 04/27/2023 Design Name: Module Name: ACC - Behavioral Project Name: Target Devices: Tool versions: Dependencies: Revision: Revision: Revision 0.01 - File Created |                                                                                    |                                                                                                                        |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------|
| OP_CODE_BUS(1:0)  Файл ACC.vhd:  Company: Engineer: Create Date: 15:27:57 04/27/2023 Design Name: Module Name: ACC - Behavioral Project Name: Target Devices: Tool versions: Description: Dependencies: Revision: Revision: Revision 0.01 - File Created                      |                                                                                    | IN_SEL_OUT_BUS(7:04)CC_DATA_IN_BUS(7:0)                                                                                |
| OVER_FLOW  Файл ACC.vhd:                                                                                                                                                                                                                                                      |                                                                                    | ACC_DATA_OUT_BUS(7:0)                                                                                                  |
| Файл ACC.vhd:                                                                                                                                                                                                                                                                 |                                                                                    | OP_CODE_BUS(1:0)                                                                                                       |
|                                                                                                                                                                                                                                                                               |                                                                                    | OVER_FLOW                                                                                                              |
| Company: Engineer: Create Date: 15:27:57 04/27/2023 Design Name: Module Name: ACC - Behavioral Project Name: Target Devices: Tool versions: Description: Dependencies: Revision: Revision 0.01 - File Created Additional Comments:                                            | Файл                                                                               | ACC.vhd:                                                                                                               |
|                                                                                                                                                                                                                                                                               | Desig<br>Modu<br>Proje<br>Targe<br>Tool<br>Descu<br><br>Depe<br><br>Revis<br>Revis | gn Name: ule Name: ACC - Behavioral ect Name: et Devices: versions: ription: endencies: sion: sion 0.01 - File Created |
| 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\_MATA\_BNUS(750)7:0)

Файл 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;
           SEG_G
                      : 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);
                  <= bcd (3 downto 0);
    ONES BUS
  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)
= "00000";
          variable DIGIT_CTRL : STD_LOGIC_VECTOR(6 downto 0)
= "00000000";
          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 \leq DIGIT_CTRL(6);
                     SEG B \leq DIGIT CTRL(5);
                     SEG_C \leq DIGIT_CTRL(4);
                     SEG_D <= DIGIT_CTRL(3);
                     SEG_E \leq 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:** 

# SEGDEC\_intf



Схема для Top Level:



## Файл Constraints.ucf:

| #*****          | ************************************** |
|-----------------|----------------------------------------|
| ******          | *****************                      |
| ******          | **#                                    |
| #               | UCF for ElbertV2 Development Board     |
| #               |                                        |
| #*******        | *****************                      |
| ******          | ******************                     |
| ******          | **#                                    |
| CONFIG VCCAUX = | = "3.3" ;                              |
|                 |                                        |

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

```
SLEW = SLOW | DRIVE = 12;
Seven Segment Display
NET "A_OUT" LOC = P117 | IOSTANDARD = LVCMOS33 | SLEW =
SLOW \mid DRIVE = 12:
 NET "B OUT" LOC = P116 | IOSTANDARD = LVCMOS33 | SLEW =
SLOW \mid DRIVE = 12;
 NET "C OUT" LOC = P115 | IOSTANDARD = LVCMOS33 | SLEW =
SLOW \mid DRIVE = 12;
 NET "D OUT" LOC = P113 | IOSTANDARD = LVCMOS33 | SLEW =
SLOW | DRIVE = 12;
 NET "E OUT" LOC = P112 | IOSTANDARD = LVCMOS33 | SLEW =
SLOW \mid DRIVE = 12;
 NET "F_OUT" LOC = P111 | IOSTANDARD = LVCMOS33 | SLEW =
SLOW \mid DRIVE = 12;
 NET "G_OUT" LOC = P110 | IOSTANDARD = LVCMOS33 | SLEW =
SLOW \mid 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 \mid PULLUP \mid IOSTANDARD =
LVCMOS33 | SLEW = SLOW | DRIVE = 12;
 NET "DATA_IN(1)" LOC = P69 | PULLUP | IOSTANDARD =
LVCMOS33 | SLEW = SLOW | DRIVE = 12;
```

LOC = P46 | IOSTANDARD = LVCMOS33 |

NET "OVERFLOW"

```
LOC = P68 | PULLUP | IOSTANDARD =
 NET "DATA_IN(2)"
LVCMOS33 | SLEW = SLOW | DRIVE = 12;
                 LOC = P64 | PULLUP | IOSTANDARD =
 NET "DATA_IN(3)"
LVCMOS33 | SLEW = SLOW | DRIVE = 12;
 NET "DATA_IN(4)"
                 LOC = P63 | PULLUP | IOSTANDARD =
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;
                 LOC = P79 | PULLUP | IOSTANDARD =
 NET "ENTER_OP2"
LVCMOS33 | SLEW = SLOW | DRIVE = 12;
 NET "CALCULATE"
                 LOC = P78 | PULLUP | IOSTANDARD =
LVCMOS33 | SLEW = SLOW | DRIVE = 12;
                LOC = P75 | PULLUP | IOSTANDARD =
 NET "RESET"
LVCMOS33 | 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
 PORT( RESE
                        STD_LOGIC;
    ENTER_OP1
                        IN
                             STD_LOGIC;
    ENTER OP2
                        IN
                             STD LOGIC;
    CALCULATE
                        IN
                             STD_LOGIC;
                             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;
    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;
    CLOCK
                   IN
                        STD_LOGIC;
                        STD LOGIC VECTOR (7 DOWNTO 0);
    DATA IN
                   IN
    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:
 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;
                         STD_LOGIC;
 SIGNAL G_OUT
 SIGNAL DP OUT
                         STD LOGIC;
 SIGNAL CLOCK
                         STD LOGIC:
                         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 \Rightarrow A_OUT,
          B OUT \Rightarrow B OUT,
          C_{OUT} => C_{OUT}
          D OUT \Rightarrow D OUT,
          E_OUT => E_OUT,
          F OUT \Rightarrow 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=00001000;
OP2=00000010;
((OP1 + OP2) - 2) \ll OP2 = 00100000
1) (OP1 + OP2) = 00001000 + 00000010 = 00001010;
2) (OP1 + OP2) - 2 = 00001010 - 00000010 = 00001000;
3) ((OP1 + OP2) - 2) \ll OP2 = 00001000 \ll 00000010 = 001000000;
```





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