Initial commit

This commit is contained in:
Andrei Solodovnikov
2023-09-07 17:04:37 +03:00
commit f4c0960704
334 changed files with 36105 additions and 0 deletions

View File

@@ -0,0 +1,99 @@
# Создание базового проекта с прошивкой ПЛИС в Vivado
## Создание проекта в Системе Автоматизированного Проектирования (САПР)
1. Запустить Vivado 2019.2
2. Нажать `Create Project`
3. В открывшемся окне нажать Next
4. Ввести название проекта (никаких пробелов и кириллических символов) → Выбрать папку для проектов (создать каталок на D:/) → Поставить галку `Create project subdirectory` → Нажать `Next`
5. Выбрать RTL Project → Поставить галку `Do not specify sources at this time` → Нажать Next
6. Выставить фильтры, для сужения списка ПЛИС:
* Family: `Artix 7`
* Package: `CSG324`,
* Speed: `-1`.
<details>
<summary> Скриншот окна с выставленными фильтрами</summary>
![Скриншот окна с выставленными фильтрами](../.pic/Vivado%20Basics/Vivado%20trainer/fpga_filter.png)
</details>
7. В списке выбрать ПЛИС `xc7a100tcsg324-1` → Нажать Next
8. Нажать Finish
9. Закрыть Vivado
10. Удалить папку
11. Повторить все действия самостоятельно
## Создание модуля на Verilog
1. Создать новый Verilog файл, для этого в окне `Sources` нажать на кнопку `+`
2. В открывшемся окне выбрать `Add or create design source` → Нажать `Next`
3. Нажать `Create File`В открывшемся окне ввести имя модуля `top` → Нажать `OK`В оставшемся окне нажать `Finish`
4. В открывшемся окне НЕ вводить названия портов и сразу нажать OK → После чего подтвердить выбор `Yes`
5. Двойным кликов в окне `Source` открыть файл `top.v`
6. Написать следующий код:
```Verilog
module top (
input clk,
input a,
input b,
output reg q
);
wire c;
assign c = a ^ b;
always @ (posedge clk) begin
q <= c;
end
endmodule
```
7. Сохранить изменения
8. Нажать `Open Elaborated Design`
9. Нажать `Schematic` в открывшемся списке
10. Проанализировать полученный результат (сопоставить с Verilog-описанием)
11. Закрыть проект
## Реализация простого проекта на отладочном стенде
1. Создать новый проект
2. Создать новый Verilog файл с названием basic
3. Написать следующий код:
```Verilog
module basic (
input [15:0] SW,
output [15:0] LED
);
assign LED[0] = SW[0] & SW[1];
assign LED[2] = SW[2] | SW[3];
assign LED[4] = SW[4] ^ SW[5];
assign LED[10:6] = ~SW[10:6];
assign LED[13:11] = {SW[11], SW[12], SW[13]};
assign LED[15:14] = { 2{SW[14]} };
endmodule
```
4. Сохранить изменения
5. В окне Sources нажать на кнопку `+`
6. В открывшемся окне выбрать `Add or create constraints` → Нажать Next
7. Нажать `Create File`В открывшемся окне ввести название → Нажать `OK``Finish`
8. В окне `Source` в открывающемся списке `Constraints` найти только что созданный файл и открыть его дя редактирования двойным щелчком
9. Скопировать содержимое файла констрейнов с [официального сайта](https://github.com/Digilent/digilent-xdc) и вставить в только что созданный → Найти строки посвященные SW и LED и раскомментировать их → Сохранить изменения
10. `Run Synthesis`
11. `Run Implementation`
12. После успешной имплементации нажимаем `Generate Bitstream` для генерации файла прошивки
13. Аккуратно достаем и подключаем стенд к компьютеру → Включаем питание на плате
14. Нажимаем `Open Hardware Manager` (под `Generate Bitstream`)
15. Вместо окна `Source` будет отображаться окно `Hardware`, в нем необходимо нажать кнопку `Auto Connect` (единственная активная кнопка) → В окне появится подключенное устройство
16. Нажать правой кнопкой на устройстве `xc7a100t_0` → Выбрать пункт меню `Program Device`
17. В открывшемся окне нажать `Program`
18. Сопоставить поведение отладочной платы с Verilog-описанием