# ФЕДЕРАЛЬНОЕ ГОСУДАРСТВЕННОЕ АВТОНОМНОЕ ОБРАЗОВАТЕЛЬНОЕ УЧРЕЖДЕНИЕ ВЫСШЕГО ОБРАЗОВАНИЯ «САМАРСКИЙ НАЦИОНАЛЬНЫЙ ИССЛЕДОВАТЕЛЬСКИЙ УНИВЕРСИТЕТ ИМЕНИ АКАДЕМИКА С.П. КОРОЛЕВА»

Институт информатики и кибернетики

Кафедра радиотехники

Отчет по лабораторной работе "РАЗРАБОТКА ЦИФРОВЫХ УСТРОЙСТВ НА БАЗЕ ПЛИС"

Студент: Согонов Е.А.

Преподаватель: Корнилин Д.В.

Группа: 6364-120304D

# СОДЕРЖАНИЕ

| 1 (  | Часть І                                               | 2 |
|------|-------------------------------------------------------|---|
| 1.1  | Создание проекта и описание устройства с помощью VHDL | 2 |
| 1.2  | Симуляция устройства                                  | 2 |
| 1.3  | Синтез цифрового устройства                           | 4 |
| 1.3. | 1 Временные ограничения                               | 5 |
| 1.4  | РЕАЛИЗАЦИЯ                                            | 6 |
| 1.5  | Индивидуальные задания                                | 6 |
| OT]  | ВЕТЫ НА ВОПРОСЫ ДЛЯ САМОПРОВЕРКИ                      | 6 |

#### 1. Часть I

#### 1.1. Создание проекта и описание устройства с помощью VHDL

По методике, описанной в методических указаниях к лабораторной работе, в программном пакете Vivado v2016.4 был создан проект.

Для описания портов и логики схемы используется файл с описанием устройства на языке VHDL fdc.vhd, содержимое которого можно увидеть ниже:

```
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
entity fdc is
  Port (D 0, D 1: in STD LOGIC;
  C: in STD LOGIC;
  Q: out STD_LOGIC);
end fdc;
architecture Behavioral of fdc is
signal x 0, x 1 : STD LogIC;
begin
  process (C)
  begin
    if rising edge(C) then
             X_0 \le D_0;
             X_1 \le D_1;
  end if;
end process;
  process (C)
  begin
    if rising edge(C) then
             Q \le X 0 and X 1;
    end if:
  end process;
end Behavioral;
```

Данный код описывает в одном модуле всю схему, представленную на рисунке 1. Первый блок process (C) описывает логику D-триггеров DD1 и DD2. Второй блок process (C) – логику конъюнктора DD3 и D-триггера DD4.

## 1.2. Симуляция устройства

Следующий этап - симуляция устройства. Для этого был создан файл симуляции (Test bench) tb\_sim.vhd на языке VHDL, содержимое которого можно увидеть ниже:

```
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
entity tb_sim is
```

```
end tb sim;
architecture Behavioral of tb_sim is
COMPONENT fdc
    PORT (
         C: in STD LOGIC;
         D 0: in STD LOGIC;
         D 1: in STD LOGIC;
         Q: out STD LOGIC);
END COMPONENT;
signal D 0: std logic := '0';
signal D_1 : std_logic := '0';
signal C : std_logic := '0';
signal Q : std_logic := '0';
begin
uut: fdc PORT MAP (
  C => C,
   D \ 0 => D \ 0
   D 1 => D 1,
   Q \Rightarrow Q;
clock: process
    begin
         C \le 0'; wait for 5 ns;
         C \le 1'; wait for 5 ns;
end process;
tb: process
begin
  D 0 \le 0'; D 1 \le 0'; wait for 50 ns;
   D_0 \le '1'; wait for 20 ns;
   D_1 \le '1'; wait for 80 ns;
  D_1 \le 0'; wait for 40 ns;
   D_1 \le 0'; wait for 40 ns;
   D 0 \le '1'; wait for 12 ns;
   D^{-}1 \le \frac{1}{1}; wait for 17 ns;
   D 0 \le 0'; D 1 \le 0'; wait for 50 ns;
end process;
```

#### end Behavioral;

После запуска симуляции были получены временные диаграммы, изображенные на рисунке 1.



Рисунок 1 — Результат симуляции

## 1.3. Синтез цифрового устройства

В этом этапе необходимо было провести тщательный временной анализ, необходимый для обнаружения узких мест и обеспечения эффективной и надежной работы устройства. В результате синтеза была получена следующая схема (рисунок 2)



Рисунок 2 — Синтезированная схема



Рисунок 3 — Принципиальная схема из методических указаний к лабораторной работе

От принципиальной схемы, изображенной в методических указаниях в начале работы (рисунок 3), полученная в результате синтеза схема отличается наличием буферных каскадов IBUF и OBUF(вероятно, это сокращения от input и output buffer), по всей видимости необходимых для согласования по логическим уровням напряжения и согласования сопротивлений.. Так же отличием можно считать элемент BUFG, который нужен, как я понял, для того,

чтобы использовать глобальный тактовый сигнал. Не совсем понял, как это реализовано в железе: это какая-то выделенная шина с тактовым сигналом внутри микросхемы?

#### 1.3.1. Временные ограничения

Тут по моему скромному мнению нужно дохуя почитать харриса или глянуть лекции, потому что я лично понимяю нихуя и только на пальцах в результате все это говно надо связать с рисунком 4



Рисунок 4 — хуевременные задержки

#### 1.4. РЕАЛИЗАЦИЯ

Про автоматическую расстановку портов что то нахуй, или еще что. можно ебануть ту картинку с морским боем

#### 1.5. Индивидуальные задания

- 1. Выясните, какая максимальная частота работы схемы возможна при заданных временных ограничениях.
- 2. Выберите ПЛИС с другими параметрами (опции -2 или -3 в названии) и определите, какая максимальная частота возможна для них.
- 3. Установите вручную положение вывода Clock на E3 и заставьте Vivado автоматически разместить все остальные выводы.
- 4. Вернитесь к этапу моделирования и повторите его используя «Run Post-Synthesis Functional Simulation», «Run Post-Synthesis Timing Simulation», «Run Post-Implementation Functional Simulation» и «Run Post-Implementation Functional Simulation». Сравните полученные результаты с результатами, полученными в разделе 2.
  - 5. Повторите пункт 4, задав другую частоту тактового сигнала.
- 6. Добавьте к наблюдаемым сигналам внутренние сигналы (выходы элемента «И» и триггеров первой ступени) и посмотрите, как выполняются временные соотношения

## ОТВЕТЫ НА ВОПРОСЫ ДЛЯ САМОПРОВЕРКИ

- 1. Какие два подхода к описанию аппаратуры вы знаете? Какой подход вы использовали в лабораторной работе?
- 2. Какие языки описания аппаратуры (HDL) вы знаете? Какой язык вы использовали в лабораторной работе?
- 3. Какой программный пакет и какую ПЛИС вы использовали в лабораторной работе?
  - 4. Опишите стандартный процесс проектирования цифровых устройств.
- 5. Вспомните таблицу переходов D-триггера и таблицу истинности логического вентиля И.
  - 6. Для чего нужна симуляция устройства на поведенческом уровне?
  - 7. Для чего необходимо задавать временные задержки?
- 8. На каком этапе проектирования цифровых устройств строится топология проекта и подключаются внешние выводы?
  - 9. Опишите назначение строк кода в файле fdc.vhd.
  - 10. Опишите назначение строк кода файла симуляции tb sim.vhd.
- 11. Нарисуйте временную диаграмму работы вашего устройства и сравните ее с диаграммой, полученной в результате симуляции.

- 12. Что такое ограничения проектирования и для чего они нужны?
- 13. Какие временные ограничения вы задавали в вашем проекте?