

Руководство пользователя по работе с программным обеспечением X-CAD

Версия 0.1

# 5400TC015

# Оглавление

| Введение 4                                                                                   |
|----------------------------------------------------------------------------------------------|
| Маршрут проектирования на основе ПЛИС 5                                                      |
| Структура программных директорий                                                             |
| Запуск программы в консольном режиме                                                         |
| Входные данные программы 11                                                                  |
| Библиотеки элементов ПЛИС                                                                    |
| Использование контактных площадок                                                            |
| Файл размещения контактных площадок 16                                                       |
| Использование имен контактных площадок 18                                                    |
| Выполнение статического временного анализа 20                                                |
| Функции, позволяющие получить списки имен по требуемому критерию                             |
| Функции, возвращающие переданные ей значения. Необходимы для совместимости с Synopsys<br>SDC |
| Выходные данные программы                                                                    |
| Примеры запуска программы в консольном режиме 31                                             |
| TCL интерфейс                                                                                |
| Tcl интерфейс управления программой32                                                        |
| Tcl интерфейс для отображения результатов RTL синтеза в базис ПЛИС                           |
| Графический интерфейс Х-САО 34                                                               |
| Запуск программы                                                                             |
| Запуск через обозревателя файлов 34                                                          |
| Запуск через командную строку                                                                |
| Стартовое окно                                                                               |
| Открытие существующего проекта                                                               |
| Мастер создания проекта                                                                      |
| Окно выбора кристалла                                                                        |
| Главное окно для работы с проектом 39                                                        |
| Главное меню рабочего окна                                                                   |
| Панели инструментов                                                                          |
| Обозреватель проекта 41                                                                      |
| Обозреватель проектной директории 44                                                         |
| Окно иерархии проекта                                                                        |
| Окно библиотек проекта                                                                       |
| Текстовый редактор                                                                           |
| Окно «Вывод»                                                                                 |

| Статусная строка                                      | 47 |
|-------------------------------------------------------|----|
| Настройки запуска                                     |    |
| Пример работы программы                               |    |
| Использование внешних программ                        | 51 |
| Icarus Verilog                                        |    |
| Моделирование RTL описания                            | 53 |
| Моделирование синтезированного описания               | 53 |
| Моделирование структурного описания                   |    |
| Моделирование структурного описания после трассировки | 55 |
| GTK Wave                                              | 57 |
| Анализатор HDL-описаний                               |    |
| Интерфейс топологического редактирования X-PLACE      | 59 |
| Запуск программы                                      | 59 |
| Запуск через обозреватель файлов                      | 59 |
| Запуск через командную строку                         | 59 |
| Запуск через интерфейс X-CAD                          | 59 |
| Главное окно для работы с проектом                    | 60 |
| Главное меню                                          | 61 |
| Панели инструментов                                   |    |
| Обозреватель структуры схемы                          |    |
| Обозреватель списка цепей                             | 63 |
| Рабочее графическое поле                              |    |
| Окно «ТсІ консоль»                                    |    |
| Статусная строка                                      |    |
| Пример работы программы                               | 65 |
| Загрузка кристалла                                    | 65 |
| Загрузка схемы                                        |    |
| Загрузка библиотеки элементов                         | 67 |
| Размещение элементов на кристалле                     |    |
| Сохранение полученного размещения                     | 69 |
| Настройки отображения                                 |    |
| Интерфейс планировки кристалла FLOORPLANNER           | 71 |
| Запуск программы                                      | 71 |
| Запуск через обозреватель файлов                      | 71 |
| Запуск через командную строку                         | 71 |
| Запуск через интерфейс X-CAD                          | 72 |
| Интерфейс программы                                   | 72 |
| Главное меню                                          | 73 |
| Панели инструментов                                   | 74 |

| Обозреватель элементов                        | 74 |
|-----------------------------------------------|----|
| Рабочее графическое поле                      | 74 |
| Окно «ТсІ консоль»                            |    |
| Статусная строка                              |    |
| Пример работы программы в режиме FloorPlanner |    |
| Загрузка кристалла                            |    |
| Загрузка схемы                                |    |
| Загрузка библиотеки элементов                 |    |
| Размещение элементов на кристалле             |    |
| Сохранение полученного размещения             | 80 |
| Использование полученного размещения          | 80 |
| Лист регистрации изменений                    | 81 |

#### Введение

Программный пакет X-CAD предназначен для автоматизации этапов логического синтеза, размещения элементов и трассировки межсоединений микросхем, проектируемых на базе программируемых логических интегральных схем (ПЛИС).

В состав пакета программных средств входят:

интерфейсные программы на языке C++, обеспечивающие загрузку схемной и топологической информации из базы данных САПР Cadence в форматах CDL, GDS-II.

Программы на языке C++, интегрированные с языком управления заданиями Tcl и обеспечивающие отображение проектируемой пользовательской схемы на базис элементов библиотеки ПЛИС, а также реализующие прохождение полного маршрута топологического проектирования, состоящего из автоматических процедур планировки, размещения и трассировки межсоединений.

Скрипты на языке Tcl для поддержки функционирования интерфейса программы X-CAD и управления процессом конфигурирования ПЛИС.

Библиотеки стандартных элементов в формате Liberty для автоматического синтеза проектных решений средствами Design Compiler (Synopsys), RTL Compiler (Cadence), Genus (Cadence) или Yosys Open SYnthesis Suite (Yosys).

| 1) | Характеристики ПЛИ | С |
|----|--------------------|---|
|----|--------------------|---|

| Параметры                      | ПЛИС (5400ТС015) |
|--------------------------------|------------------|
| Тех. процесс, нм               | 180              |
| Емкость, ЛЭ                    | 1058             |
| Количество стандартных ЯВВ, шт | 93               |
| Количество тактовых ЯВВ, шт    | 4                |

2) Совместимость со сторонним программным обеспечением:

Cadence Encounter RTL Compiler, Cadence Genus Synthesis Solution, Cadence Spectre Simulation Platform;

Synopsys Design Compiler, Synopsys HSPICE;

Yosys Open SYnthesis Suite;

Icarus Verilog;

OSS CVC Simulator.

3) Поддерживаемые языки описания аппаратуры:

Verilog 2005 (стандарт IEEE 1364-2005).

4) Системные требования:

Операционная система Windows 7 или выше;

Операционная система Red Hat 6 \ Cent OS 6 или выше;

Оперативная память: 8 Гб;

Свободное место на жестком диске: 4 Гб;

Наличие видео драйвера с поддержкой спецификации OpenGL 2.0.

## Маршрут проектирования на основе ПЛИС

Программные средства X-CAD обеспечивают возможность интеграции с существующим коммерческим ПО (при наличии) для выполнения логического синтеза и моделирования общего назначения от компаний Cadence и Synopsys, а также со свободно распространяемым ПО Yosys Open Synthesis Suite. На рисунке ниже изображен маршрут, обеспечивающий интеграцию средств САПР компании Cadence (Рисунок 1):

- 1) Загрузка файла библиотеки стандартных элементов ПЛИС и HDL описания проектируемой пользовательской схемы в программу логического синтеза RTL Compiler / Genus;
- Полученное схемное описание передается в подпрограмму САПР для технологического отображения, размещения и трассировки, после чего происходит проверка проекта на быстродействие с помощью выполнения статического временного анализа (CBA) и моделирования схемы в симуляторе Cadence Spectre;



3) В результате работы САПР генерируется файл прошивки ПЛИС.

Рисунок 1. Маршрут проектирования на ПЛИС с использованием ПО Cadence

На рисунке 2 приведен аналогичный маршрут, обеспечивающий интеграцию с САПР компании Synopsys (Рисунок 2):

- Загрузка файла библиотеки стандартных элементов ПЛИС и HDL описания проектируемой пользовательской схемы в программу логического синтеза Synopsys Design Compiler;
- Полученное схемное описание передается в подпрограмму САПР для технологического отображения, размещения и трассировки, после чего происходит проверка проекта на быстродействие с помощью выполнения статического временного анализа и моделирования схемы в симуляторе HSpice;
- 3) В результате работы САПР генерируется файл прошивки.



Рисунок 2. Маршрут проектирования на ПЛИС с использованием ПО Synopsys

На рисунке 3 приведен маршрут, обеспечивающий интеграцию со свободно распространяемым ПО Yosys Open SYnthesis Suite (Рисунок 3):

- Загрузка файла библиотеки стандартных элементов ПЛИС и HDL описания пользовательской схемы в программу логического синтеза Yosys;
- Полученное схемное описание передается в подпрограмму САПР для технологического отображения, размещения и трассировки, после чего происходит проверка проекта на быстродействие с помощью выполнения статического временного анализа и моделирования схемы в симуляторе lcarus Verilog;
- 3) В результате работы САПР генерируется файл прошивки.



Рисунок 3. Маршрут проектирования на ПЛИС с использованием ПО Yosys

# Структура программных директорий

Структура директории программы X-CAD:

X-CAD # домашняя директория

| bin   | # директория исполняемых модулей |                                                           |  |
|-------|----------------------------------|-----------------------------------------------------------|--|
|       | xcore.exe                        | # модуль для запуска XCORE                                |  |
|       | xcad.exe<br>C                    | # модуль для запуска XCAD, графического интерфейса<br>АПР |  |
|       | xplace.exe                       | # модуль для запуска XPLACE                               |  |
|       | xmap.exe                         | # модуль для запуска ХМАР                                 |  |
|       | xsta.exe                         | # модуль для запуска XSTA                                 |  |
| src   | # директория                     | с исходными файлами                                       |  |
|       | /data                            | # файлы конфигурации ПЛИС                                 |  |
|       | /libraries # (                   | библиотеки для работы с ПЛИС                              |  |
|       | /scripts # j                     | управляющие скрипты                                       |  |
|       | /docs                            | # документация                                            |  |
| lib   | # библиотеки                     | tcl/tk                                                    |  |
| tools | # программны                     | е модули Yosys, IcarusVerilog, GTK Wave, CVC              |  |

#### Запуск программы в консольном режиме

Консольный режим программы выполняется с помощью управляющего скрипта на языке Tcl. Команда запуска из системной консоли имеет следующий вид:

<PATH>/bin/xcore.exe <PATH>/src/scripts/<script> -i <ckt\_file> <options>,

где:

<*PATH*> – домашняя директория САПР X-CAD,

*<script>* – управляющий скрипт на языке Tcl, обеспечивающий запуск главного исполняемого модуля, согласование входных и вывод выходных данных,

<ckt\_file> - полное имя файла с описанием проектируемой схемы,

<options> – опции запуска программы.

Каждая ПЛИС имеет свой управляющий скрипт, адаптированный под ее архитектуру и схемотехнические особенности. Соответствие названия ПЛИС и управляющего скрипта приведено ниже:

5400TC015

XA3

#### Основные опции запуска программы:

| Опция                      | Описание                                                           |  |  |
|----------------------------|--------------------------------------------------------------------|--|--|
| -h                         | вывод на экран краткой справки о программе X-CAD                   |  |  |
| -i <ckt_file></ckt_file>   | имя входного проектного файла формата Verilog или Tcl              |  |  |
| -o <out_name></out_name>   | задание имен выходных файлов                                       |  |  |
| top stop pomos             | определение имени модуля верхнего уровня. Задается в случае        |  |  |
| -top <top_name></top_name> | различия имени входного проектного файла и модуля верхнего уровня. |  |  |
|                            | Управление процессом логического синтеза                           |  |  |
| -rtl                       | синтез с помощью программы Cadence RTL Compiler                    |  |  |
| -gen                       | синтез с помощью программы Cadence Genus                           |  |  |
| -dc                        | синтез с помощью программы Synopsys Design Compiler                |  |  |
| -y++                       | синтез с помощью программы Yosys                                   |  |  |
| Упр                        | авление процессом компоновки и размещения                          |  |  |
|                            | загрузка размещения элементов проектной схемы из заданного файла;  |  |  |
| -p <file></file>           | если размещение содержится вместе с нетлистом в Tcl-файле          |  |  |
|                            | <ckt_file>, следует указать –р "" (пустые кавычки)</ckt_file>      |  |  |
| -inout <file></file>       | загрузка размещения ячеек ввода-вывода (ЯВВ) из заданного файла    |  |  |
| -macro <file></file>       | загрузка размещения макроячеек из заданного файла                  |  |  |
| -ip_place <file></file>    | загрузка размещения IP блоков из заданного файла                   |  |  |
| -le -file>                 | загрузка готовой планировки логических элементов из заданного      |  |  |
|                            | файла                                                              |  |  |
|                            | Управление компоновкой логических элементов:                       |  |  |
|                            | 0 – выключение парной компоновки ЛЭ (компоновка только по сигналу  |  |  |
|                            | SET/RESET);                                                        |  |  |
| -le_union <value></value>  | 1 – компоновка ЛЭ по входам {а   d};                               |  |  |
|                            | 2 – компоновка по всем логическим входам ЛЭ;                       |  |  |
|                            | 3 – максимальный уровень компоновки, в том числе не связанных друг |  |  |
|                            | с другом ЛЭ.                                                       |  |  |
|                            | задание множителя внутреннего цикла алгоритма размещения           |  |  |
|                            | элементов;                                                         |  |  |
| -sa_lm <value></value>     | увеличение значения параметра, увеличивает длительность и          |  |  |
|                            | качество автоматического размещения;                               |  |  |
|                            | <value> - целое число из интервала [11000]</value>                 |  |  |

| Управление процессом трассировки                                               |                                                                                                                 |  |
|--------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|--|
| ordor filo                                                                     | задание пользовательского порядка трассировки цепей проектной                                                   |  |
| -order <me></me>                                                               | схемы, см. описание Tcl команды xc_net_order                                                                    |  |
| -sr <value></value>                                                            | -sr – задание метода перетрассировки перегруженных цепей                                                        |  |
|                                                                                | в процессе автоматической трассировки,                                                                          |  |
|                                                                                | <value> принимает одно из трех значений {0, 1, 2}.</value>                                                      |  |
|                                                                                | -rr – задание метода обхода трассировочных ресурсов ПЛИС,                                                       |  |
|                                                                                | <value> принимает одно из двух значений {0, 1}.</value>                                                         |  |
|                                                                                | Возможные комбинации значений опций:                                                                            |  |
|                                                                                | -sr 2 -rr 1 – по умолчанию: достигается оптимальный результат                                                   |  |
| -rr <value></value>                                                            | по времени и качеству трассировки;                                                                              |  |
|                                                                                | -sr 2 -rr 0 – оптимизация времени трассировки;                                                                  |  |
|                                                                                | -sr 0 -rr 1 – оптимизация объема трассировочных ресурсов.                                                       |  |
|                                                                                | используемых для имплементации проектной схемы;                                                                 |  |
|                                                                                | -sr 0 -rr 0 – отсутствие оптимизации: может быть использована                                                   |  |
|                                                                                | в случае, когда проектная схема не разводится при иных значениях                                                |  |
|                                                                                | коэффициент учета истории перегруженности коммутационного                                                       |  |
| -v h <value></value>                                                           | ресурса при трассировке                                                                                         |  |
|                                                                                | values - пюбое число из интервала [0, 1]                                                                        |  |
|                                                                                | коэффициент, отвечающий за влияние накопленного и собственного                                                  |  |
| -v n <values< td=""><td>базового веса вершины графа трассировки</td></values<> | базового веса вершины графа трассировки                                                                         |  |
|                                                                                | <ul> <li>систерно воса вершины прафа прасопредил,</li> <li>cvalues - пюбое число из интервала [0, 1]</li> </ul> |  |
|                                                                                |                                                                                                                 |  |
| -nath w zvalues                                                                | пля межсоепинений                                                                                               |  |
|                                                                                | для межеосдинении,                                                                                              |  |
|                                                                                |                                                                                                                 |  |
| -nath I -values                                                                | ограничение максимальной длины межсоединения, т.е. количества                                                   |  |
|                                                                                |                                                                                                                 |  |
|                                                                                |                                                                                                                 |  |
|                                                                                |                                                                                                                 |  |
|                                                                                |                                                                                                                 |  |
| -ro fast -values                                                               | -ro fast 1 - $2$                                                                                                |  |
|                                                                                |                                                                                                                 |  |
|                                                                                | The synchronic origin satisfies by the second strategies $-31, -11, -11, -11, -11, -11, -11, -11, $             |  |
|                                                                                | -v_n, -v_p, -раш_w, -раш_ипорируются.<br>Внимание! Опция не может быть включена вместе с опцией -ro. ba         |  |
|                                                                                |                                                                                                                 |  |
|                                                                                | подключение предустановленных значении параметров трассировки                                                   |  |
|                                                                                | для достижения наилучшего качества трассировочного решения,                                                     |  |
| ro ba avalues                                                                  |                                                                                                                 |  |
| -io_iiq <value></value>                                                        |                                                                                                                 |  |
|                                                                                | При включении опции заданные вручную значения параметров -sr, -п,                                               |  |
|                                                                                | -v_n, -v_p, -раш_w, -раш_инорируются.                                                                           |  |
|                                                                                | Внимание! Опция не может обль включена вместе с опцией -го_тазт.                                                |  |
| Управление процессом трассировки: поддержка устаревших опций                   |                                                                                                                 |  |
| -reroute                                                                       |                                                                                                                 |  |
|                                                                                | о – алгоритм А оез разрыва и перетрассировки неразведенных                                                      |  |
|                                                                                |                                                                                                                 |  |
|                                                                                | и, ∠ – алгоритм А с двумя версиями метода разрыва и                                                             |  |
|                                                                                |                                                                                                                 |  |
| -i                                                                             | з – алгоритм Распетноет (включен по умолчанию)                                                                  |  |
| -npup                                                                          | ограничение на количество разрывов и перетрассировок для каждой                                                 |  |
| ro itor                                                                        | цени (учитывается при -reroute {1,2})                                                                           |  |
| -ro_iter                                                                       | ограничение на суммарное количество разрывов и перетрассировок                                                  |  |
|                                                                                | всего списка ценеи (учитывается при -гегоите {1,2})                                                             |  |

#### Входные данные программы

Входными данными для программы может быть описание схемы на разных уровнях представления данных. Так, если **<ckt\_name>** – название проектируемой схемы, то:

- **1.** <**ckt\_name>.v** HDL описание схемы на языке Verilog требует обязательного запуска RTLcompiler, Genus, Design Compiler или Yosys.
- **2.** <ckt\_name>.sv HDL описание схемы на языке System Verilog требует обязательного запуска RTL-compiler, Genus, Design Compiler или Yosys.
- **3.** <ckt\_name>.vhd HDL описание схемы на языке VHDL требует обязательного запуска RTLcompiler, Genus, Design Compiler или Yosys.
- **4.** <**ckt\_name>.syn\_\*.v** синтезированное Verilog описание схемы с использованием библиотечных и периферийных элементов ПЛИС. Файл может быть создан вручную или получен в результате синтеза с помощью RTL-compiler, Genus, Design Compiler, Yosys.
- 5. <ckt\_name>.xmap.tcl описание схемы на языке Tcl с использованием библиотечных элементов ПЛИС (является также одним из выходных файлов работы программы при использовании HDL описания в качестве исходного), как правило, требует наличия файла <ckt\_name>.xmap.lib.tcl.

#### Пример: c17.xmap.tcl, фрагмент

#### #INPUT LIST

set xc\_input { N1 N2 N3 N6 N7 }

#OUTPUT LIST

set xc\_output { N22 N23 }

#INPUT IOs

xc\_inst {XC\_BUF\_N1} ibuf {a=N1 x=XC\_I\_N1} {inp\_io=1}

xc\_inst {XC\_BUF\_N2} ibuf {a=N2 x=XC\_I\_N2} {inp\_io=1} xc\_inst {XC\_BUF\_N3} ibuf {a=N3 x=XC\_I\_N3} {inp\_io=1}

*xc\_inst* {*XC\_BUF\_N6*} *ibuf* {*a*=*N6 x*=*XC\_I\_N6*} {*inp\_io*=1}

*xc\_inst* {*XC\_BUF\_N7*} *ibuf* {*a*=*N7 x*=*XC\_I\_N7*} {*inp\_io*=1}

#OUTPUT IOs

```
xc_inst {XC_BUF_N22} obuf {a=XC_O_N22 x=N22} {out_io=1}
```

*xc\_inst* {*XC\_BUF\_N23*} *obuf* {*a=XC\_O\_N23 x=N23*} {*out\_io=1*}

#LUTs

```
xc_inst {_1_} LE_cell_i3_11 { d=_0_c=XC_I_N3 b=XC_I_N1 y=XC_0_N22 }
xc_inst {_2_} LE_cell_i4_107 { d=XC_I_N7 c=XC_I_N2 b=XC_I_N6 a=XC_I_N3 y=XC_0_N23 }
xc_inst {_3_} LE_cell_i3_11 { d=XC_I_N2 c=XC_I_N6 b=XC_I_N3 y=_0_ }
```

- 6. <ckt\_name>.inout.tcl файл размещения периферийных площадок ЯВВ. Подробное описание и примеры использования представлены в разделе «Использование файла размещения контактных площадок»
- **7.** <**ckt\_name>.place.tcl** файл размещения логических элементов, содержащий команды на языке Tcl вида:
- xc\_map\_inst <имя элемента> <имя посадочной площадки>

#### Пример:

xc\_map\_inst cell\_1 ILAB0101.ILE0701.ILE1 xc\_map\_inst cell\_2 ILAB0101.ILE0801.ILE1 ... xc\_map\_inst cell\_N ILAB0101.ILE1201.ILE2

8. <ckt\_name>.le.tcl – файл компоновки логических ячеек в логические элементы на языке Tcl вида:

```
хс le <имя ЛЭ> {<имя ячейки> < имя ячейки >}
```

#### Пример:

```
xc_le LE_0 { cell_1 cell_3 }
xc_le LE_1 { cell_2 }
...
xc_le LE_N { cell_N }
```

## Библиотеки элементов ПЛИС

Библиотеки элементов ПЛИС расположены в соответствующих поддиректориях **X-CAD/src/libraries/<chip>/<lib\_case>**, где **<chip>** определяется в соответствии с таблицей:

5400TC015 – XA3

lib\_case> – один из доступных углов характеризации:

- PwcV1.65T125 худший случай (напряжение 1.65 В, температура 125°С)
- PtcV1.80T25 стандартный (напряжение 1.8 В, температура 25°С)
- **PbcV1.95Tm40** лучший случай (напряжение 1.95 В, температура -40°С)

Библиотеки представлены в следующих форматах:

- \*.tcl описание конфигурирования элементов ПЛИС.
- \*.lib библиотека элементов в стандарте Liberty.
- \*.v библиотека элементов в формате Verilog.

Специальные обозначения, используемые в названиях библиотек:

- LE библиотека логических элементов ПЛИС.
- ІО библиотека элементов ввода-вывода ПЛИС.
- **RE** библиотека коммутационных элементов ПЛИС.

#### Использование контактных площадок

Автоматизация представленного маршрута проектирования подразумевает автоматическую генерацию экземпляров модулей ячеек ввода-вывода на основании списков имен входных и выходных портов Verilog-описания схемы.

Уникальное имя, присваиваемое экземпляру ячейки, имеет вид:

XC\_BUF\_<имя порта>

У входной ячейки имя внутреннего сигнала, входящего в ПЛИС, принимает вид:

XC I <имя порта>

У выходной ячейки имя внутреннего сигнала, приходящего из ПЛИС, принимает вид:

XC О <имя порта>

У входной и выходной ячеек, предназначенных для тактового сигнала, имя внутреннего сигнала принимает вид:

XC C <имя порта>

Внешние сигналы ячеек ввода/вывода, связанные с периферией, сохраняют имя соответствующего им порта из Verilog-описания устройства.

**Пример** автоматически сгенерированных экземпляров модулей входной, выходной и тактовых ячеек:

```
xa_ib XC_BUF_G0 (.a(XC_I_G0), .x(G0));
xa_ob XC_BUF_G17 (.a(G17), .x(XC_0_G17));
xa_clk_ib XC_BUF_CK (.a(XC_C_CK), .x(CK));
xa_clk_ob XC_BUF_CK out (.a(CK_out), .x(XC_C_CK_out));
```

Экземпляр модуля ячейки ввода/вывода может быть добавлен вручную в соответствии с тем стандартом языка аппаратуры, который поддерживается используемым программным обеспечением для выполнения логического синтеза.

Пример добавленных вручную экземпляров модулей входной и выходной ячеек:

xa\_ib u1 (.a(G0), .x(G0\_int)); xa ob u2 (.a(G17 int), .x(G17));

Пример добавленных вручную экземпляров модулей входной и выходной тактовых ячеек:

xa\_clk\_ib clk1 (.a(CK), .x(CK\_int)); xa\_clk\_ob clk2 (.a(CK\_int), .x(CK\_out));

Использование выходной тактовой ячейки (как автоматически сгенерированной, так и добавленной пользователем) возможно только в том случае, когда выходной тактовый сигнал повторяет входной (когда выходному тактовому сигналу назначается входной).

Данная ситуация показана на следующем примере:

Также пользователю доступно использование специализированной контактной площадки PAD\_RST, позволяющей глобально осуществить сброс всех триггеров на кристалле ПЛИС.

Для назначения сигнала сброса на данную контактную площадку необходимо при разработке Verilog-описания задать этому сигналу имя «GRESET».

Пример использования контактной площадки глобального сброса:

#### Файл размещения контактных площадок

<ckt\_name>.inout.tcl – файл размещения периферийных площадок ПЛИС. Файл имеет следующий синтаксис описания:

```
set xc(inout) {
{
        <ums nopma > <ums контактной площадки>}
....
{<ums nopma > <ums контактной площадки>}
}
set xc(inout_type) {
        <ums nopma > <mun площадки > <nuн площадки>}
....
{<ums nopma > <mun площадки > <nuн площадки>}
},
```

где <*ums порта*> - имя входного/выходного порта RTL описания схемы; <*ums контактной площадки*> - имя контактной площадки ПЛИС, на которой размещен порт, <*mun площадки*> - тип контактной площадки / имя библиотечного элемента контактной площадки; <*пин площадки*> - пин контактной площадки, к которому подключен порт

Входные/выходные порты RTL описания схемы, отсутствующие в файле **<ckt\_name>.inout.tcl**, будут размещены на контактные площадки автоматически.

Пример Verilog-описания и соответствующего ему файла размещения контактных площадок:

```
module fa ( input a, b, c, output sum, carry );
wire d,e,f;
wire a_in;
xa_ib m0 (.a(a), .x(a_in));
xor(sum,a_in,b,c);
and(d,a_in,b);
and(e,b,c);
and(f,a_in,c);
or(carry,d,e,f);
endmodule
```

m0 – пример определенного вручную экземпляра ячейки ввода/вывода. Экземпляры ячеек для сигналов b, c, carry будут добавлены автоматически. Площадка для сигналов a и sum назначаются в соответствии с inout-файлом. Площадки для b, c, carry будут назначены автоматически.

```
set xc(inout) {
    { a DIN2}
    { sum DOUT59}
}
set xc(inout_type) {
    { a xa_ib a}
    { sum xa_ob x}
}
```

Файл **<ckt\_name>.inout.tcl** может быть получен при помощи интерфейса планировки кристалла FloorPlanner. Подробное описание работы с данной программой представлено в разделе Интерфейс планировки кристалла FLOORPLANNER.

Файл с размещением периферийных площадок должен быть подключен к проекту с помощью опции *-inout* в консольном или в графическом режиме.

# Использование имен контактных площадок

Автоматическую генерацию и размещение ЯВВ можно выполнить, используя в Verilog-описании схемы названия портов, совпадающие с именем контактной площадки. Имена контактных площадок заданы в соответствии с их назначением и именами внешних портов ПЛИС. Доступные контактные площадки для кристалла **5400TC015** представлены в таблицах ниже.

| Название входа | Название выхода | Назначение входа | Назначение выхода |
|----------------|-----------------|------------------|-------------------|
| DIN_CLK1       | DOUT _CLK1      | GCLK1            | GCLK1             |
| DIN_CLK2       | DOUT_CLK2       | GCLK2            | GCLK2             |
| DIN_CLK3       | DOUT_CLK3       | GCLK3            | GCLK3             |
| DIN_CLK4       | DOUT _CLK4      | GCLK4            | GCLK4             |
| DIN1           | DOUT1           | DIO[1]           | DIO[1]            |
| DIN2           |                 | DIO[2]           |                   |
|                | DOUT3           |                  | DIO[2]            |
| DIN4           | DOUT4           |                  | DIO_OE[2]         |
| DIN5           |                 | DIO[3]           |                   |
|                | DOUT6           |                  | DIO[3]            |
| DIN7           | DOUT7           |                  | DIO_OE[3]         |
| DIN8           |                 | DIO[4]           |                   |
|                | DOUT9           |                  | DIO[4]            |
| DIN10          | DOUT10          |                  | DIO_OE[4]         |
| DIN11          | DOUT11          | DIO[5]           | DIO[5]            |
| DIN12          |                 | DIO[6]           |                   |
|                | DOUT13          |                  | DIO[6]            |
| DIN14          | DOUT14          |                  | DIO_OE[6]         |
| DIN15          |                 | DIO[7]           |                   |
|                | DOUT16          |                  | DIO[7]            |
| DIN17          | DOUT17          |                  | DIO_OE[7]         |
| DIN18          |                 | DIO[8]           |                   |
|                | DOUT19          |                  | DIO[8]            |
| DIN20          | DOUT20          |                  | DIO_OE[8]         |
| DIN21          | DOUT21          | DIO[9]           | DIO[9]            |
| DIN22          |                 | DIO[10]          |                   |
|                | DOUT23          |                  | DIO[10]           |
| DIN24          | DOUT24          |                  | DIO_OE[10]        |
| DIN25          |                 | DIO[11]          |                   |
|                | DOUT26          |                  | DIO[11]           |
| DIN27          | DOUT27          |                  | DIO_OE[11]        |
| DIN28          |                 | DIO[12]          |                   |
|                | DOUT29          |                  | DIO[12]           |
| DIN30          | DOUT30          |                  | DIO_OE[12]        |
| DIN31          | DOUT31          | DIO[13]          | DIO[13]           |
| DIN32          |                 | DIO[14]          |                   |
|                | DOUT33          |                  | DIO[14]           |
| DIN34          | DOUT34          |                  | DIO_OE[14]        |
| DIN35          |                 | DIO[15]          |                   |
|                | DOUT36          |                  | DIO[15]           |
| DIN37          | DOUT37          |                  | DIO_OE[15]        |
| DIN38          |                 | DIO[16]          |                   |
|                | DOUT39          |                  | DIO[16]           |
| DIN40          | DOUT40          |                  | DIO_OE[16]        |
| DIN41          | DOUT41          | DIO[17]          | DIO[17]           |

| DIN42 |        | DIO[18] |            |
|-------|--------|---------|------------|
|       | DOUT43 |         | DIO[18]    |
| DIN44 | DOUT44 |         | DIO_OE[18] |
| DIN45 |        | DIO[19] |            |
|       | DOUT46 |         | DIO[19]    |
| DIN47 | DOUT47 |         | DIO_OE[19] |
| DIN48 |        | DIO[20] |            |
|       | DOUT49 |         | DIO[20]    |
| DIN50 | DOUT50 |         | DIO_OE[20] |
| DIN51 | DOUT51 | DIO[21] | DIO[21]    |
| DIN52 |        | DIO[22] |            |
|       | DOUT53 |         | DIO[22]    |
| DIN54 | DOUT54 |         | DIO_OE[22] |
| DIN55 |        | DIO[23] |            |
|       | DOUT56 |         | DIO[23]    |
| DIN57 | DOUT57 |         | DIO_OE[23] |
| DIN58 |        | DIO[24] |            |
|       | DOUT59 |         | DIO[24]    |
| DIN60 | DOUT60 |         | DIO_OE[24] |
| DIN61 | DOUT61 | DIO[25] | DIO[25]    |
| DIN62 |        | DIO[26] |            |
|       | DOUT63 |         | DIO[26]    |
| DIN64 | DOUT64 |         | DIO_OE[26] |
| DIN65 |        | DIO[27] |            |
|       | DOUT66 |         | DIO[27]    |
| DIN67 | DOUT67 |         | DIO_OE[27] |
| DIN68 |        | DIO[28] |            |
|       | DOUT69 |         | DIO[28]    |
| DIN70 | DOUT70 |         | DIO_OE[28] |
| DIN71 | DOUT71 | DIO[29] | DIO[29]    |
| DIN72 |        | DIO[30] |            |
|       | DOUT73 |         | DIO[30]    |
| DIN74 | DOUT74 |         | DIO_OE[30] |
| DIN75 |        | DIO[31] |            |
|       | DOUT76 |         | DIO[31]    |
| DIN77 | DOUT77 |         | DIO_OE[31] |
| DIN78 |        | DIO[32] |            |
|       | DOUT79 |         | DIO[32]    |
| DIN80 | DOUT80 |         | DIO_OE[32] |
| DIN81 | DOUT81 | DIO[33] | DIO[33]    |
| DIN82 |        | DIO[34] |            |
|       | DOUT83 |         | DIO[34]    |
| DIN84 | DOUT84 |         | DIO_OE[34] |
| DIN85 |        | DIO[35] |            |
|       | DOUT86 |         | DIO[35]    |
| DIN87 | DOUT87 |         | DIO_OE[35] |
| DIN88 |        | DIO[36] |            |
|       | DOUT89 |         | DIO[36]    |
| DIN90 | DOUT90 |         | DIO_OE[36] |

#### Выполнение статического временного анализа

Запуск выполнения статического временного анализа (CBA) проектируемой схемы производится в автоматическом режиме. Для установки тактовых сигналов, определения временных ограничений и изменения других настроек CBA следует использовать опции запуска.

| Основные оп | ции запуска | CBA: |
|-------------|-------------|------|
|-------------|-------------|------|

| Управление процессом статического временного анализа |                                                                 |  |  |
|------------------------------------------------------|-----------------------------------------------------------------|--|--|
| -clk <list></list>                                   | – определение списка тактовых сигналов в проекте                |  |  |
| -per <list></list>                                   | – определение значений периодов тактовых сигналов               |  |  |
| -sta_rise <value></value>                            | – определение времени нарастания входного сигнала               |  |  |
| -sta_fall <value></value>                            | – определение времени спада входного сигнала                    |  |  |
| -sta_tran <value></value>                            | – определение времени нарастания и спада входного сигнала       |  |  |
| -sta_max_delay                                       | – определение значения максимальной задержки на главных выходах |  |  |
| <value></value>                                      | схемы                                                           |  |  |
| -sta_num_crit                                        |                                                                 |  |  |
| <value></value>                                      | - определение количества критических путей, выведенных в отчет  |  |  |
| -sta sdc -file paths                                 | – определение полного пути до файла временными ограничениями    |  |  |
|                                                      | проекта                                                         |  |  |

Результаты CBA генерируются по завершению работы программы в папку <top\_name>.STA.reports.

Результатом проведенного СВА схемы до этапа трассировки является следующий набор файлов:

- <top\_name>.gate.nworst.txt временной отчет для заданного количества наиболее медленных критических путей;
- <top\_name>.gate.sdf файл с задержками и заданными временными ограничениями.

Результатом проведенного СВА схемы после этапа трассировки является следующий набор файлов:

- <top\_name>.routed.nworst. txt временной отчет для заданного количества наиболее медленных критических путей;
- <top\_name>.routed.sdf файл с задержками и заданными временными ограничениями.

#### Доступные временные ограничения для использования в SDC файле:

| create_clock           | set_multicycle_path  |
|------------------------|----------------------|
| set_clock_latency      | set_input_transition |
| set_clock_uncertainty  | set_input_delay      |
| set_clock_transition   | set_output_delay     |
| set_propagated_clock   | set_max_delay        |
| create_generated_clock | set_min_delay        |
| set_false_path         | set_load             |
| set_disable_timing     | set_case_analysis    |

• create\_clock – добавить к анализу тактовый сигнал, его источник, период, время нарастания и спада сигнала.

| <b>create_clock</b> -period <t_per> [-waveform <t_rise> <t_fall>]</t_fall></t_rise></t_per> |                                                                                                                                                                                                   |  |  |  |  |  |  |  |  |
|---------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|
| <source/> ,                                                                                 |                                                                                                                                                                                                   |  |  |  |  |  |  |  |  |
| -period <t_per> _</t_per>                                                                   | задать период задаваемого тактового сигнала. <t_per> – время<br/>периода тактового сигнала, задается в нс или МГц;</t_per>                                                                        |  |  |  |  |  |  |  |  |
| -waveform<br><t_rise> <t_fall></t_fall></t_rise>                                            | задать коэффициент заполнения тактового сигнала.<br>По умолчанию, коэффициент заполнения равен 50%,<br>что эквивалентно <t_rise> = 0 нс,<br/><t_fall> = (<t_per>/2) нс.</t_per></t_fall></t_rise> |  |  |  |  |  |  |  |  |
|                                                                                             | <t_rise> <t_fall> – время начала нарастания и начала спада<br/>сигнала.<br/>источник создаваемого синхросигнала (порт, пин).</t_fall></t_rise>                                                    |  |  |  |  |  |  |  |  |
| <source/> -                                                                                 | По умолчанию тактовый сигнал будет назван по имени<br>источника. При желании можно указать имя тактового с<br>помощью опции -name.                                                                |  |  |  |  |  |  |  |  |

create\_clock -period 5 [get\_ports CLK1]

create\_clock -period 5 -waveform {1 2}[get\_ports CLK2]

Результат определения коэффициента заполнения тактового сигнала по умолчанию и с использованием опции – waveform показан на рисунке 4.



Рисунок 4. Диаграммы тактовых сигналов

#### • set\_clock\_latency – установить время задержки тактового сигнала.

set\_clock\_latency [-rise/-fall] [-min][-max] [-source] [-late] [-early]
<delay\_value> <name>,

| -rise   | _ | задать з                                               | задержку   | только    | при    | нарастании   | тактового |  |  |  |  |
|---------|---|--------------------------------------------------------|------------|-----------|--------|--------------|-----------|--|--|--|--|
|         |   | сигнала;                                               | сигнала;   |           |        |              |           |  |  |  |  |
| -fall   | — | задать задержку только при убывании тактового сигнала; |            |           |        |              |           |  |  |  |  |
| -min    | _ | задать                                                 | только     | минимал   | ьную   | задержку     | тактового |  |  |  |  |
|         |   | сигнала;                                               |            |           |        |              |           |  |  |  |  |
| -max    | _ | задать<br>сигнала;                                     | ТОЛЬКО     | максимал  | ьную   | задержку     | тактового |  |  |  |  |
| -source | _ | задать то                                              | олько зад  | ержку зад | ержка  | источника;   |           |  |  |  |  |
| -late   | _ | задать то                                              | олько поз, | днее врем | ия при | бытия от ист | очника;   |  |  |  |  |
|         |   |                                                        |            |           |        |              |           |  |  |  |  |

| -early                      | - | задать только раннее время прибытия от источника; |        |           |          |     |          |  |  |  |
|-----------------------------|---|---------------------------------------------------|--------|-----------|----------|-----|----------|--|--|--|
| <delay_value></delay_value> | - | значение вр                                       | емени  | задержки; |          |     |          |  |  |  |
| <pre>&gt;</pre>             | _ | установить                                        | имя    | тактового | сигнала, | для | которого |  |  |  |
|                             | _ | задается зад                                      | держка | a.        |          |     |          |  |  |  |

Задержка clock latency состоит из двух:

- source latency задержка источника время, требуемое синхросигналу, для распространения от источника до точки, указанной в проекте.
- **network\_latency** задержка сети время, требуемое синхросигналу, чтобы дойти от точки, указанной в проекте, до тактового вывода последовательностного элемента.

В данном случае задержкой источника является задержка ЯВВ, которая добавляется в проект автоматически. Её задержка определяется программой из характеризованной библиотеки.

Задержка сети определяется программой за счет оценки реальных трассировочных элементов, используемых в схеме для коммутации межсоединений. Их задержка также передается из характеризованной библиотеки.

Пример использования команды:

set\_clock\_latency -rise -max 0.34 CLK1

• set\_clock\_uncertainty – установить время, на которое отклоняется тактовый сигнал от идеального при распространении на различные приемники после трассировки.

set\_clock\_uncertainty [-setup/-hold] [-rise/-fall]

-from <clk names> -to <clk names> <uncertainty>,

| -setup                        | _ | задать погрешность только для времени установки;          |  |  |  |  |  |  |  |  |  |
|-------------------------------|---|-----------------------------------------------------------|--|--|--|--|--|--|--|--|--|
| -hold                         | _ | задать погрешность только для времени удержания;          |  |  |  |  |  |  |  |  |  |
| -rise                         | _ | задать погрешность во время нарастании тактового сигнала; |  |  |  |  |  |  |  |  |  |
| -fall                         | _ | задать погрешность во время спада тактового сигнала;      |  |  |  |  |  |  |  |  |  |
| -from <clk_names></clk_names> | - | задать список тактовых сигналов, являющихся начальными    |  |  |  |  |  |  |  |  |  |
|                               |   | точками анализируемого пути;                              |  |  |  |  |  |  |  |  |  |
| -to colk names                |   | задать список тактовых сигналов, являющихся конечными     |  |  |  |  |  |  |  |  |  |
|                               | _ | точками анализируемого пути;                              |  |  |  |  |  |  |  |  |  |
| <uncertainty></uncertainty>   | _ | задать значение погрешности.                              |  |  |  |  |  |  |  |  |  |

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

Пример использования команды:

set\_clock\_uncertainty -rise -from CLK1 -to CLK2 0.34

• set\_clock\_transition – установить время переключения тактового сигнала.

set\_clock\_transition [-rise/-fall] <transition time>,

<clock name>

#### 5400TC015

| -rise                               | _ | задать только время нарастания тактового сигнала;          |
|-------------------------------------|---|------------------------------------------------------------|
| -fall                               | _ | задать только время спада тактового сигнала;               |
| <transition_time></transition_time> | — | задать значение времени переключения;                      |
| <clock_name></clock_name>           |   | задать список тактовых сигналов, которым будет установлено |
|                                     | _ | заданное значение времени переключения.                    |

Пример использования команды:

set\_clock\_transition -rise 0.15 CLK1

• set\_propagated\_clock – распространить задержки тактового сигнала и автоматически определить задержку на каждом тактовом пине регистра с учетом добавленных паразитных элементов.

set\_propagated\_clock <clock name>,

<clock\_name> – задать список тактовых сигналов..

Пример использования команды:

set\_propagated\_clock CLK1

• create\_generated\_clock – добавить к анализу тактовый сигнал, производный от основного тактового сигнала, деленный, помноженнный или инвертированный внутренним элементом схемы.

| create_generated_clock              |   | -name      | <c2< th=""><th>lock_name&gt;</th><th>&gt;</th><th>-so</th><th>urce</th><th><mast< th=""><th>cer_name&gt;</th></mast<></th></c2<> | lock_name>   | >       | -so   | urce      | <mast< th=""><th>cer_name&gt;</th></mast<> | cer_name> |
|-------------------------------------|---|------------|----------------------------------------------------------------------------------------------------------------------------------|--------------|---------|-------|-----------|--------------------------------------------|-----------|
| [-divide_by divide_factor           |   | -multiply_ | _by                                                                                                                              | multiply_    | _facto  | or]   | [-duty_   | cycle                                      | percent]  |
| [-invert] <source/> ,               |   |            |                                                                                                                                  |              |         |       |           |                                            |           |
| -name <clk_name></clk_name>         | _ | имя созда  | ваем                                                                                                                             | иого синхрос | сигнала | a;    |           |                                            |           |
| -source <master_name></master_name> | _ | имя источі | ника                                                                                                                             | основного о  | синхро  | сигн  | ала (порт | г, пин);                                   |           |
| -divide_by factor                   | _ | коэффици   | ент ,                                                                                                                            | деления сиг  | тнала;  |       |           |                                            |           |
| -multiply_by factor                 | _ | коэффици   | ент                                                                                                                              | умножения    | сигнал  | a;    |           |                                            |           |
| -duty_cycle percent                 | _ | коэффици   | ент                                                                                                                              | заполнения   | в проц  | цента | ax;       |                                            |           |
| -invert                             | _ | инверсия,  | созд                                                                                                                             | цаваемого с  | инхрос  | игна  | ла;       |                                            |           |
| <source/>                           | _ | источник с | озда                                                                                                                             | аваемого си  | нхроси  | ігнал | а (порт,  | пин);                                      |           |

Например, рассмотрим схему, изображенную на рисунке 5, выполняющая деление тактового сигнала на 3 (Рисунок 5).



Рисунок 5. Схема деления тактового сигнала

Основной тактовых сигнал CLK и производный от него CLKDIV3 задаются программе следующим образом:

```
create_clock period 2 -name CLK [get ports CLK]
```

create\_generated\_clock -name CLKDIV3 -source [get\_ports CLK] -divide\_by 3 duty\_cycle 67 [get\_pins DFF2/Q]

Формы заданных тактовых сигналов представлены на рисунке ниже (Рисунок 6).



Рисунок 6. Временные диаграммы основного и производного тактовых сигналов

• **set\_false\_path** – исключить заданный путь из временного анализа. Команда определяет заданные пути ложными и удаляет временные ограничения на этих путях.

Ложные временные пути – это пути, по которым не распространяется изменение логического уровня.

set\_false\_path [-setup/-hold] [-rise/-fall] -through {node list} -from {node
list} -to {node list},

| -setup          | _ | исключить                                                 | ИЗ     | временного     | анализа     | проверку    | времени  |  |  |  |  |  |
|-----------------|---|-----------------------------------------------------------|--------|----------------|-------------|-------------|----------|--|--|--|--|--|
| beeap           |   | установки заданного сигнала;                              |        |                |             |             |          |  |  |  |  |  |
| -hold           | _ | исключить                                                 | ИЗ     | временного     | анализа     | проверку    | времени  |  |  |  |  |  |
| nora            |   | удержания :                                               | задаі  | нного сигнала; | ;           |             |          |  |  |  |  |  |
| -rise           | _ | исключить и                                               | із вре | еменного анал  | иза элеме   | нты, тактир | ующиеся  |  |  |  |  |  |
| 1100            |   | нарастающим фронтом заданного тактового сигнала;          |        |                |             |             |          |  |  |  |  |  |
| -fall           | _ | исключить из временного анализа элементы, тактирующиеся   |        |                |             |             |          |  |  |  |  |  |
|                 |   | убывающим фронтом заданного тактового сигнала;            |        |                |             |             |          |  |  |  |  |  |
| -through {list} | _ | задать спи                                                | сок    | пинов, порто   | в или яче   | еек, через  | которые  |  |  |  |  |  |
| chilough (110c) |   | должны про                                                | ходи   | ть ложные пу   | ти;         |             |          |  |  |  |  |  |
|                 |   | задать список начальных точек исключаемого временного     |        |                |             |             |          |  |  |  |  |  |
| -from {list}    | _ | пути – тактовые сигналы, входные порты, входные тактовые  |        |                |             |             |          |  |  |  |  |  |
|                 |   | пины после,                                               | дова   | тельностных я  | чеек;       |             |          |  |  |  |  |  |
|                 |   | задать список конечных точек исключаемого временного пути |        |                |             |             |          |  |  |  |  |  |
| -to {list}      | - | - тактовые                                                | сигна  | алы, выходные  | е порты, вх | одные пин   | ы данных |  |  |  |  |  |
|                 |   | последовательностных ячеек;                               |        |                |             |             |          |  |  |  |  |  |

Пример использования команды:

set\_false\_path -to [get\_clocks CLK]

Данная команда объявляет пути, тактируемые в конечных точках сигналом CLK, на рисунке 7 ложными, т.е. исключает из временного анализа все пути (Рисунок 7).

set\_false\_path -fall -to [get\_clocks CLK]

Данная команда объявляет пути, тактируемые в конечных точках убывающим фронтом сигнала CLK, на рисунке 7 ложными, т.е. исключает из временного анализа пути В и С.



Рисунок 7. Схема, поясняющая использование ложных путей

 set\_disable\_timing – удалить из временного анализа все объекты (ячейки, пины или порты) на заданном пути.

Эта команда полностью удаляет из временного анализа встретившиеся на пути объекты, в отличие от команды **set\_false\_path**, которая исключает только конкретный путь, а не вычисление задержки объектов этого пути. Если все пути через определенный пин – ложные, то применение **set\_disable\_timing** более эффективно, чем **set\_false\_path**.

set\_disable\_timing {[-from pin\_name] | [-to pin\_name]} <cell\_list>,

| -from pin_name          | - | задать начальный пин исключаемого временного пути;       |
|-------------------------|---|----------------------------------------------------------|
| -to pin_name            |   | задать конечный пин исключаемого временного пути;        |
|                         |   | Для работы команды необходимо задать одновременно        |
|                         |   | как пин начала пути, так и пин, показывающий конец пути. |
| <cell_list></cell_list> | - | задать список ячеек, удаляемых из временного анализа     |
|                         |   | для заданного пути;                                      |

set\_disable\_timing -from DFF1/D -to DFF2/Q {DFF1 DFF2}

• **set\_multicycle\_path** – установить путь, занимающий несколько тактов, для проверки времени установки и времени удержания.

set multicycle path ncycles [-setup/-hold] [-rise/-fall]

-through {node list} -from {node list} -to {node list},

| ncvcles           | количество циклов тактового сиг                      | нала, которое требуется                            |  |  |  |  |  |  |  |
|-------------------|------------------------------------------------------|----------------------------------------------------|--|--|--|--|--|--|--|
| ncycreb           | данным для проверки времени уст                      | данным для проверки времени установки и удержания; |  |  |  |  |  |  |  |
| -sotup            | изменить количество циклов та                        | актового сигнала только                            |  |  |  |  |  |  |  |
| Secup             | для проверки времени установки;                      |                                                    |  |  |  |  |  |  |  |
|                   | изменить количество циклов такт                      | ового сигнала только для                           |  |  |  |  |  |  |  |
| -hold             | – проверки времени удержания.                        | По умолчанию время                                 |  |  |  |  |  |  |  |
|                   | удержания проверяется на ncycles                     | - 1 такте;                                         |  |  |  |  |  |  |  |
| -rise             | <ul> <li>изменить количество циклов нарас</li> </ul> | стания тактового сигнала;                          |  |  |  |  |  |  |  |
| -fall             | <ul> <li>изменить количество циклов убыва</li> </ul> | ания тактового сигнала;                            |  |  |  |  |  |  |  |
| there were (list) | задать список пинов, портов ил                       | и ячеек, через которые                             |  |  |  |  |  |  |  |
|                   | проходит устанавливаемый путь;                       |                                                    |  |  |  |  |  |  |  |
|                   | задать список начальных точек                        | устанавливаемого пути –                            |  |  |  |  |  |  |  |
| -from {list}      | – тактовые сигналы, входные порть                    | , входные тактовые пины                            |  |  |  |  |  |  |  |
|                   | последовательностных ячеек;                          |                                                    |  |  |  |  |  |  |  |
|                   | задать список конечных точек у                       | /станавливаемого пути –                            |  |  |  |  |  |  |  |
| -to {list}        | – тактовые сигналы, выходные порт                    | гы, входные пины данных                            |  |  |  |  |  |  |  |
|                   | последовательностных ячеек;                          |                                                    |  |  |  |  |  |  |  |

Пример использования команды:

set\_multicycle\_path 4 -setup -from [get\_ports CLK]

• set\_input\_transition – установить время переключения на входах схемы.

set\_input\_transition <value> <input name list> [r / f],

| _                                        | значение времени переключения;                            |  |  |  |  |  |  |  |
|------------------------------------------|-----------------------------------------------------------|--|--|--|--|--|--|--|
| -                                        | список входов, которым будет присвоено заданное значение; |  |  |  |  |  |  |  |
| -                                        | установить время нарастания сигнала на заданных входах;   |  |  |  |  |  |  |  |
| _                                        | установить время спада сигнала на заданных входах;        |  |  |  |  |  |  |  |
|                                          | По умолчанию, если не заданы опции г/f, заданное время    |  |  |  |  |  |  |  |
| переключения установится как для нараста |                                                           |  |  |  |  |  |  |  |
|                                          | для спада.                                                |  |  |  |  |  |  |  |
|                                          | _                                                         |  |  |  |  |  |  |  |

set\_input\_transition 1.5 [get\_inputs]

• **set\_input\_delay** – установить время задержки прибытия входного сигнала относительно основного тактового сигнала.

set input delay <input delay value> <net name list>

[-clock <related clock>],

| <input_delay value=""></input_delay> | - | значение времени задержки; |         |        |          |          |                    |             |  |
|--------------------------------------|---|----------------------------|---------|--------|----------|----------|--------------------|-------------|--|
| <net list="" name=""></net>          | _ | задать                     | списо   | к вхс  | одов, н  | которым  | будет              | присвоено   |  |
|                                      |   | заданное значение;         |         |        |          |          |                    |             |  |
| -clock <related clock=""></related>  | _ | установ                    | ить и   | мя т   | гактовог | го сигна | ла, о <sup>.</sup> | тносительно |  |
|                                      |   | которого                   | о прихо | дит вх | ходной   | сигнал;  |                    |             |  |

Пример использования команды:

set input delay 0.344 {IN1 IN2} [-clock CLK]

• set\_output\_delay – установить время задержки прибытия выходного сигнала до последовательностной логики вне проекта относительно основного тактового сигнала.

set\_output\_delay <output delay value> <net name list>,

[<related clock>],

| <output_delay value=""></output_delay> | - | значение   | времен  | и задерж  | ки;        |        |             |
|----------------------------------------|---|------------|---------|-----------|------------|--------|-------------|
| <pre><pre>name list&gt;</pre></pre>    | _ | задать с   | список  | входов,   | которым    | будет  | присвоено   |
|                                        | _ | заданное   | значен  | ие;       |            |        |             |
| -clock                                 |   | установит  | гь имя  | а тактов  | ого сигна  | ала, о | тносительно |
| <related clock=""></related>           | - | которого г | приходи | іт выходн | ой сигнал. |        |             |

Пример использования команды:

set\_output\_delay 0.7 {OUT} [-clock CLK]

• set\_max\_delay — задать максимальное время задержки сигнала для временных путей, заканчивающихся в заданном списке выходов.

set max delay <delay value> <name list> [r / f],

| <delay_value></delay_value> | - | значение времени задержки;                                               |
|-----------------------------|---|--------------------------------------------------------------------------|
| <name list=""></name>       | - | список выходов, которым будет присвоено заданное значение;               |
| r                           | - | установить максимальную задержку для нарастающего сигнала;               |
| f                           | - | установить максимальную задержку для убывающего сигнала;                 |
|                             |   | По умолчанию, если не заданы опции r/f, заданное время                   |
|                             |   | задержки установится как для нарастающего, так и для убывающего сигнала. |

set\_max\_delay 10.5 [get\_outputs] r

• set\_min\_delay — задать минимальное время задержки сигнала для временных путей, заканчивающихся в заданном списке выходов.

set min delay <delay value> <name list> [r / f],

| <delay_value></delay_value> | - | значение времени задержки;                                               |
|-----------------------------|---|--------------------------------------------------------------------------|
| <name list=""></name>       | - | список выходов, которым будет присвоено заданное значение;               |
| r                           | - | установить максимальную задержку для нарастающего сигнала;               |
| f                           | - | установить максимальную задержку для убывающего сигнала;                 |
|                             |   | По умолчанию, если не заданы опции r/f, заданное время                   |
|                             |   | задержки установится как для нарастающего, так и для убывающего сигнала. |

Пример использования команды:

set\_min\_delay 6.5 [get\_outputs] r

• set\_load – задать дополнительную емкость списку цепей.

set\_load <cap value> <names list> replace,

| <cap_value></cap_value> | _ | значение е | мкости   | ,          |        |              |           |            |
|-------------------------|---|------------|----------|------------|--------|--------------|-----------|------------|
| (nomos list)            | _ | задать спи | сок цеп  | ей, которы | м буде | т установле  | ена допол | пнительная |
|                         | _ | емкость;   |          |            |        |              |           |            |
|                         |   | заменить   | суще     | ствующую   | на     | заданных     | цепях     | емкость.   |
| replace                 | - | По умолч   | анию,    | значение,  | устан  | ювленное     | данной    | командой,  |
|                         |   | добавляето | ся к суц | цествующе  | й емко | сти, а не за | меняет её | ė;         |

Пример использования команды:

set load 0.5 [get outputs] replace

• set\_case\_analysis – задать постоянное логическое значение сигнала или нарастающий/убывающий фронт и исключить из временного анализа связанный с ними путь.

set\_case\_analysis {0 | 1 | zero | one | rise | fall} <objects\_list>,

| 0 / zero       | - | задать порту или пину значение «0»;                  |
|----------------|---|------------------------------------------------------|
| 1 / one        | _ | задать порту или пину значение «1»;                  |
| rise           | _ | задать порту или пину постоянный нарастающий сигнал; |
| fall           | _ | задать порту или пину постоянный убывающий сигнал;   |
| (objects list) |   | задать список портов или пинов, для которых будет    |
|                | _ | задано постоянное значение;                          |

# Функции, позволяющие получить списки имен по требуемому критерию

| get_inputs                      | - | получить список входов;           |
|---------------------------------|---|-----------------------------------|
| get_outputs                     | - | получить список выходов;          |
| get_nodes                       | - | получить список всех цепей;       |
| get_nodes <internal></internal> | - | получить список внутренних цепей; |
| get_cells                       | - | получить список всех ячеек;       |

# Функции, возвращающие переданные ей значения. Необходимы для совместимости с Synopsys SDC.

| get_clocks    | — | получить список созданных тактовых сигналов; |
|---------------|---|----------------------------------------------|
| get_pins      | - | получить список всех пинов;                  |
| get_ports     | - | получить список всех портов;                 |
| get_lib_cells | _ | получить список всех библиотечных ячеек;     |

#### Выходные данные программы

- <ckt\_name>.log протокол выполнения программы.
- <ckt\_name>.run\_rtl.tcl файл с командами выполнения логического синтеза.
- <ckt\_name>.syn\_y.v синтезированное описание схемы на языке Verilog с использованием библиотечных элементов ПЛИС, полученное с помощью Yosys.
- <ckt\_name>.xmap.tcl описание схемы на языке Tcl с использованием библиотечных и периферийных элементов. В схему добавляются периферийные элементы: xa\_ib, xa\_ob. К именам входов добавляется префикс XC\_1\_<input\_name>. К именам выходов добавляется префикс XC\_0\_<output\_name>, составляются списки входных и выходных узлов xc\_inputs, xc\_outputs, а также список тактовых узлов xc\_clocks.
- <ckt\_name>.xmap.lib.tcl вывод библиотеки элементов в Tcl-формате;
- <ckt\_name>.xmap.glib.v вывод библиотеки дополнительных элементов в Verilog-формате.
- <ckt\_name>.gate.v вывод списка соединений в терминах элементов библиотеки ПЛИС в Verilog-формате.
- <ckt\_name>.gate.flat.v вывод списка соединений в терминах элементов библиотеки ПЛИС с раскрытием иерархии в Verilog-формате.
- <ckt\_name>.routed.v вывод списка соединений с результатами трассировки в терминах элементов библиотеки ПЛИС в Verilog-формате.
- <ckt\_name>.routed.flat.v вывод списка соединений с результатами трассировки в терминах элементов библиотеки ПЛИС с раскрытием иерархии в Verilog-формате.
- <ckt\_name>.le.tcl вывод результатов парной компоновки логических элементов на языке Tcl, можно использовать как входной файл.
- <ckt\_name>.map.tcl вывод результатов размещения и трассировки в Tcl-формате;
- <ckt\_name>.place.tcl вывод результатов размещения на языке Tcl, можно использовать как входной файл при повторном запуске программы.
- <ckt\_name>.ro.map.tcl вывод результатов трассировки в Tcl-формате с детализацией отображения цепей в списки соединений элементов ПЛИС;
- <ckt\_name>.geom.gds вывод результатов размещения и трассировки в формате GDS-II;
- <ckt\_name>.il вывод результатов трассировки в Skill-формате, для использования в редакторе Virtuoso Cadence.
- <ckt\_name>.mem вывод результатов конфигурирования ПЛИС в терминах конфигурации памяти;
- <ckt\_name>.bitnum прошивка в терминах программируемых бит памяти.
- <ckt\_name>.scs вывод результатов конфигурирования ПЛИС в Spice-формате для моделирования Spectra.
- <ckt\_name>.xsp вывод результатов конфигурирования ПЛИС в Spice-формате для моделирования в Xspice.
- <ckt\_name>.xspc вывод результатов конфигурирования ПЛИС в Spice-формате с добавлением паразитных конденсаторов для моделирования в Xspice.
- <ckt\_name>.sta.results/ директория с результатами статического временного анализа.

# Примеры запуска программы в консольном режиме Далее описаны разные варианты запуска управляющего скрипта: 1. Переход к рабочей директории cd X-CAD/test 2. Запуск с использованием Yosys ../bin/xcore.exe ../src/scripts/xa -i <ckt\_name>.v -y++ 3. Например: ../bin/xcore.exe ../src/scripts/xa -i ../src/test isc3/c432.v -y++ 4. Синтезированное Verilog описание схемы ../bin/xcore.exe ../src/scripts/xa -i <ckt name>.syn y.v 5. Например: ../bin/xcore.exe ../src/scripts/xa -i ./c432.syn y.v 6. Tcl описание схемы ../bin/xcore.exe ../src/scripts/xa -i <ckt name>.tcl 7. Например: ../bin/xcore.exe ../src/scripts/xa -i c432.xmap.tcl 8. С использованием готового размещения ../bin/xcore.exe ../src/scripts/xa -i <ckt name>.v -p <ckt name>.place.tcl 9. Например: 10.../bin/xcore.exe ../src/scripts/xa -i c432.syn y.v -p ./c432.place.tcl 11. Описание схемы на языке Tcl и размещение находятся в одном файле ../bin/xcore.exe ../src/scripts/xa -i <ckt name>.tcl -p "" 12. Например:

../bin/xcore.exe ../src/scripts/xa -i c432.syn y.tcl -p ""

### TCL интерфейс

#### **ТсІ интерфейс управления программой**

| xc_init                                                  | – инициализация работы с программой.                                 |
|----------------------------------------------------------|----------------------------------------------------------------------|
| xc_quit                                                  | – завершение работы с программой.                                    |
| xc_set_param                                             | – установка параметров программы, синтаксис:                         |
| xc_set_param <                                           | имя параметра> <значение параметра>                                  |
| xc_ckt_init                                              | – инициализация новой схемы, синтаксис:                              |
| xc_ckt_init <m< th=""><th>ия схемы&gt; PROJECT</th></m<> | ия схемы> PROJECT                                                    |
| xc_ckt_set_gnd                                           | – назначение узла земли схемы, синтаксис:                            |
| xc_ckt_set_gnd                                           | <узел земли>                                                         |
| xc_ckt_set_vdd                                           | – назначение узла питания схемы, синтаксис:                          |
| xc_ckt_set_vdd                                           | <узел питания>                                                       |
| xc_net_order high                                        | – Задает порядок трассировки узлов с высоким приоритетом, синтаксис: |
| xc_net_order h                                           | igh { <list_nodes_names>}</list_nodes_names>                         |
|                                                          |                                                                      |

где <*list\_nodes\_names*> — список узлов для трассировки в порядке убывания приоритета.

#### Пример:

xc net order high { net1 net2 input net }

Файл, содержащий данную команду, может быть загружен при запуске исполняемого скрипта с помощью опции -order "filename".

#### Tcl интерфейс для отображения результатов RTL синтеза в базис ПЛИС

**xc\_lib\_cell** – добавление экземпляра модели элемента в библиотеку. Синтаксис команды **xc\_lib\_cell**:

xc\_lib\_cell <lib\_cell\_name> <subckt\_name> {<input nodes>} {<control\_nodes>}
{<function>},

| <lib_cell_name></lib_cell_name>                                                                                 | - имя библиотечной ячейки;                                                                   |
|-----------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|
| <subckt_name></subckt_name>                                                                                     | - имя подсхемы из spice описания ПЛИС (формат cdl);                                          |
|                                                                                                                 | - список входных и выходных узлов в формате:                                                 |
|                                                                                                                 | <io_pin_name>=<port_list>, где:</port_list></io_pin_name>                                    |
| <input nodocs<="" td=""/> <td><io_pin_name> — имя контакта в соответствии с .lib библиотекой</io_pin_name></td> | <io_pin_name> — имя контакта в соответствии с .lib библиотекой</io_pin_name>                 |
|                                                                                                                 | <pre><port_list> — список узлов контакта в соответствии со spice описанием</port_list></pre> |
|                                                                                                                 | схемы ПЛИС (знак & вместо = позволяет объединять узлы для реализации                         |
|                                                                                                                 | элементов хог или mux)                                                                       |
| control nodocs                                                                                                  | - список управляющих узлов с установленными значениями                                       |
|                                                                                                                 | программирования;                                                                            |
| <function></function>                                                                                           | - логическая функция библиотечной ячейки.                                                    |

**хс\_pin** – добавление экземпляра контакта ввода – вывода.

Синтаксис команды xc\_pin:

xc\_pin <pinName> <direction> <nodeName>,

| <pinname></pinname>     | - имя добавляемого контакта |
|-------------------------|-----------------------------|
|                         | - направление контакта:     |
| <direction></direction> | і – вход                    |
|                         | о – выход                   |
|                         | b - двунаправленный         |
| <nodename></nodename>   | - имя узла проектной схемы  |

xc\_inst – добавление экземпляра логического элемента;

Синтаксис команды **xc\_inst**:

xc\_inst <inst\_name> <lib\_cell\_name> {<list nodes>} {<inout>}

| <inst_name></inst_name>         | - имя добавляемого элемента       |
|---------------------------------|-----------------------------------|
| <lib_cell_name></lib_cell_name> | - имя библиотечной ячейки         |
| <list nodes=""></list>          | - список входных и выходных узлов |
| <inout></inout>                 | - идентификация Ю-элемента        |
|                                 | (inp_io=1 или out_io=1).          |

**xc\_le** – группировка логических ячеек в логические элементы. Схемотехника ПЛИС предусматривает быструю локальную связь с выхода первой ячейки на любой из входов второй, таким образом позволяя объединять элементы проектируемой схемы в пары для более быстрой передачи данных.

Синтаксис команды **хс\_le**:

xc\_le <LE\_name> { <inst\_name> <inst\_name> }

| <le_name></le_name>     | - имя добавляемого логического элемента  |
|-------------------------|------------------------------------------|
| <inst_name></inst_name> | - имя добавляемого элемента типа xc_inst |

# Графический интерфейс X-CAD

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

Данный интерфейс позволяет просто и быстро провести потоковую работу с пакетом программ для генерации прошивок целевых ПЛИС.

Программа разработана с применением кроссплатформенных средств разработки (библиотека Qt) и распространяется на платформах семейств Windows и Unix.

#### Запуск программы

Запуск программы может быть осуществлен как посредством активации исполняемого файла из файлового менеджера, так и из командной строки.

#### Запуск через обозревателя файлов

Для запуска через обозревателя файлов необходимо открыть папку с исполняемым файлом «xcad.exe» (с соответствующей иконкой <sup>(1)</sup>), который расположен в директории «bin» пакета программ, и активировать двойным щелчком левой кнопки мыши или вызвать с помощью правой кнопки мыши контекстное меню и выбрать соответствующий пункт для запуска приложения.

#### Запуск через командную строку

Чтобы запустить программу посредством командной строки, необходимо перейти в папку «bin» пакета программ и вызвать на исполнение файл «xcad.exe», используя следующие команды:

- Windows: "start xcad.exe"
- Unix: "./xcad"

#### Стартовое окно

При первом запуске программа создаст в домашней директории поддиректорию «XCAD», а также следующие файлы и директории:

- history.hst файл для хранения истории открытых проектов;
- user\_config.cfg файл пользовательских настроек программы;
- Projects директория для пользовательских проектов.

Позже в директории «XCAD», также, будет создан следующий файл:

• *win\_state.ws* – файл, хранящий состояние графического интерфейса на момент закрытия программы.

После того, как файлы и директории были созданы, пользователя встречает стартовое окно менеджера проектов (Рисунок 8) со списком последних открытых проектов (изначально пуст), который впоследствии будет отображать список проектов со следующей информацией: «имя проекта», «последний запуск», «кристалл», «ядро», «полный путь» (до файла проекта).

Перед открытием окна программа проверяет существование файлов проектов по указанным расположениям. Если файл проекта не был найден, то соответствующая этому проекту строка в списке будет выделяться красным цветом, а иконка проекта сменится иконкой с восклицательным знаком в красном круге (<sup>1</sup>). При выборе такого элемента списка, кнопки открытия проекта будут заблокированы.

Также в этом окне имеются следующие кнопки:

- «Открыть выбранный проект» открывает выбранный из списка проект (если список пуст,
- то кнопка будет заблокирована);
- «Открыть существующий проект» открывает окно обозревателя файлов для выбора файла проекта (с расширением "\*.xcprj");
- «Новый проект» открывает окно мастера создания проекта;
- «Удалить проект» удаляет директорию с проектом и соответствующую запись в истории (если проект не выбран, то кнопка будет заблокирована);
- Переключатель языка (в правом нижнем углу).

| хс Добро пожаловать в X-CAD — 🗆 🗙                        |                               |  |  |  |  |  |  |  |
|----------------------------------------------------------|-------------------------------|--|--|--|--|--|--|--|
| Имя проекта Последний запуск 🔻 Кристалл Ядро Полный путь | • Открыть выбранный проект    |  |  |  |  |  |  |  |
|                                                          | 📒 Открыть существующий проект |  |  |  |  |  |  |  |
|                                                          | 🇱 Новый проект                |  |  |  |  |  |  |  |
|                                                          | 🗙 Удалить проект              |  |  |  |  |  |  |  |
|                                                          |                               |  |  |  |  |  |  |  |
|                                                          |                               |  |  |  |  |  |  |  |
|                                                          |                               |  |  |  |  |  |  |  |
|                                                          |                               |  |  |  |  |  |  |  |
|                                                          |                               |  |  |  |  |  |  |  |
|                                                          |                               |  |  |  |  |  |  |  |
|                                                          |                               |  |  |  |  |  |  |  |
|                                                          |                               |  |  |  |  |  |  |  |
|                                                          | 💻 Русский 🔻                   |  |  |  |  |  |  |  |

Рисунок 8. Стартовое окно программы

Список проектов поддерживает, также, контекстное меню (Рисунок 9), которое вызывается посредством щелчка правой кнопкой мыши (ПКМ) на элементе списка. Меню содержит следующие возможности:

- «Открыть» открывает выбранный проект;
- «Открыть расположение» открывает директорию, в которой расположен файл проекта;
- «Удалить из истории» удаляет запись о проекте из этого окна и истории;
- «Удалить проект» удаляет директорию с проектом и соответствующую запись в истории.

#### Открытие существующего проекта

Если программа запускается не первый раз и ранее были созданы/открыты проекты, то список будет содержать все из них (Рисунок 9). Открыть существующий проект можно следующими способами:

- выбрать проект из списка (нажав на него ЛКМ) и нажать кнопку «Открыть выбранный проект»;
- двойным щелчком ЛКМ на проекте из списка;
- нажать на кнопку «Открыть существующий проект», после чего через открывшееся окно обозревателя файлов найти файл проекта с расширением «\*.хсргј», выбрать его (ЛКМ) и нажать «Открыть», или нажать на него двойным щелчком ЛКМ.

При открытии несуществующего проекта (например, двойным щелчком ЛКМ) будет показано сообщение о том, что файл проекта (Рисунок 10) больше не существует.

| хс Добро пожаловать в X-CAD — 🗆 🗙 |             |                     |                      |                                                           |                                         |                  |                             |        |  |
|-----------------------------------|-------------|---------------------|----------------------|-----------------------------------------------------------|-----------------------------------------|------------------|-----------------------------|--------|--|
|                                   | Имя проекта | Последний запуск    | Кристалл             | Ядро                                                      | Полный путь                             |                  | Открыть выбранный п         | роект  |  |
|                                   | 🧓 s510      | 18.06.2020 15:39:39 | 5400TP094            | XA                                                        | C:/X-CAD/Projects/s510/s510.            | ).xcprj          |                             |        |  |
|                                   | 🐻 fa_test   | 26.03.2021 11:28:39 | 5400TP094            | XA                                                        | C:/X-CAD/Projects/fa_test/fa_test.xcprj |                  | Открыть существующии проект |        |  |
|                                   |             |                     | 🕨 Открь              | <ul> <li>Открыть</li> <li>Открыть расположение</li> </ul> |                                         |                  | 👜 Новый проект              |        |  |
|                                   |             |                     | 📒 Открь              |                                                           |                                         |                  |                             |        |  |
|                                   |             |                     | 🔳 Удалить из истории |                                                           |                                         | 🗙 Удалить проект |                             |        |  |
|                                   |             |                     | 🗙 Удалить проект     |                                                           |                                         |                  | Pyc                         | ский 💌 |  |

Рисунок 9. Стартовое окно программы с элементами списка

| <b>хс</b> Оши | с Ошибка Х                                               |  |  |  |  |
|---------------|----------------------------------------------------------|--|--|--|--|
| $\otimes$     | Файл не существует:<br>C:/X-CAD/Projects/s510/s510.xcprj |  |  |  |  |
|               | Ок                                                       |  |  |  |  |

Рисунок 10. Сообщение об ошибке при открытии несуществующего проекта

После загрузки проекта откроется главное окно программы для дальнейшей работы с проектом (Рисунок 11).



Рисунок 11. Главное окно программы
### Мастер создания проекта

Мастер создания проекта помогает пользователю создать проект. Его можно запустить, нажав на кнопку «Новый проект» в стартовом окне менеджера проектов, или выбрав пункт меню «Файл – Новый проект» в главном окне, или нажав соответствующую кнопку на панели инструментов главного окна. Окно мастера (Рисунок 12) содержит следующие элементы интерфейса:

- строка «Целевой кристалл», отражающую текущий активный кристалл, который можно изменить посредством кнопки «Выбрать» с символом кристалла ПЛИС;
- поле «Директория», где можно вручную или посредством обозревателя (кнопка «Открыть» с изображением папки) указать путь до директории, где будут храниться все файлы, связанные с проектом (или дочерняя директория с именем проекта, где они будут храниться, если установлен флаг «Создать директорию проекта»); для совместимости с внешними инструментами, путь может содержать только латиницу, цифры и знаки: «:», «/», «\_», «.», «-»;
- поле «Имя проекта», где вручную указывается имя проекта (может содержать только латиницу, цифры и знаки «\_» и «-»);
- поле «Полный путь» (нередактируемое), где отражается полный путь, по которому будет создан файл проекта;
- флаг «Создать директорию проекта», выставление которого приведет к созданию по пути, указанному в поле «Директория проекта», дочерней директории с именем проекта, где впоследствии будет создан файл проекта, и где будут располагаться все связанные с ним файлы;
- интерфейс управления проектными файлами со следующими элементами:
  - о кнопка «Добавить» (с изображением папки) для добавления файлов в проект;
  - кнопка «Удалить» (с изображением красного креста) для удаления добавленных файлов, если необходимо;
  - поле «Головной модуль» для указания модуля верхнего уровня (можно выбрать только после добавления файлов в проект);
  - окно со списком добавленных файлов, где отражается имя и полный путь до файла, а также, можно выбрать в какую виртуальную папку будет перемещен файл после создания проекта;
- кнопка «Создать проект», которая запускает процесс создания проекта и открывает главное окно программы.

| 👹 New project     | ×                            |
|-------------------|------------------------------|
|                   | Создание проекта             |
| Целевой кристалл  | 5400TP094 (5400TP)           |
| Директория        | C:/X-CAD/Projects            |
| Имя               | Введите имя проекта          |
| Полный путь       | C:/X-CAD/Projects            |
|                   | ✓ Создать директорию проекта |
| Головной модуль   | •                            |
| Добавить проектнь | е файлы 📃 🗶                  |
| В папку И         | мя Полный путь               |
|                   |                              |
|                   |                              |
|                   |                              |
|                   |                              |
|                   |                              |
|                   |                              |
|                   | <b>Парал</b> ать проект      |
|                   |                              |

Рисунок 12. Окно создания проекта

Если при создании проекта в пути или имени проекта были указаны недопустимые символы, то программа выдаст ошибку (Рисунок 13).

| 💽 Оши | бка 🛛 🕹                                                          |
|-------|------------------------------------------------------------------|
| 8     | Строка содержит недопустимые символы:<br>C:/X-CAD/Projects/,#;!№ |
|       | Ок                                                               |

Рисунок 13. Сообщение об ошибке в пути до директории проекта

Если же все данные были введены корректно, то после нажатия на кнопку «Создать проект» по пути, указанному в поле «Полный путь», будет создан файл проекта и сопутствующие файлы и директории. После этого окно мастера будет закрыто и запустится главное окно программы.

Также программа запомнит путь из поля «Директория» и в следующий раз, при создании проекта, по умолчанию укажет его. Изначально, путь указан до директории «XCAD/Project», созданную в домашнем каталоге при первом запуске программы.

# Окно выбора кристалла

Окно позволяет выбрать целевой кристалл (Рисунок 14) и открывается через мастера создания проекта (кнопка «Выбрать» с изображением кристалла ПЛИС) или через главное окно программы («Проект – Выбор кристалла»). Окно содержит следующие элементы:

- фильтр «Семейство» в виде выпадающего списка с выбором целевого семейства кристаллов;
- окно со списком кристаллов (для указанного семейства) и дополнительной информацией по каждому кристаллу: «имя», «семейство», «ядро», «логические ячейки», «периферийные ячейки», «напряжение», «ток», «температура», «потребляемая мощность» и «производитель»;

- кнопка «Ок», подтверждающая выбор кристалла (для выбора необходимо выделить кристалл в списке нажатием на нем ЛКМ);
- кнопка «Отмена», отменяющая выбор и возвращающая к предыдущему выбранному кристаллу.

Подтвердить выбор также можно двойным нажатием ЛКМ по строке с нужным кристаллом.

| 👹 Выбор          | 🖗 Выбор кристалла Х            |      |                   |                     |       |       |     |             |                       |               |     |
|------------------|--------------------------------|------|-------------------|---------------------|-------|-------|-----|-------------|-----------------------|---------------|-----|
| Выберите         | Выберите необходимый кристалл. |      |                   |                     |       |       |     |             |                       |               |     |
| Семейство 5400ТР |                                |      |                   |                     |       |       | •   |             |                       |               |     |
| Имя              | Семейство                      | Ядро | Логические ячейки | Периферийные ячейки | Напря | жение | Ток | Температура | Потребляемая мощность | Производитель |     |
| 5400TP09         | 4 5400TP                       | XA   | 1794              | 212                 |       | 1.8   |     |             |                       | DC So         | /uz |
| A18T             | 5400TP                         | XA2  | 1794              | 212                 |       | 1.8   |     |             |                       | DC Soy        | /uz |
| FPGA64           | 5400TP                         | XA3  | 1058              | 93                  |       | 1.8   |     |             |                       | DC Soy        | /uz |
|                  |                                |      |                   |                     |       |       |     |             |                       |               |     |
|                  |                                |      |                   |                     |       |       |     |             |                       |               |     |
|                  |                                |      |                   |                     |       |       |     |             |                       |               |     |
|                  |                                |      |                   |                     |       |       |     |             |                       |               |     |
|                  |                                |      |                   |                     |       |       |     |             |                       |               |     |
|                  |                                |      |                   |                     |       |       |     |             |                       |               |     |
|                  |                                |      |                   |                     |       |       |     |             |                       |               |     |
|                  |                                |      |                   |                     |       |       |     |             |                       |               |     |
|                  |                                |      |                   |                     |       |       |     |             |                       |               |     |
|                  |                                |      |                   |                     |       |       |     |             |                       |               |     |
|                  |                                |      |                   |                     |       |       |     |             |                       |               |     |
|                  |                                |      |                   |                     |       |       |     |             |                       |               |     |
|                  |                                |      |                   |                     |       |       |     |             |                       |               |     |
|                  | Ок Отмена                      |      |                   |                     |       |       |     |             |                       |               |     |

Рисунок 14. Окно выбора кристалла

# Главное окно для работы с проектом

Главное окно – основное пространство для работы с проектом, содержащее следующие элементы интерфейса:

- Главное меню (Рисунок 15-1);
- Панели инструментов (Рисунок 15-2);
- Обозреватель проекта (Рисунок 15-3);
- Обозреватель проектной директории (Рисунок 15-3);
- Дерево иерархии проекта (Рисунок 15-3);
- Окно библиотек проекта (Рисунок 15-3);
- Текстовый редактор (Рисунок 15-4);
- Окно «Вывод» (Рисунок 15-5);
- Статусная строка (Рисунок 15-6).



Рисунок 15. Главное окно программы

#### Главное меню рабочего окна

*Главное меню* (Рисунок 15-1) – панель с дочерними меню, содержащими основные действия для работы с программой. Меню содержит следующие дочерние меню:

- «Файл» создание, загрузка и сохранение проектов и файлов, завершение работы программы;
- «Редактировать» инструменты текстового редактора;
- «Вид» настройки видимости элементов интерфейса главного окна;
- «Проект» выбор целевого кристалла, обзор директории проекта;
- «Запуск» настройки, запуск и прерывание работы маршрута;
- «Инструменты» запуск дополнительных инструментов и сторонних программ, а также настройка путей до программ (Рисунок 16);
- «Окно» изменение шрифта приложения, стиля окон и языка интерфейса (русский/английский);
- «Помощь» краткая информация о программе.

Если после внесения изменений в окно настроек путей оно будет закрыто посредством системной кнопки закрытия окна, всплывет сообщение с предложением сохранить изменения, отменить изменения или отменить выход из окна.

Также, в окне изменения путей можно сбросить настройки до значений по умолчанию (кнопка «По умолчанию»).

| 🕸 Пути инструментов           | ×                                |
|-------------------------------|----------------------------------|
|                               | Синтезаторы                      |
| Путь до Ү++                   | /tools/y++/y++.exe               |
| Путь до DC Compiler           |                                  |
| Путь до RTL Compiler          |                                  |
| Путь до Genius                |                                  |
|                               | Инструменты                      |
| Путь до Icarus Verilog        | /tools/iverilog/bin/iverilog.exe |
| Путь до Icarus VVP            |                                  |
| Путь до директории Icarus IVL |                                  |
| По умолчанию                  | Ок Отмена                        |

Рисунок 16. Окно настроек путей расположения до программ

#### Панели инструментов

*Панели инструментов* (Рисунок 15-2) повторяют наиболее востребованные в процессе работы действия, содержащиеся в меню, для быстрого доступа. Сюда включены следующие панели:

- Главная панель инструментов (повторяет меню «Файл»);
- Инструменты для работы с текстовым редактором (повторяет меню «Редактировать»);
- Инструменты для настройки и управления запуском (повторяет меню «Запуск»);
- Панель внешних инструментов (повторяет меню «Инструменты»);

Панели могут быть передвинуты пользователем в любую часть окна.

### Обозреватель проекта

Обозреватель проекта (Рисунок 15-3, Рисунок 17) — окно, в котором отображается структура проекта. Оно содержит корневой элемент с именем проекта и дочерние элементы-папки, в которых могут находиться файлы:

- «HDL описания» для файлов с описанием схем на языках: Verilog, System Verilog, VHDL;
- «Синтезированные описания» для синтезированных Verilog-файлов и файлов с описанием схемы в базисе ПЛИС;
- «Тестовые файлы» для файлов с тестовыми модулями, содержащими входные воздействия;
- «Verilog моделирование» для Verilog-файлов, необходимых для поведенческого моделирования;
- «Временное моделирование» для файлов, содержащих отчеты временного анализа;
- «Размещение» для файлов, содержащих результаты размещения элементов;
- «Трассировка» для файлов, содержащих результаты трассировки межсоединений;
- «Spice-моделирование» для входных и выходных файлов Spice-моделирования;
- «Программирование» для файлов прошивки.



Рисунок 17. Обозреватель проекта

Добавить файлы в папку можно как с помощью контекстного меню, так и посредством *механизма* захвата и перетаскивания (Drag'n'Drop).

При добавлении в проект, *файлы анализируются*, и в элементах с именами файлов создаются дочерние элементы – модули, а также формируются списки входных/выходных цепей для окна настроек запуска.

Также для всех файлов создаются резервные копии, которые располагаются в директории «Backup» в директории проекта.

При добавлении описания схемы в пустой проект, программа предпринимает попытку автоматически определить модуль верхнего уровня (определяется наивысшим уровнем иерархии). Если таких модулей в файле несколько, то программа выставит первый найденный модуль в качестве модуля верхнего уровня. Если в файле не описаны модули, то дочерние элементы с именами модулей созданы не будут.

Поддерживается, также, перемещение файлов между виртуальными папками посредством механизма захвата и перетаскивания.

Для каждого из уровней структуры проекта существует контекстное меню, вызываемое ПКМ (Рисунок 18).





г)

Рисунок 18. Контекстные меню обозревателя проекта для: а – проекта; б –папки; в – файла; г – модуля

Меню проекта (Рисунок 18-а):

- «Запуск» запускает выполнение маршрута;
- «Стоп» останавливает выполнение маршрута;
- «Настройки запуска» открывает окно настроек запуска;
- «Открыть директорию» открывает расположение файла проекта;
- «Выбор кристалла» открывает окно выбора кристалла.

Меню папки (Рисунок 18-б):

- «Добавить новый файл» открывает окно создания нового файла;
- «Добавить существующий файл» открывает окно выбора существующего файла.

Меню файла (Рисунок 18-в):

- «Открыть директорию» открывает расположение файла;
- «Удалить из проекта» исключает файл из проекта.
- «Удалить файл с ПК» безвозвратно удаляет файл с ПК.

Меню модуля (Рисунок 18-г):

- «Сделать головным модулем» устанавливает выбранный модуль в качестве модуля верхнего уровня иерархии;
- «Искать в файле» открывает расположение модуля в файле.

Двойной щелчок ЛКМ по элементу файл открывает его в текстовом редакторе.

Двойной щелчок ЛКМ по модулю делает его модулем верхнего уровня.

### Обозреватель проектной директории

Обозреватель проектной директории (Рисунок 15-3, Рисунок 19) отображает файлы, содержащиеся в рабочей директории проекта. Двойной щелчок ЛКМ по файлу откроет его в текстовом редакторе программы.

| Обозреватель директории проекта    |            |             |                  |         |  |
|------------------------------------|------------|-------------|------------------|---------|--|
| Имя файла                          | ▼ Размер   | Тип файла   | Изменён          | <b></b> |  |
| <ul> <li>Backup</li> </ul>         |            | File Folder | 17.06.2020 10:49 |         |  |
| fa.syn_y.v                         | 357 байты  | v File      | 17.06.2020 10:49 |         |  |
| fa.syn_y.xmap.tcl                  | 1,23 KiB   | tcl File    | 17.06.2020 10:49 |         |  |
| // fa.v                            | 181 байты  | v File      | 17.06.2020 10:37 |         |  |
| <ul> <li>fa.STA.reports</li> </ul> |            | File Folder | 18.06.2020 9:53  |         |  |
| fa.gate.nworst.txt                 | 15,11 KiB  | txt File    | 18.06.2020 9:53  |         |  |
| fa.gate.nworst_slack.tcl           | 87 байты   | tcl File    | 18.06.2020 9:53  |         |  |
| 📸 fa.gate.sdf                      | 2,18 KiB   | sdf File    | 18.06.2020 9:53  |         |  |
| fa.gate.sl_table.tcl               | 733 байты  | tcl File    | 18.06.2020 9:53  |         |  |
| fa.gate.sta.log                    | 5,54 KiB   | log File    | 18.06.2020 9:53  |         |  |
| fa.gate.sta_run.log                | 5,44 KiB   | log File    | 18.06.2020 9:53  |         |  |
| Y_WORK                             |            | File Folder | 17.06.2020 10:49 |         |  |
| 📄 fa.bitnum                        | 43,91 KiB  | bitnum File | 18.06.2020 9:53  |         |  |
| 📄 fa.flat.log                      | 3,67 KiB   | log File    | 18.06.2020 9:53  |         |  |
| fa.flat.sta.v                      | 771 байты  | v File      | 18.06.2020 9:53  |         |  |
| fa.gate.v                          | 1,04 KiB   | v File      | 18.06.2020 9:53  |         |  |
| fa.log                             | 121,93 KiB | log File    | 18.06.2020 9:53  |         |  |
| fa.place.tcl                       | 500 байты  | tcl File    | 18.06.2020 9:53  |         |  |
| 🗐 fa.syn_y.v                       | 357 байты  | v File      | 18.06.2020 9:53  |         |  |
| fa.syn_y.xmap.lib.tcl              | 90,66 KiB  | tcl File    | 18.06.2020 9:53  |         |  |
| fa.syn_y.xmap.lib.v                | 349 байты  | v File      | 18.06.2020 9:53  |         |  |
| fa.syn_y.xmap.log                  | 869 байты  | log File    | 18.06.2020 9:53  |         |  |
| fa.syn_y.xmap.tcl                  | 1,23 KiB   | tcl File    | 18.06.2020 9:53  |         |  |
| fa.syn_y.xmap.v                    | 626 байты  | v File      | 18.06.2020 9:53  |         |  |
| fa.xsp                             | 64,54 KiB  | xsp File    | 18.06.2020 9:53  |         |  |
| fa.xspc                            | 109,33 KiB | xspc File   | 18.06.2020 9:53  |         |  |
| fa test.log                        | 21,48 KiB  | log File    | 18.06.2020 9:53  | -       |  |

Рисунок 19. Обозреватель директории проекта

### Окно иерархии проекта

Окно иерархии проекта (Рисунок 15-3, Рисунок 20) содержит иерархию модулей, описанных в HDLфайлах проекта, начиная от модуля верхнего уровня. Если модуль верхнего уровня не назначен, окно будет пустым.

Двойной щелчок ЛКМ по модулю открывает в текстовом редакторе файл, где данный модуль вызывается модулем более высокого уровня. Щелчок ПКМ по модулю вызывает контекстное меню, в котором доступен переход к месту объявлению данного модуля.



Рисунок 20. Окно иерархии проекта

### Окно библиотек проекта

Окно библиотек проекта (Рисунок 15-3, Рисунок 21) структурирует HDL-описания проекта в виде библиотек. Данная особенность необходима для некоторых логических синтезаторов. По умолчанию окно содержит единственную библиотеку «work». Для добавления новых библиотек или перемещения файлов в уже существующие, необходимо вызвать контекстное меню и выбрать пункт «Задать библиотеку». В контекстном меню библиотеки (вызывается щелчком ПКМ) доступна опция удаления библиотеки. После удаления библиотеки, все файлы, находящиеся в ней, будут перемещены в библиотеку по умолчанию.

| Библиотеки проекта @ |  |  |  |  |
|----------------------|--|--|--|--|
| Библиотеки           |  |  |  |  |
| 🔻 💵 work             |  |  |  |  |
| fa.v                 |  |  |  |  |
|                      |  |  |  |  |
|                      |  |  |  |  |
|                      |  |  |  |  |
|                      |  |  |  |  |
|                      |  |  |  |  |
|                      |  |  |  |  |
|                      |  |  |  |  |
|                      |  |  |  |  |

Рисунок 21. Окно библиотек проекта

### Текстовый редактор

*Редактор текстовых файлов* (Рисунок 15-4, Рисунок 22), который обладает следующими возможностями:

- Подсветка синтаксиса для языка Verilog и Tcl;
- Автодобавление отступа равного отступу предыдущей строки;
- Контекстное меню (повторяет меню «Редактировать»);
- Номера строк;
- Выделение текущей строки;

- Поддержка горячих клавиш;
- Поиск и замена в файле (чувствительность к регистру, поиск по регулярному выражению, замена одного или всех вхождений).
- Поддержка режима захвата и перетаскивания файлов (Drag'n'Drop).

| fa.v 🗶 fa.syn_y.v 🗶 fa.syn_y           | y.xmap.tcl 🗙                            |                      |   |     |
|----------------------------------------|-----------------------------------------|----------------------|---|-----|
| 1 `timescale 1ns/100ps //file fa.v     |                                         |                      |   |     |
| 3 module fa (input a, b, c, output     | t sum, carry );                         |                      |   |     |
| 4                                      | , , , , , , , , , , , , , , , , , , , , |                      |   |     |
| 5 wire d,e,f;                          |                                         |                      |   |     |
| 7 <b>xor</b> (sum,a,b,c);              | 🖱 Назад                                 | Ctrl+Z               |   |     |
| 8 and $(d,a,b)$ ;<br>9 and $(e,b,c)$ ; | С Вперед                                | Ctrl+Y, Ctrl+Shift+Z |   |     |
| 10 and(f,a,c);                         | 😽 Вырезать                              | Ctrl+X               |   |     |
| 11 <b>or</b> (carry,d,e,f);            | 🧾 Копировать                            | Ctrl+C               |   |     |
| 12<br>13 endmodule                     | 🖺 Вставить                              | Ctrl+V               |   |     |
|                                        | 🗙 Удалить                               | Del, Backspace       |   |     |
|                                        | 🦉 Выделить все                          | Ctrl+A               |   |     |
|                                        | 🛃 Найти                                 | Ctrl+F               |   |     |
|                                        | 🗄 Найти и заменить                      | Ctrl+H               |   |     |
|                                        | 🛕 Шрифт редактора                       |                      |   |     |
|                                        |                                         |                      |   |     |
|                                        |                                         |                      |   |     |
| .* Аа Найти:                           |                                         |                      | < | > × |
| Заменить:                              |                                         |                      | 5 | 5   |

Рисунок 22. Текстовый редактор

### Окно «Вывод»

*Окно «Вывод»* (Рисунок 15-5, Рисунок 23) – окно с тремя режимами работы: «Вывод», «Ошибки и предупреждения» и список ошибок. Выбор режима осуществляется через выпадающий список «Текущее окно».

В режиме «Вывод» в окно перенаправляется весь текстовый вывод программ, которые были запущены в процессе работы маршрута, а также информация о начале и завершении работы программ, их пути и строки вызова, а также коды завершения. В данном режиме поддерживается подсветка строк с ошибками и предупреждениями, а также с ключевыми словами «OK», «STOPPED», «ERROR», «WARNING», и строкой с именем созданного файла прошивки. Весь вывод, содержащийся в окне в режиме «Вывод», сохраняется в файл «*ums\_проекта.*log» в директории проекта.

| Вывод                                            | ð× |
|--------------------------------------------------|----|
| Текущее окно: 🗉 Вывод 🔹 📩                        |    |
| *** xc_run cap_prepare started, time: 14:55:49   |    |
| (*** xc_run cap_prepare finished, time: 14:55:49 |    |
| www.write fa.xspc spice xspc                     |    |
| "C:/X-CAD/src/scripts/xa", version 1.9, finished |    |
| ~~~ Time xc_quit: 14:55:50                       |    |
| X-core [OK]                                      |    |
|                                                  |    |
|                                                  |    |
|                                                  | •  |

### Рисунок 23. Окно «Вывод»

Режим «Ошибки и предупреждения» предназначен только для вывода строк с ошибками и предупреждениями программ. Весь остальной вывод здесь отображен не будет. Подсветка строк аналогична режиму «Вывод».

В режиме «Список ошибок» окно, также, как и в режиме «Ошибки и предупреждения», содержит только ошибки и предупреждения, полученные в результате работы программ. Окно поддерживает (по двойному щелчку ЛКМ) переход к строке, вызвавшей ошибку или предупреждение. Однако здесь будут отражены сообщения только тех программ, которые поддерживаются программой X-CAD. На данный момент поддерживаются следующие программы: Yosys и Icarus Verilog.

В окне также имеется кнопка очистки окон вывода, расположенная рядом с элементом выбора поля.

### Статусная строка

Статусная строка (Рисунок 15-6) служит для вывода информационных сообщений. Например, сообщение о готовности проекта, строка вызова последней программы, подсказка именований пунктов меню и др.

### Настройки запуска

Активация пункта «Настройки запуска» меню «Запуск» (или соответствующей кнопки на панели инструментов, или пункта контекстного меню проекта) открывает окно настроек запуска (Рисунок 24), где содержатся настройки параметров синтеза и маршрута в целом.

Включение/отключение опции происходит путем активации кнопки «Да/Нет». Если выбран вариант «Нет» (кнопка окрашена серым цветом) - опция отключена и не повлияет на работу маршрута; а если выбран вариант «Да» (кнопка окрашена зеленым цветом) - опция будет активна и внесет соответствующие изменения в работу маршрута.

Если опция требует ввода дополнительной информации, но в поле не указано значение, поле будет подсвечено красным цветом.

Если после внесения изменений окно будет закрыто посредством системной кнопки закрытия окна, всплывет сообщение с предложением сохранить изменения, отменить изменения или отменить закрытие окна.

Также, в окне настроек запуска можно сбросить настройки до значений по умолчанию.

| 🝓 Настройки запуска                          |                |                |      | ×         |
|----------------------------------------------|----------------|----------------|------|-----------|
|                                              | Наст           | ройки запуска  |      |           |
| Инструмент синтеза                           |                | Y++            |      |           |
| Маршрут                                      |                | LIB            |      | •         |
| Условия работы                               |                | PtcV1.80T25    |      | •         |
| Использовать собственный скрипт синтеза      |                | Нет            | ]    |           |
|                                              | Общи           | е настройки    |      |           |
| Задать имена выходных файлов                 | [-0]           | Нет            |      |           |
|                                              | Кластери       | зация элементо | рв   |           |
| Отключить объединение логики и триггеров     | [-nojoin]      | Нет            |      |           |
| Использовать файл кластеризации LE           | [-le]          | Нет            |      |           |
| Использовать файл кластеризации LAB          | [-lab]         | Нет            |      |           |
| Отключить парное объединение LE              | [-le_union]    | Нет            |      |           |
| Задать максимальное количество LE в LAB      | [-cl_lab_size] | Нет            | 1    | -         |
| Задать максимальное количество LAB           | [-cl_no_labs]  | Нет            | 1    | \$        |
|                                              | Размещ         | ение элементов | 3    |           |
| Использовать файл размещения Ю ячеек         | [-inout]       | Нет            |      |           |
| Использовать файл размещения LAB             | [-lab_place]   | Нет            |      |           |
| Использовать файл размещения макро-блоков    | [-macro]       | Нет            |      |           |
| Использовать файл размещения всех элементов  | [-p]           | Нет            |      |           |
| Отключить алгоритм моделирования отжига      | [-sa]          | Нет            |      |           |
| Задать множитель циклов моделирования отжига | [-sa_lm]       | Нет            | 1    | <b>•</b>  |
|                                              | Трассиров      | ка межсоедине  | ний  |           |
| Использовать файл порядка трассировки цепей  | [-order]       | Нет            |      |           |
| PathFinder: Фактор истории поиска пути       | [-v_h]         | Нет            | 0,10 | \$        |
| PathFinder: Фактор штрафа поиска пути        | [-v_p]         | Нет            | 0,50 | \$        |
| PathFinder: Максимальный вес пути            | [-path w]      | Нет            | 300  | <b>\$</b> |
| 🛞 Значения по умолчанию                      |                |                |      | Ок Отмена |

Рисунок 24. Окно настроек запуска

#### Пример работы программы

Запустите программу и активируйте кнопку «Создать проект». После этого откроется окно с параметрами создания нового проекта.

Заполните все необходимые поля. На данном этапе можно добавить необходимые файлы в проект. Для этого необходимо нажать на кнопку «Добавить» и выбрать файлы. Файлы также можно будет добавить и после создания проекта. Для создания проекта необходимо нажать на кнопку «Создать».

После этого откроется главное окно. Для примера был создан проект с именем «fa\_test» (Рисунок 25). После создания проекта откроется главное окно программы.

| 👹 Новый проект    |               |                             | ×                |  |  |  |  |
|-------------------|---------------|-----------------------------|------------------|--|--|--|--|
| Создание проекта  |               |                             |                  |  |  |  |  |
| Целевой кристалл  | 5510XC1T (55  | 510XC)                      |                  |  |  |  |  |
| Директория        | C:/X-CAD/Proj | iects                       |                  |  |  |  |  |
| Имя               | fa_test       |                             |                  |  |  |  |  |
| Полный путь       | C:/X-CAD/Proj | iects/fa_test/fa_test.xcprj |                  |  |  |  |  |
|                   | ✓ Создать ди  | іректорию проекта           |                  |  |  |  |  |
| Головной модуль   |               |                             | •                |  |  |  |  |
| Добавить проектнь | іе файлы      |                             | - ×              |  |  |  |  |
| В папку И         | мя            | Полный путь                 |                  |  |  |  |  |
|                   |               |                             |                  |  |  |  |  |
|                   |               |                             |                  |  |  |  |  |
|                   |               |                             |                  |  |  |  |  |
|                   |               |                             |                  |  |  |  |  |
|                   |               |                             |                  |  |  |  |  |
|                   |               |                             |                  |  |  |  |  |
|                   |               | [                           | 📲 Создать проект |  |  |  |  |

Рисунок 25. Создание тестового проекта

После создания проекта, можно добавить необходимые файлы описания схем на языке Verilog. Для этого примера была взята схема «fa\_test» из набора тестовых схем Icarus Verilog (Рисунок 26).



Рисунок 26. Окно проекта с загруженным файлом схемы «fa»

На данном этапе можно запускать проект с параметрами по умолчанию, нажав на кнопку «Запуск» (с зеленой стрелкой), либо предварительно изменить настройки в соответствующем окне («Настройки запуска»). После этого начнется выполнение маршрута. Если в результате работы не было ошибок, в папке проекта будут сгенерированы такие файлы как: промежуточные описания, файлы размещения элементов на кристалле и прошивки (Рисунок 27).

Для выполнения CBA необходимо включить его в настройках опцией «Запустить статический временной анализ» и задать список тактовых сигналов схемы, список значений периодов тактовых сигналов, максимальную время прибытия сигнала на выходы схемы и другие опции CBA.



Рисунок 27. Окно проекта после окончания всех процессов

После того, как завершится этап синтеза и сгенерируется синтезированное описание проектируемой схемы, можно установить данный файл в качестве главного («Синтезированные описания» – «Установить как текущий»). В этом случае, при запуске маршрута, этап синтеза будет пропущен, и сразу будет осуществлен запуск программы ХА. Это может быть удобно при необходимости сравнить результаты работы маршрута с разными параметрами ядра.

# Использование внешних программ

Программа X-CAD предоставляет возможности для работы с внешними программами: X-Place, Icarus Verilog и GTK Wave.

Для каждой внешней программы, на панели инструментов и в меню «Инструменты», есть соответствующая кнопка, которая открывает окно с настройками запуска этой программы. В таком окне присутствуют следующие элементы: имя программы и соответствующая иконка, краткое описание, набор настроек запуска, поле дополнительных опций (на случай, если пользователю нужны другие опции, не представленные в окне), поле с результирующей строкой вызова программы и кнопки:

« 93начения по умолчанию» - возвращает все настройки к значениям по умолчанию;

«Рчистый запуск» - программа будет вызвана без аргументов;

«>Запуск» - запуск программы со всеми текущими настройками запуска.

# **Icarus Verilog**

Icarus Verilog - компилятор и симулятор языка описания аппаратуры Verilog стандарта IEEE-1364. Icarus Verilog имеет ограниченную поддержку временного моделирования и временной информации о схеме в формате Standard Delay Format (SDF). Формат SDF — это стандарт IEEE для представления и интерпретации временных данных для использования на любом этапе процесса проектирования электроники. Временное моделирование может быть полезно для выявления ложных путей и их проверки.

Для запуска моделирования Verilog-описания с помощью Icarus Verilog необходимо выполнить следующие действия:

- 1. добавить в папку «Тестовые модули» тестовый модуль (testbench) с описанием входных воздействий для тестируемой схемы;
- установить добавленный тестовый модуль с входными воздействиями модулем верхнего уровня (Рисунок 28);



Рисунок 28. Определение модуля верхнего уровня в окне обозревателя проекта

3. добавить в исходный код тестового модуля (testbench) строки для формирования временных диаграмм в формате VCD:

```
initial begin
$dumpfile("<vcd_file_name>.vcd");
$dumpvars(0,<tb_module_name>);
end
```

где:

<vcd\_file\_name> – имя выходного файла;

<tb\_module\_name> – имя тестового модуля верхнего уровня;

- открыть окно запуска Icarus Verilog («Инструменты» « <sup>№</sup> Icarus Verilog»), выбрать нужный файл из выпадающего списка «Тестовый файл» и выбрать нужный модуль из списка «Тестовый модуль»;
- 2. выбрать необходимые файлы с описанием проектной схемы для моделирования;
- 3. нажать на кнопку «Запустить».

Моделирование Verilog описания проектируемого устройства с помощью Icarus Verilog может быть выполнено в четырех вариациях, после прохождения различных этапов проектирования в ПЛИС. Варианты моделирования:

- 1. Моделирование RTL описания. Выполняется для поведенческого моделирования и формальной верификации исходного описания проекта на уровне RTL.
- 2. Моделирование синтезированного описания. Выполняется для верификации результатов логического синтеза проектируемой схемы.
- 3. Моделирование структурного описания. Выполняется для верификации результатов технологического отображения проектируемой схемы в базис элементов ПЛИС.
- 4. Моделирование структурного описания после трассировки. Выполняется для финальной верификации проектируемой схемы, после топологического синтеза.

### Моделирование RTL описания

Для проведения поведенческого моделирования RTL описания необходимо выбрать следующий набор файлов в окне «Входный файлы» для запуска lcarus Verilog (Рисунок 29):

- Файл с тестовым модулем (testbench);
- Исходные файлы с описанием проекта.

| 🔮 Настройки Icarus Verilog |                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                | ×                   |
|----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|
|                            |                                                                                                                                                                              | CARUS D                                                                                                                                                                                                                                                                                                        |                     |
| Тестовый файл              | D:/XCAD/src/examples/COMMON/                                                                                                                                                 | /tb_crc32.v                                                                                                                                                                                                                                                                                                    | Добавить            |
| Тестовый модуль            | tb_crc32                                                                                                                                                                     | ▼                                                                                                                                                                                                                                                                                                              |                     |
| Входные файлы              | Файл<br>Тестовые файлы<br>✓ Itb_crc32.v<br>Файлы проекта<br>✓ crc32.v<br>Виблиотечные файлы<br>✓ XC2M_IO_PtcV1.20T25.v<br>✓ XC2M_IP_PtcV1.20T25.v<br>✓ XC2M_RE_PtcV1.20T25.v | Путь<br>D:/XCAD/src/examples/COMMON/tb_crc32.v<br>D:/XCAD/src/libraries/XC2M/PtcV1.20T25/XC2M_IO_PtcV1.20T25.v<br>D:/XCAD/src/libraries/XC2M/PtcV1.20T25/XC2M_IP_PtcV1.20T25.v<br>D:/XCAD/src/libraries/XC2M/PtcV1.20T25/XC2M_LE_PtcV1.20T25.v<br>D:/XCAD/src/libraries/XC2M/PtcV1.20T25/XC2M_RE_PtcV1.20T25.v | Добавить<br>Удалить |
| Включить поддержку Specify | $\checkmark$                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                |                     |
| Дополнительные опции запу  | ска                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                |                     |
| Отмена                     |                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                | Запустить           |

Рисунок 29. Запуск моделирования RTL описания

#### Моделирование синтезированного описания

Для проведения поведенческого моделирования синтезированного описания необходимо выбрать следующий набор файлов в окне «Входный файлы» для запуска Icarus Verilog (Рисунок 30):

- Файл с тестовым модулем (testbench);
- Синтезированные файлы с описанием проекта.

Синтезированные файлы могут иметь различный суффикс, в зависимости от использованного ПО для логического синтеза:

- \*.syn\_y.v файл с результатами логического синтеза Yosys;
- \*.syn\_gen.v файл с результатами логического синтеза Cadance Genus;
- \*.syn\_dc.v файл с результатами логического синтеза Design Compiler.

При запуске моделирования синтезированного описания будут использованы усредненные задержки из конструкций specify, заданные в Verilog библиотеках использованных элементов. Для проведения моделирования без учета этих задержек необходимо снять галочку с опции «Включить поддержку Specify».

| Настройки Icarus Verilog   | 1                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                           | ×                          |
|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------|
|                            |                                                                                                                                                                                                                                                                                                                                                 | C-VEARUS                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                            |
| Тестовый файл              | D:/XCAD/src/examples/COMMC                                                                                                                                                                                                                                                                                                                      | DN/b_crc32.v                                                                                                                                                                                                                                                                                                                                                                                                                                              | Добавить                   |
| Тестовый модуль            | tb_crc32                                                                                                                                                                                                                                                                                                                                        | •                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                            |
| Входные файлы              | Файл           Тестовые файлы           ✓         th_crc32.v           Файлы проекта           crc32.v           ✓         crc32.svn_y.v           crc32.gate.v           crc32.routed.v           Øx67.notreчные файлы           ✓         XC2M_IC_PtcV1.2072!           ✓         XC2M_IE_PtcV1.2072!           ✓         XC2M_RE_PtcV1.2072! | Путь<br>D:/XCAD/src/examples/COMMON/tb_crc32.v<br>D:/XCAD/src/examples/COMMON/crc32.v<br>D:/XCAD/Projects/POI/crc32/crc32.syn_y.v<br>D:/XCAD/Projects/POI/crc32/crc32.syn_y.v<br>D:/XCAD/src/libraries/XC2M/PtcV1.20T25/XC2M_IO_PtcV1.20T25.v<br>S.v D:/XCAD/src/libraries/XC2M/PtcV1.20T25/XC2M_IP_PtcV1.20T25.v<br>S.v D:/XCAD/src/libraries/XC2M/PtcV1.20T25/XC2M_IE_PtcV1.20T25.v<br>S.v D:/XCAD/src/libraries/XC2M/PtcV1.20T25/XC2M_RE_PtcV1.20T25.v | <u>Добавить</u><br>Удалить |
| Включить поддержку Specify | ✓                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                            |
| Дополнительные опции запу  | icka                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                            |
| Отмена                     |                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Запустить                  |

Рисунок 30. Запуск моделирования синтезированного описания

### Моделирование структурного описания

Для проведения поведенческого моделирования структурного описания после этапа технологического отображения необходимо выбрать следующий набор файлов в окне «Входный файлы» для запуска lcarus Verilog (Рисунок 31):

- Файл с тестовым модулем (testbench);
- Синтезированные файлы с описанием проекта.

К синтезированным файлам для данного вида моделирования относятся:

- \*.gate.v файл со структурным описанием проекта на вентильном уровне в иерархическом виде после этапа технологического отображения в термины элементов ПЛИС;
- \*.flat.gate.v файл со структурным описанием проекта на вентильном уровне в плоском виде после этапа технологического отображения в терминах элементов ПЛИС;

• **\*.xmap.glib.v** - опциональный файл с библиотекой дополнительных элементов, задействованных при технологическом отображении.

При запуске моделирования описания в иерархическом виде необходимо **всегда** подключать библиотеку дополнительных элементов, в то время как для моделирования описания в плоском виде этого делать не требуется.

Данный вид моделирования может быть запущен с учетом задержек в формате SDF, полученных в результате статического временного анализа. Для этого необходимо убедиться в подключении соответствующего SDF файла в структурном описании с помощью конструкции *initial*:

# initial \$sdf\_annotate("<file\_name>.gate.sdf");

Для проведения моделирования без учета этих задержек необходимо снять галочку с опции «Включить поддержку Specify», либо закомментировать конструкцию *initial* в Verilog описании.

| Настройки Icarus Verilog   | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | ×                          |
|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------|
|                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | CICARUS D                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                            |
| Тестовый файл              | D:/XCAD/src/examples/COMMON                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | ۱/tb_crc32.v                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Добавить                   |
| Тестовый модуль            | tb_crc32                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | •                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                            |
| Входные файлы              | Файл           Image: Construct of the second sec | Путь<br>D:/XCAD/src/examples/COMMON/tb_crc32.v<br>D:/XCAD/src/examples/COMMON/crc32.v<br>D:/XCAD/Projects/POI/crc32/crc32.syn_v.v<br>D:/XCAD/Projects/POI/crc32/crc32.gate.v<br>D:/XCAD/Projects/POI/crc32/crc32.routed.v<br>v D:/XCAD/src/libraries/XC2M/PtcV1.20T25/XC2M_IO_PtcV1.20T25.v<br>v D:/XCAD/src/libraries/XC2M/PtcV1.20T25/XC2M_IP_PtcV1.20T25.v<br>v D:/XCAD/src/libraries/XC2M/PtcV1.20T25/XC2M_LE_PtcV1.20T25.v<br>v D:/XCAD/src/libraries/XC2M/PtcV1.20T25/XC2M_LE_PtcV1.20T25.v | <u>Добавить</u><br>Удалить |
| Включить поддержку Specify | V                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                            |
| Дополнительные опции запу  | icka                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                            |
| Отмена                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Запустить                  |

Рисунок 31. Запуск моделирования структурного описания

# Моделирование структурного описания после трассировки

Для проведения поведенческого моделирования структурного описания после этапа трассировки в ПЛИС необходимо выбрать следующий набор файлов в окне «Входный файлы» для запуска Icarus Verilog (см. Рисунок 32):

- Файл с тестовым модулем (testbench);
- Синтезированные файлы с описанием проекта.
- К синтезированным файлам для данного вида моделирования относятся:
- \*.routed.v файл со структурным описанием проекта на вентильном уровне в иерархическом виде после этапа трассировки в ПЛИС;

- \*.flat.routed.v файл со структурным описанием проекта на вентильном уровне в плоском виде после этапа трассировки в ПЛИС;
- **\*.xmap.glib.v** опциональный файл с библиотекой дополнительных элементов, задействованных при технологическом отображении.

При запуске моделирования описания в иерархическом виде необходимо **всегда** подключать библиотеку дополнительных элементов, в то время как для моделирования описания в плоском виде этого делать не требуется.

Данный вид моделирования может быть запущен с учетом задержек в формате SDF, полученных в результате статического временного анализа. Для этого необходимо убедиться в подключении соответствующего SDF файла в структурном описании с помощью конструкции *initial*:

# initial \$sdf\_annotate("<file\_name>.routed.sdf");

Для проведения моделирования без учета этих задержек необходимо снять галочку с опции «Включить поддержку Specify», либо закомментировать конструкцию *initial* в Verilog описании.

| 🔮 Настройки Icarus Verilog |                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                            | ×                          |
|----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------|
|                            |                                                                                                                                                                                                                                                                                                                                                                                  | CICARUS                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                            |
| Тестовый файл              | D:/XCAD/src/examples/COMMO                                                                                                                                                                                                                                                                                                                                                       | N/tb_crc32.v                                                                                                                                                                                                                                                                                                                                                                                                                                               | • Добавить                 |
| Тестовый модуль            | tb_crc32                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                            | <b>~</b>                   |
| Входные файлы              | Файл           Тестовые файлы           ✓           Файлы проекта           crc32.v           crc32.syn_y.v           crc32.qate.v           v           vc32.gate.v           vc32.gate.v           vc32.routed.v           Библиотечные файлы           ✓           XC2M_ID_PtcV1.20T25.           ✓           XC2M_LE_PtcV1.20T25.           ✓           XC2M_RE_PtcV1.20T25. | Путь<br>D:/XCAD/src/examples/COMMON/tb_crc32.v<br>D:/XCAD/Projects/PO1/crc32/crc32.syn_y.v<br>D:/XCAD/Projects/PO1/crc32/crc32.gate.v<br>D:/XCAD/Projects/PO1/crc32/crc32.routed.v<br>v D:/XCAD/src/libraries/XC2M/PtcV1.20T25/XC2M_IO_PtcV1.20T25.v<br>v D:/XCAD/src/libraries/XC2M/PtcV1.20T25/XC2M_IP_PtcV1.20T25.v<br>v D:/XCAD/src/libraries/XC2M/PtcV1.20T25/XC2M_LE_PtcV1.20T25.v<br>v D:/XCAD/src/libraries/XC2M/PtcV1.20T25/XC2M_RE_PtcV1.20T25.v | <u>Добавить</u><br>Удалить |
| Включить поддержку Specify | V                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                            |
| Дополнительные опции запу  | oka                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                            |
| Отмена                     |                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Запустить                  |

Рисунок 32. Запуск моделирования структурного описания после трассировки

# **GTK Wave**

По завершении работы Icarus Verilog образуется «\*.vcd» файл, который можно открыть программой GTK Wave («Инструменты» – «**Ш**GTK Wave») (Рисунок 33) через соответствующее окно программы X-CAD для просмотра результатов моделирования (Рисунок 34).

| 📓 Настройки запуска                             | ×                                       |  |  |  |  |
|-------------------------------------------------|-----------------------------------------|--|--|--|--|
| Описание:                                       | GTKWave                                 |  |  |  |  |
|                                                 |                                         |  |  |  |  |
| Файл                                            | C:/XCAD/Projects/crc32/crc32.routed.vcd |  |  |  |  |
| Дополнительные опции                            |                                         |  |  |  |  |
| gtkwave C:/XCAD/Projects/crc32/crc32.routed.vcd |                                         |  |  |  |  |
| 🔕 Значения по умо.                              | лчанию Ристый запуск Запустить          |  |  |  |  |

Рисунок 33. Окно запуска GTK Wave

| File Edit Search Time Markers View Help      Signals          Signals                                                                           Site or Cold State or Co                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | GTKWave - C:/X-CAD/Projects/crc32/crc32.vcd                                                                                                   |                                                          | — r | $\times$ |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------|-----|----------|
| Image: Contract of the second of the seco | File Edit Search Time Markers View Help                                                                                                       |                                                          |     |          |
| v SST       Signals         Time       clk         crc_out[31:0]       data         enable       reset         Signals       reset                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | ¥ 🕞 📴 I Q € Q 🥎 🍋 🖓 I 🖨 🌳                                                                                                                     | From: 0 sec To: 21350 ns   🔁   Marker:   Cursor: 1030 ns |     |          |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | <pre> v SST  ime clk crc_out[31:0] data enable reg clk wire crc_out[31:0] reg data reg enable reg reset  Filter: Append Insert Replace </pre> | Maves                                                    |     |          |

Рисунок 34. Окно программы GTK Wave с результатами моделирования

# Анализатор HDL-описаний

HDL-описания проектных схем на языке Verilog могут быть подвергнуты синтаксическому анализу. Для этого необходимо:

- 1. Открыть окно анализа («Инструменты» « Анализ кода»).
- 2. В появившемся окне выбрать необходимый язык описания и нажать на кнопку «Ок» (Рисунок 35).

| 🚍 Анализ кода |            |    |  |  |  |  |  |
|---------------|------------|----|--|--|--|--|--|
| Язык          | ык Verilog |    |  |  |  |  |  |
|               | Отмена     | Ок |  |  |  |  |  |

Рисунок 35. Окно запуска анализа HDL-описаний

После завершения анализа появится окно с сообщением о количестве ошибок и предупреждений, либо их отсутствии. Найденные ошибки и предупреждения можно просмотреть в окне « ПСписок ошибок» (Рисунок 36). Двойной клик левой кнопкой мыши по строке данного списка приведет к открытию файла, в котором возникла проблема, и установке указателя на необходимую строку.

| Вывод               |       |                                               | 6 × |
|---------------------|-------|-----------------------------------------------|-----|
| Текущее окно: Списо | к оши | бок 👻 📥                                       |     |
| File                | Line  | Error                                         |     |
| C:/X-CAD/crc32      | v 9   | syntax error                                  |     |
| C:/X-CAD/crc32      | v 8   | Errors in port declarations.                  |     |
| C:/X-CAD/crc32      | v 49  | warning: implicit definition of wire 'crc_o'. |     |
|                     |       |                                               |     |
|                     |       |                                               |     |
|                     |       |                                               |     |
|                     |       |                                               |     |
|                     |       |                                               |     |
|                     |       |                                               |     |

Рисунок 36. Список ошибок

# Интерфейс топологического редактирования X-PLACE

X-Place – графический интерфейс, предназначенный для просмотра и редактирования размещения функциональных и сложных функциональных блоков (СФ-блоков), периферийных блоков и макроблоков на кристалле ПЛИС.

Программа разработана с применением кроссплатформенных средств разработки и распространяется на платформах семейств Windows и Unix. Средства разработки включают библиотеки: Qt, OpenGL.

# Запуск программы

Запуск программы может быть осуществлен посредством запуска исполняемого файла через обозреватель файлов, запуска из командной строки или через соответствующее окно программы X-CAD.

# Запуск через обозреватель файлов

Для запуска через обозреватель файлов необходимо открыть папку с исполняемым файлом «xplace.exe», который расположен в директории «bin» пакета программ, и активировать двойным щелчком ЛКМ или вызвать с помощью правой кнопки мыши контекстное меню и выбрать соответствующий пункт для запуска приложения.

# Запуск через командную строку

Чтобы запустить программу посредством командной строки, необходимо перейти в папку «bin» пакета программ и вызвать на исполнение файл «x-place.exe», используя следующие команды:

- Windows: "start xplace.exe < аргументы\_u\_значения>"
- Unix: "./xplace < аргументы\_u\_значения>"

Программа поддерживает следующие аргументы командной строки:

- -*і «файл»* описание схемы (на языке Tcl в стандартном режиме);
- - *I* «файл» библиотека элементов схемы (на языке Tcl);
- *-р «файл»* файл размещения элементов (на языке Tcl);
- *-с «имя\_кристалла»* данные кристалла по имени, которое соответствует имени кристалла в файле «xa\_config.ini».
- -*pp* запуск программы в режиме планировки кристалла.

# Запуск через интерфейс Х-САД

Для запуска программы следует активировать соответствующий пункт меню программы X-CAD («Инструменты» – «X-Place») (Рисунок 37) и в открывшемся окне нажать кнопку «Чистый запуск», или установить необходимые значения параметров запуска и нажать «Запустить».

| 🛞 Настройки запуска                                                                                                                                          |                                                                                     | ×                                         |  |  |  |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------|-------------------------------------------|--|--|--|--|
| Описание:                                                                                                                                                    |                                                                                     | X-Place                                   |  |  |  |  |
| Схема                                                                                                                                                        | [-i]                                                                                | C:/X-CAD/Projects/fa_test/fa.xmap.tcl     |  |  |  |  |
| Библиотека                                                                                                                                                   | [-]]                                                                                | C:/X-CAD/Projects/fa_test/fa.xmap.lib.tcl |  |  |  |  |
| Размещение                                                                                                                                                   | [-p]                                                                                | C:/X-CAD/Projects/fa_test/fa.place.tcl    |  |  |  |  |
| плис                                                                                                                                                         | [-c]                                                                                | 5400TP094                                 |  |  |  |  |
| Дополнительные опции                                                                                                                                         |                                                                                     |                                           |  |  |  |  |
| x-place.exe -i C:/X-CAD/Projects/fa_test/fa.xmap.tcl -l C:/X-CAD/Projects/fa_test/fa.xmap.lib.tcl -p C:/<br>X-CAD/Projects/fa_test/fa.place.tcl -c 5400TP094 |                                                                                     |                                           |  |  |  |  |
| 🙆 Значения по умол                                                                                                                                           | <ul> <li>Эначения по умолчанию</li> <li>Чистый запуск</li> <li>Запустить</li> </ul> |                                           |  |  |  |  |

Рисунок 37. Окно запуска X-Place

### Главное окно для работы с проектом

Главное окно – основное пространство для работы с проектом, содержащее следующие элементы интерфейса:

- Главное меню (Рисунок 38-1);
- Панели инструментов (Рисунок 38-2);
- Обозреватель структуры схемы (Рисунок 38-3);
- Обозреватель списка цепей (Рисунок 38-4);
- Рабочее графическое поле (Рисунок 38-5);
- Окно «Tcl консоль» (Рисунок 38-6);
- Статусная строка (Рисунок 38-7).



Рисунок 38. Структура главного окна программы:

1 – главное меню; 2 – панели инструментов; 3 – обозреватель структуры схемы;
 4 – обозреватель списка цепей; 5 – рабочее окно;
 6 – окно «ТсІ консоль»; 7 – статусная строка

# Главное меню

*Главное меню* (Рисунок 35-1) – панель с дочерними меню, содержащими основные действия для работы с программой. Меню содержит следующие дочерние меню:

- «Файл» открытие описания схемы на языке Tcl в терминах XA, сохранение текущего размещения, загрузка размещения, завершение работы программы;
- «Редактировать» удаление выбранных размещенных элементов, выделение всех элементов;

- «Вид» позволяет:
  - Управлять графическим отображением кристалла;
  - Устанавливать режим отображения межсоединений;
  - Устанавливать режим отображения межсоединений выделенных объектов;
  - Включать/отключать динамическое выделение объектов на кристалле;
- «Кристалл» выбор целевого кристалла, загрузка кристалла из index.tcl файла;
- «Режим работы» переключение режимов работы: стандартный или FloorPlanner;
- «Окно» настройка шрифта приложения, выбор языка;
- «Помощь» позволяет получить вспомогательную информацию (находится в разработке).

#### Панели инструментов

*Панели инструментов* (Рисунок 38-2) повторяют наиболее востребованные в процессе работы действия, содержащиеся в меню, для быстрого доступа. Сюда включены следующие панели:

- Главная панель инструментов (повторяет меню «Файл»);
- Инструменты для работы с размещением (повторяет меню «Редактировать»);
- Некоторые другие инструменты.

Панели могут быть передвинуты пользователем в любую часть окна.

### Обозреватель структуры схемы

Обозреватель структуры схемы (Рисунок 38-3, Рисунок 39) – окно, в котором отображается структура схемы, представленная в виде списка элементов, разделенных по типам целевых ячеек кристалла.



Рисунок 39. Обозреватель структуры схемы

Слева от каждого элемента есть иконка, которая отражает состояние элемента:

| Иконка | Описание                                                                                                            |
|--------|---------------------------------------------------------------------------------------------------------------------|
| 0      | Библиотечные данные для элемента загружены не были. Перед размещением следует сначала подгрузить данные библиотеки. |
|        | Библиотечные данные для элемента загружены. Элемент готов к размещению.                                             |
|        | Библиотечные данные загружены. Элемент размещен                                                                     |

Для каждого элемента схемы с помощью ПКМ может быть вызвано контекстное меню. Меню имеет следующие элементы:

- «Информация» открывает окно с информацией об элементе и ячейке, к которой он привязан (если есть);
- «Отменить размещение» отменяет назначение элемента ячейке;
- «Установить фокус» устанавливает фокус на ячейке, в которую размещен элемент (если есть).

Также обозреватель поддерживает *механизм захвата и перетаскивания (Drag'n'Drop)*, с помощью которого можно назначить элемент на нужную ячейку.

Двойное нажатие ЛКМ на элементе схемы установит фокус подобно пункту меню «Установить фокус».

#### Обозреватель списка цепей

Обозреватель списка цепей (Рисунок 38-4, Рисунок 40) – окно, в котором отображается список цепей и откуда можно управлять их отображением.

| Список цепей         | ð 🗙 |
|----------------------|-----|
| Имя цепи             | -   |
| 🔻 🗸 Список цепей(10) |     |
| ✓ XC_O_sum           |     |
| XC_O_carry           |     |
| ✓ XC_I_c             |     |
| ✓ XC_I_b             |     |
| ✓ XC_I_a             |     |
| ✓ sum                |     |
| ✓ carry              |     |
| V c                  |     |
| V b                  |     |
| <b>√</b> a           |     |

Рисунок 40. Обозреватель списка цепей

*Флаг* рядом с цепью отвечает за ее *отображение в графическом окне*. Если флаг установлен, то цепь отображается, иначе – скрывается.

Флаг корневого элемента списка цепей влияет на все цепи.

При выделении одной или нескольких цепей, они выделяются в графическом окне (даже если флаг(и) отключен(ы)).

### Рабочее графическое поле

*Рабочее графическое поле* (Рисунок 38-5) – основное средство работы с размещением элементов. Оно имеет следующие возможности:

- Поддерживает механизм Drag'n'Drop для перемещения и назначения элементов в ячейки;
- Масштабирование посредством вращения колесика мыши;
- Перемещение обзора посредством перемещения мыши с зажатой клавишей СКМ (средней кнопки мыши);
- Выделение ячеек:
  - Выделение ячейки с помощью ЛКМ;
  - Выделение группы ячеек с помощью зажатой клавиши Ctrl и одиночного щелчка ЛКМ по необходимым ячейкам;
  - о Выделение группы ячеек посредством движения мыши с зажатой ЛКМ;
  - Выделение всех ячеек с помощью горячей клавиши «Ctrl+A» (аналогично «Редактировать – Выделить все»);
- Двойной щелчок ЛКМ по ячейке открывает информационное окно для ячейки и размещенного элемента (если есть);
- Всплывающие подсказки с именами ячеек и размещенными в них элементами (если есть) при наведении мыши на ячейку.

Также для рабочего графического поля можно выставить различные настройки отображения (см. ниже «Настройки отображения»).

# Окно «Tcl консоль»

*Окно «Tcl консоль»* (Рисунок 38-6, Рисунок 41) – окно в котором отображается информация о процессе размещения элементов на схеме. Окно также является консолью с поддержкой языка Tcl, где можно исполнять команды данного языка.

Окно обладает подсветкой синтаксиса, выделяя разными цветами информационные сообщения, предупреждения и ошибки.



Рисунок 41. Окно «ТсІ консоль»

# Статусная строка

Статусная строка (Рисунок 38-7) необходима для отображения краткой информации о работе программы.

### Пример работы программы

Для того чтобы показать, как работает программа, возьмем результаты работы XA по схеме «fa» из примера работы программы X-CAD.

При запуске программы X-Place появляется главное окно (Рисунок 42), в котором пока нет данных ни о кристалле, ни о схеме.



Рисунок 42. Вид главного окна при запуске

# Загрузка кристалла

Следующим шагом необходимо загрузить кристалл ПЛИС. Сделать это можно двумя способами:

- 1. открыть меню «Кристалл» из панели меню и выбрать необходимый кристалл, наведя указатель мыши на необходимое семейство кристаллов;
- выбрать «Кристалл Загрузить кристалл из index файла». Откроется окно файлового обозревателя, через который необходимо выбрать файл с расширением «\*.index.tcl» (для того чтобы загрузить схему, рядом с этим файлом должен лежать файл с расширением «\*.place.tcl») и нажать «Открыть».

После этого начнется загрузка кристалла, который в результате будет отображен в графической области главного окна (Рисунок 43).



Рисунок 43. Главное окно с загруженным графическим представлением кристалла ПЛИС

# Загрузка схемы

Теперь следует загрузить схему, которая будет размещена на кристалле. Сделать это можно через меню «Файл – Открыть схему». Откроется окно файлового обозревателя, где следует выбрать файл схемы с расширением «\*.tcl». Для примера, на рисунке 44 изображено окно после загрузки файла «fa.xmap.tcl» с описанием схемы «fa» (Рисунок 44).



Рисунок 44. Окно программы после загрузки схемы

# Загрузка библиотеки элементов

Если рядом с файлом лежит библиотека элементов (в терминах ХА и расширением «\*.xmap.lib.tcl»), то данные из неё будут автоматически подгружены программой после того, как пользователь подтвердит действие в информационном окне (например, для данной схемы – «fa.xmap.lib.tcl»), элементы будут объединены в группы по типу целевого блока и слева от имени элемента будет отображаться серый значок, означающий, что элемент пока не размещен на кристалле (Рисунок 45-б). Если же библиотека не была найдена или пользователь отказал в загрузке, то данные подгружены не будут, программа предупредит об этом, все элементы будут объединены в группу «Without library data» и рядом с элементами будет отображаться красный значок (Рисунок 45-а).



Рисунок 45. Обозреватель структуры:

а) – до загрузки библиотечных данных; б) – после загрузки данных

Если после загрузки библиотеки все еще остались элементы без данных, то программа предложит подгрузить данные из стандартных библиотек.

Элементы, которые не имеют библиотечных данных невозможно будет разместить на кристалле.

Библиотечные данные можно подгрузить и из сторонней библиотеки. Для этого необходимо выбрать «Файл – Загрузить библиотеку», через окно обозревателя файлов выбрать необходимый файл библиотеки и нажать «Открыть».

### Размещение элементов на кристалле

После успешной загрузки схемы и в случае отсутствия элементов без библиотечных данных, программа предпримет попытку автоматического поиска файлов размещения (с расширением «\*.place.tcl»). Если файл размещения был найден, то программа запросит разрешение на его загрузку и, в случае положительного ответа пользователя, данные размещения будут загружены.

После загрузки схемы можно приступать к ручному размещению элементов или загрузить уже готовый файл размещения для его редактирования. Для загрузки размещения необходимо выбрать «Файл – Загрузить размещение» и через обозреватель выбрать файл размещения (часто с расширением «\*.place.tcl»). Для примера был открыт файл «fa.place.tcl» (Рисунок 46).



Рисунок 46. Окно с загруженными данными размещения схемы «fa»

После того, как элементы будут расположены на кристалле, занятые ячейки будут окрашены в оранжевый цвет, а значки в списке элементов поменяют цвет с серого на зеленый. Также будет сгенерирована система межсоединений элементов в зелено-жёлтой окраске: жёлтая часть соединения – цепь для этого элемента является выходной, зеленая – входной.

Если при загрузке размещения некоторые элементы уже оказываются размещены, появится информационное окно с вопросом о том, что хочет сделать пользователь. Тут имеются три варианта:

- «Продолжить» элементы со схожими именами будут перемещены, а все остальные останутся на местах;
- «Очистить и продолжить» текущее размещение полностью очищается, чтобы произвести «чистое» размещение;
- «Отмена» загрузка осуществлена не будет.

#### Сохранение полученного размещения

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

для дальнейшего использования при проектировании в программе X-CAD.

Данная функция доступна в меню «Файл» (Рисунок 47) и поддерживает сохранение следующих типов файлов:

«\*.place.tcl» – размещение всей схемы (Рисунок 47-1);

«\*.inout.tcl» – размещение ячеек ввода/вывода(Рисунок 47-2);

«\*.macro.tcl» – размещение макроблоков(Рисунок 47-3).

«\*.ip.tcl» – размещение IP-блоков(Рисунок 47-4).

| 📒 Открыть схему        |   | Ctrl+O         |
|------------------------|---|----------------|
| 💵 Загрузить библиотеку |   | Ctrl+L         |
| 📳 Загрузить размещение |   | Ctrl+P         |
| 🛃 Экспорт размещения   | 1 | Ctrl+S, Ctrl+E |
| 🛃 Экспорт inout.tcl    | 2 |                |
| 🛃 Экспорт macro.tcl    | 3 |                |
| 🛃 Экспорт ip.tcl       | 4 |                |
| 🗙 Выйти                |   | Ctrl+Q         |

Рисунок 47. Функция экспорта размещения всей схемы, ячеек ввода/вывода или макроблоков

### Настройки отображения

Общие настройки отображения («Вид – Отображаемые объекты») позволяют настроить (включить/отключить) отображение:

- Заполненные ячейки;
- Кристалл (не затрагивает занятые ячейки);
- Цепи (не затрагивает отображение цепей выделенных ячеек);
- Подсвеченные цепи выделенных объектов.

*Настройки режима отображения цепей* (пример на Рисунок 48) позволяют выбрать один из двух режимов отображения:

- *Прямые соединения* из каждого размещенного элемента выходят соединяющие линии напрямую к элементам, связанным с данным;
- Центрированные соединения межсоединение представляет собой группу линий с общим центром масс, откуда эти линии выходят по направлению к подсоединенным элементам.

Настройки режима отображения подсвеченных цепей позволяет выбрать режим подсвечивания соединений выделенных объектов:

- Только подсоединенные элементы подсвечиваются только те линии, которые связывают данный элемент с другими;
- Полностью подсветить цепь межсоединение подсвечивается полностью, то есть не только соединения данного элемента с другими, но и все другие направления, куда распространяется это межсоединение.

*Динамическое выделение рамкой* подразумевает отображение результата выделения сразу после изменения положения выделяющей рамки, а не после того, как пользователь отпустит кнопку мыши (ВНИМАНИЕ! На больших схемах сильно снижает производительность).



Рисунок 48. Способы представления цепей (пример на регулярной структуре ПЛИС): центрированный (слева) и прямой (справа)

# Интерфейс планировки кристалла FLOORPLANNER

FloorPlanner – режим программы X-Place, предназначенный для ручного размещения и настройки периферийных элементов, макроблоков и IP-блоков на кристалле ПЛИС до этапа физического синтеза схемы.

# Запуск программы

Запуск программы может быть осуществлен посредством запуска исполняемого файла через обозреватель файлов, из командной строки или через соответствующее окно программы X-CAD.

# Запуск через обозреватель файлов

Для запуска через обозреватель файлов необходимо открыть папку с исполняемым файлом «x-place.exe», который расположен в директории «bin» пакета программ, и активировать двойным щелчком левой кнопки мыши или вызвать с помощью правой кнопки мыши контекстное меню и выбрать соответствующий пункт для запуска приложения. Затем необходимо в меню программы переключить режим работы на режим планировки кристалла («Режим работы» - «FloorPlanner»).

| Файл   | Редакти | ровать | Вид | Кристалл | Режим работы  | Окно | Помощь |     |
|--------|---------|--------|-----|----------|---------------|------|--------|-----|
|        | 1       |        |     | D C      | Стандартны    | ій   |        | 0 0 |
| CTOWET |         |        |     |          | ✓ FloorPlanne | r    |        | -   |

Рисунок 49. Смена режима работы через меню программы

# Запуск через командную строку

Чтобы запустить программу посредством командной строки, необходимо перейти в папку «bin» пакета программ и вызвать на исполнение файл «x-place.exe», используя следующие команды:

- Windows: "start x-place.exe -pp < аргументы\_u\_значения>"
- Unix: "./x-place.exe -pp < аргументы\_u\_значения>"

Программа поддерживает следующие аргументы командной строки:

- -і «файл» описание схемы (на языке Verilog);
- -I «файл» библиотека элементов схемы (на языке Tcl);
- *-р «файл»* файл размещения (на языке Tcl, \*.inout.tcl, \*.macro.tcl);

- *-с «имя\_кристалла»* данные кристалла по имени, которое соответствует имени кристалла в файле «xa\_config.ini».
- -pp запуск программы в режиме планировки кристалла;
- -top имя топ-модуля.

### Запуск через интерфейс Х-САD

Для запуска программы необходимо выбрать соответствующий пункт меню программы X-CAD («Инструменты» - «FloorPlanner») или кнопку на панели инструментов, затем, в появившемся окне (Рисунок 50) нажать на кнопку «Чистый запуск» или «Запустить». Нажатие на кнопку «Запустить» приведет к запуску программы с передачей в качестве аргументов всех Verilog-файлов, лежащих в разделе «HDL-описания», а также топ-модуля и используемого кристалла. Также можно передать inout-файл, содержащий размещение I/O элементов.

| 🛱 Настрої  | йки FloorPlanner                |           | Х |
|------------|---------------------------------|-----------|---|
|            | FLO                             | OR        |   |
| Категория  | HDL описания                    |           | • |
| Топ-файл   | C:/X-CAD/Projects/crc32/crc32.v |           | - |
| Топ-модуль | arc32                           |           | - |
| Inout-файл |                                 | ▼ ) [     |   |
| Macro-файл |                                 |           |   |
| Кристалл   | 5510TC044A                      |           |   |
|            | 찯 Чистый запуск                 | Запустить |   |

Рисунок 50. Окно запуска X-Place в режиме FloorPlanner

# Интерфейс программы

Окно программы представлено на рисунок 51 и содержит следующие элементы интерфейса:

- Главное меню (Рисунок 51-1);
- Панели инструментов (Рисунок 51-2);
- Обозреватель элементов (Рисунок 51-3);
- Рабочее графическое поле (Рисунок 51-4);
- Окно «Tcl консоль» (Рисунок 51-5);
- Статусная строка (Рисунок 51-6).


Рисунок 51. Структура главного окна программы в режиме FloorPlanner: 1 – главное меню; 2 – панели инструментов; 3 – обозреватель элементов; 4 – рабочее окно; 5 – окно «Tcl консоль»; 6 – статусная строка

#### Главное меню

*Главное меню* – панель с дочерними меню, содержащими основные действия для работы с программой. Меню содержит следующие дочерние меню:

- «Файл» открытие описания схемы на языке Verilog, сохранение текущего размещения элементов, загрузка размещения, завершение работы программы;
- «Редактировать» удаление выбранных размещенных элементнов, выделение всех элементов;
- «Вид» позволяет:
  - о управлять графическим отображением кристалла;
  - о Устанавливать режим отображения межсоединений;
  - о Устанавливать режим отображения межсоединений выделенных объектов;
  - Включать/отключать динамическое выделение объектов на кристалле;
- 🛛 🛛 «Кристалл» выбор целевого кристалла, загрузка кристалла из index.tcl файла;

- Режим работы переключение режимов работы: стандартный или FloorPlanner;
- «Окно» настройка шрифта приложения, выбор языка;
- «Помощь» позволяет получить вспомогательную информацию (находится в разработке).

## Панели инструментов

*Панели инструментов* повторяют наиболее востребованные в процессе работы действия, содержащиеся в меню, для быстрого доступа. Сюда включены следующие панели:

- Главная панель инструментов (повторяет меню «Файл»);
- Инструменты для работы с размещением (повторяет меню «Редактировать»);
- Панель дополнительных инструментов.

Панели могут быть перемещены пользователем в любую часть окна.

#### Обозреватель элементов

Обозреватель элементов (Рисунок 52) — окно, в котором отображаются входные/выходные сигналы, а также макроблоки и IP-блоки, используемые в Verilog-описаниях.

| Структура схемы 🞯              |           |         |       |   |         |   |                           |   |  |
|--------------------------------|-----------|---------|-------|---|---------|---|---------------------------|---|--|
| Название                       | Группа I/ | Тип I/О | Пин   |   | Элемент |   |                           |   |  |
| <ul> <li>INPUT (3)</li> </ul>  |           |         |       |   |         |   |                           |   |  |
| 📀 a                            | PAD       | ٣       | xa_ib | ٣ | a       | * | [FROM_PAD2   TO_PAD2]     | • |  |
| 📀 ь                            | PAD       | ٠       | xa_ib | ٠ | a       | Ŧ | [FROM_PAD3   TO_PAD3]     | • |  |
| 📀 с                            | PAD       | Ŧ       | xa_ib | ٠ | a       | Ŧ | [FROM_PAD1   TO_PAD1]     | • |  |
| <ul> <li>OUTPUT (2)</li> </ul> |           |         |       |   |         |   |                           |   |  |
| < sum                          | PAD       | ۳       | xa_ob | ۳ | x       | • | [TO_PAD204   FROM_PAD204] | • |  |
| 📀 carry                        | PAD       | ٠       | xa_ob | ٠ | x       | • | [TO_PAD203   FROM_PAD203] | • |  |

#### Рисунок 52. Обозреватель структуры схемы

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

Над элементами данного окна доступны те же операции, что и над элементами обозревателя структуры схемы «Стандартного» режима, описанного ранее.

## Рабочее графическое поле

*Рабочее графическое поле* – основной инструмент планировки кристалла. Поле имеет следующие возможности:

- Поддерживает механизм Drag'n'Drop для перемещения и назначения элементов в ячейки;
- Масштабирование посредством вращения колесика мыши;
- *Перемещение* обзора посредством перемещения мыши с зажатой клавишей СКМ (средней кнопки мыши);
- Выделение ячеек:
  - Выделение ячейки с помощью ЛКМ;
  - о Выделение группы ячеек с помощью зажатой клавиши Ctrl и одиночного щелчка ЛКМ

по необходимым ячейкам;

- о Выделение группы ячеек посредством движения мыши с зажатой ЛКМ;
- Выделение всех ячеек с помощью горячей клавиши «Ctrl+A» (аналогично «Редактировать – Выделить все»);
- Двойной щелчок ЛКМ по ячейке открывает информационное окно для ячейки, которое также позволяет назначить элемент в данную ячейку;
- Всплывающие подсказки с именами ячеек и размещенными в них элементами (если есть) при наведении мыши на ячейку.

## Окно «Tcl консоль»

*Окно «Tcl консоль»* – окно в котором отображается информация о процессе размещения элементов на схеме. Окно также является консолью с поддержкой языка Tcl, где можно исполнять команды данного языка.

## Статусная строка

Статусная строка необходима для отображения краткой информации о статусе работы программы.

## Пример работы программы в режиме FloorPlanner

Работа программы в режиме FloorPlanner будет продемонстрирована на схеме fa.

При запуске программы X-Place пользователя встречает главное окно (Рисунок 53). Если программа была запущена без дополнительных аргументов, то рабочее поле и окно «Структура схемы» будут пустыми.

Если программа была запущена без аргумента «-*pp*», то необходимо переключиться в режим «FloorPlanner» («Режим работы – FloorPlanner»).



### Рисунок 53. Вид главного окна при запуске

## Загрузка кристалла

Следующим шагом необходимо загрузить кристалл ПЛИС. Сделать это можно следующим образом: открыть меню «Кристалл» из панели меню и выбрать необходимый кристалл, где кристаллы разбиты по семействам. После этого начнется загрузка ячеек схемы, которые в результате будут отображены в графической области главного окна (Рисунок 54). После завершения данного процесса автоматически будут загружены стандартные библиотеки целевого кристалла ПЛИС.

В том случае, если для загрузки доступен ровно один кристалл ПЛИС, то при старте программы, данный кристалл будет загружен автоматически.



Рисунок 54. Главное окно с загруженным графическим представлением кристалла ПЛИС

### Загрузка схемы

Теперь следует загрузить Verilog-описание, элементы которого необходимо разместить. Сделать это можно через меню «Файл – Открыть схему». Откроется окно файлового обозревателя, где следует выбрать файлы с расширением «\*.v». Следом за этим откроется окно, в котором необходимо выбрать какой из выбранных файлов и какой модуль в выбранном файле будут главными (Рисунок 55).

| Placement_G    | ?                                    | $\times$ |   |
|----------------|--------------------------------------|----------|---|
| Файлы          | Файлы<br>D:/XCAD_PROJECTS/tests/fa.v |          |   |
| Главный файл   | D:/XCAD_PROJECTS/tests/fa.v          |          | • |
| Главный модуль | fa                                   |          | • |
| Отменить       |                                      | Ок       |   |

Рисунок 55. Окно выбора главного файла и главного модуля

Для примера, на рисунке 56 изображено окно после загрузки файла «fa.v» с описанием схемы «fa» в базисе выбранной ПЛИС (Рисунок 56).

| 🛞 X-place                      |             |            |            |            |          |        |   |    |   |   |  |  |  | - | ×  |
|--------------------------------|-------------|------------|------------|------------|----------|--------|---|----|---|---|--|--|--|---|----|
| Файл Редакти                   | ировать Ви, | д Криста   | лл Реж     | ким работь | ы Окно I | Помощь |   |    |   |   |  |  |  |   |    |
| 📒 💵 📓                          | 5 5         | <b>כ</b> ו | <b>C</b> % | 🗈 X        |          | 0      | € | ΘJ | 0 | 0 |  |  |  |   |    |
| Структура схемы                |             |            |            |            | 6        | <      |   |    |   |   |  |  |  |   |    |
| Название                       | Группа I/O  | Тип I/О    | Пин        | Элемент    |          |        |   |    |   |   |  |  |  |   |    |
| <ul> <li>Input (3)</li> </ul>  |             | · · · · ·  |            |            |          |        |   |    |   |   |  |  |  |   |    |
| 🗢 a                            | PAD -       | xa_ib •    | • a •      |            | -        |        |   |    |   |   |  |  |  |   |    |
| 🕗 Ь                            | PAD 👻       | xa_ib •    | • a •      |            | -        | 1 : 😐  |   |    |   |   |  |  |  |   |    |
| 🖉 c                            | PAD 👻       | xa_ib •    | • a •      |            |          |        |   |    |   |   |  |  |  |   |    |
| <ul> <li>Output (2)</li> </ul> |             |            |            |            |          |        |   |    |   |   |  |  |  |   |    |
| Sum 🖉                          | PAD 👻       | xa_ob •    | • x •      |            | •        |        |   |    |   |   |  |  |  |   |    |
| 🖉 carry                        | PAD 👻       | xa_ob *    | • x •      |            | -        |        |   |    |   |   |  |  |  |   |    |
|                                |             |            |            |            |          |        |   |    |   |   |  |  |  |   |    |
|                                |             |            |            |            |          |        |   |    |   |   |  |  |  |   |    |
|                                |             |            |            |            |          |        |   |    |   |   |  |  |  |   |    |
|                                |             |            |            |            |          |        |   |    |   |   |  |  |  |   |    |
|                                |             |            |            |            |          |        |   |    |   |   |  |  |  |   |    |
|                                |             |            |            |            |          |        |   |    |   |   |  |  |  |   |    |
|                                |             |            |            |            |          |        |   |    |   |   |  |  |  |   |    |
|                                |             |            |            |            |          |        |   |    |   |   |  |  |  |   |    |
|                                |             |            |            |            |          |        |   |    |   |   |  |  |  |   |    |
| Вывод                          |             |            |            |            |          |        |   |    |   |   |  |  |  |   | ØX |
| Tcl console                    | (Tcl ver    | 8.5.19     | e);        |            |          |        |   |    |   |   |  |  |  |   |    |
| OpenGL: Deb                    | ugger cre   | ated.      |            |            |          |        |   |    |   |   |  |  |  |   |    |
| QTcl shell>                    |             |            |            |            |          |        |   |    |   |   |  |  |  |   |    |
|                                |             |            |            |            |          |        |   |    |   |   |  |  |  |   |    |
|                                |             |            |            |            |          |        |   |    |   |   |  |  |  |   |    |
|                                |             |            |            |            |          |        |   |    |   |   |  |  |  |   |    |
|                                |             |            |            |            |          |        |   |    |   |   |  |  |  |   |    |
|                                |             |            |            |            |          |        |   |    |   |   |  |  |  |   |    |
|                                |             |            |            |            |          |        |   |    |   |   |  |  |  |   |    |
|                                |             |            |            |            |          |        |   |    |   |   |  |  |  |   |    |
|                                |             |            |            |            |          |        |   |    |   |   |  |  |  |   |    |
|                                |             |            |            |            |          |        |   |    |   |   |  |  |  |   |    |

Рисунок 56. Окно программы после загрузки схемы

## Загрузка библиотеки элементов

Если Verilog-описание использует элементы, неописанные в стандартных библиотеках кристалла, то данные элементы будут недоступны для использования. Для того, чтобы появилась возможность использования данных элементов, необходимо подгрузить данные элементы из сторонней библиотеки. Для этого необходимо выбрать «Файл – Загрузить библиотеку», через окно обозревателя файлов выбрать необходимый файл библиотеки и нажать «Открыть».

## Размещение элементов на кристалле

После загрузки Verilog-описания можно приступать к размещению элементов или загрузить файл, содержащий размещение элементов, в случае его наличия для текущей схемы. Элементы, имена которых совпадают с названиями имен I/O ячеек будут размещены автоматически. Для загрузки размещения необходимо выбрать «Файл – Загрузить inout-файл» и через обозреватель выбрать файл с расширением «\*.inout.tcl». Аналогичные действия могут быть проделаны для загрузки размещения тасго-блоков и IP-блоков.

Для ручного размещения элементов существует несколько способов:

- Выбрать необходимую ячейку в обозревателе структуры схемы;
- Перетащить элемент на необходимую ячейку с помощью механизма Drag'n'Drop;
- Назначить элемент на ячейку из информационного окна ячейки.

Также можно воспользоваться опцией «Автоматическое размещение I/O» нажав на соответствующую кнопку в панели инструментов или в меню «Редактировать». После нажатия на данную кнопку каждому периферийному элементу будет назначена подходящая по типу ячейка кристалла.

После того, как элементы будут расположены на кристалле, занятые ячейки будут окрашены в оранжевый цвет, а значки в списке элементов поменяют цвет с серого на зеленый (Рисунок 57).

|          |            |        |       |        |       |        |    |     |         |          |        |        |     |   |   |   | <br> |   |   |          |
|----------|------------|--------|-------|--------|-------|--------|----|-----|---------|----------|--------|--------|-----|---|---|---|------|---|---|----------|
| X        | X-plac     | e      |       |        |       |        |    |     |         |          |        |        |     |   |   |   |      | _ |   | $\times$ |
| Фа       | іл Р       | едакти | роват | гь Ви  | ід Кр | оиста. | лл | Pex | ким раб | боты (   | Окно   | Помощ  | ь   |   |   |   |      |   |   |          |
|          |            | E      |       | E      | 2     | 5      | C  | ob  |         | X 🗉      |        | 0      | Ð   | Ø | Ø | 0 |      |   |   |          |
| Стру     | ктура      | схемы  |       |        |       |        |    |     |         |          |        |        | 0 X |   |   |   |      |   |   |          |
| Назе     | ание       |        | Груп  | na I/O | Тип   | I/0    | П  | ин  | Элемен  | нт       |        |        |     |   |   |   |      |   |   |          |
| <b>T</b> | nput (     | 3)     |       |        | ~     |        |    |     |         |          |        |        | _   |   |   |   |      |   |   |          |
|          | $\sim$     | а      | PAD   |        | × xa_ | ib 🔹   | a  | *   | [FROM   | _PAD1    | TO_PA  | D1]    | -   |   |   |   |      | _ | _ | _        |
|          | $\bigcirc$ | b      | PAD   |        | × xa_ | ib 🔹   | a  | *   | [FROM   | PAD2     | TO_PA  | D2]    | -   |   |   |   |      |   |   |          |
|          | Ø          | c      | PAD   |        | × xa_ | ib 🔹   | a  | ٣   |         |          |        |        | -   |   |   |   |      |   |   |          |
| - (      | Output     | (2)    |       |        |       |        |    |     |         |          |        |        |     |   |   |   |      |   |   | _        |
|          |            | sum    | PAD   |        | × xa_ | ob 🔹   | ×  | *   |         |          |        |        | -   |   |   |   |      |   |   |          |
|          | $\sim$     | carry  | PAD   |        | × xa_ | ob 🤻   | ×  | ۳   | [TO_PA  | D204   F | FROM_F | AD204] | -   |   |   |   |      |   |   | _        |
|          |            |        |       |        |       |        |    |     |         |          |        |        |     |   |   |   |      |   |   |          |
|          |            |        |       |        |       |        |    |     |         |          |        |        |     |   |   |   |      |   |   | _        |
|          |            |        |       |        |       |        |    |     |         |          |        |        | :   |   |   |   |      |   |   |          |
|          |            |        |       |        |       |        |    |     |         |          |        |        |     |   |   |   | <br> |   |   | _        |
|          |            |        |       |        |       |        |    |     |         |          |        |        |     |   |   |   |      |   |   |          |
|          |            |        |       |        |       |        |    |     |         |          |        |        |     |   |   |   |      |   |   |          |
|          |            |        |       |        |       |        |    |     |         |          |        |        |     |   |   |   |      |   |   |          |
|          |            |        |       |        |       |        |    |     |         |          |        |        |     |   |   |   |      |   |   | _        |
|          |            |        |       |        |       |        |    |     |         |          |        |        |     |   |   |   |      |   |   |          |
|          |            |        |       |        |       |        |    |     |         |          |        |        |     |   |   |   | <br> |   |   | -        |
|          |            |        |       |        |       |        |    |     |         |          |        |        |     | _ |   |   |      |   |   |          |
|          |            |        |       |        |       |        |    |     |         |          |        |        |     |   |   |   | <br> |   |   |          |
|          |            |        |       |        |       |        |    |     |         |          |        |        |     | _ |   |   |      |   |   |          |
|          |            |        |       |        |       |        |    |     |         |          |        |        |     |   |   |   |      |   |   | -        |
|          |            |        |       |        |       |        |    |     |         |          |        |        |     |   |   |   |      |   |   |          |
| Выво     | д          |        |       |        |       |        |    |     |         |          |        |        |     |   |   |   |      |   |   | ð×       |
| Tcl      | con        | sole   | (Tc   | l ve   | r 8.5 | 5.19   | ); |     |         |          |        |        |     |   |   |   |      |   |   |          |
| One      | nGT.•      | Deb    | naae  | r cr   | eater | 1.     |    |     |         |          |        |        |     |   |   |   |      |   |   |          |
| QTo      | l sh       | e11>   | agge  | 1 01   | casco |        |    |     |         |          |        |        |     |   |   |   |      |   |   |          |
|          |            |        |       |        |       |        |    |     |         |          |        |        |     |   |   |   |      |   |   |          |
|          |            |        |       |        |       |        |    |     |         |          |        |        |     |   |   |   |      |   |   |          |
|          |            |        |       |        |       |        |    |     |         |          |        |        |     |   |   |   |      |   |   |          |
|          |            |        |       |        |       |        |    |     |         |          |        |        |     |   |   |   |      |   |   |          |
|          |            |        |       |        |       |        |    |     |         |          |        |        |     |   |   |   |      |   |   |          |
|          |            |        |       |        |       |        |    |     |         |          |        |        |     |   |   |   |      |   |   |          |
|          |            |        |       |        |       |        |    |     |         |          |        |        |     |   |   |   |      |   |   |          |

Рисунок 57. Окно с некоторым количеством размещенных периферийных элементов

## Сохранение полученного размещения

Для сохранения полученного размещения необходимо выбрать соответствующую опцию в меню «Файл» (рисунок 58). Режим FloorPlanner поддерживает следующие типы файлов:

- «\*.inout.tcl» размещение ячеек ввода/вывода (Рисунок 58-1);
- «\*.macro.tcl» размещение макроблоков (Рисунок 58-2).
- «\*.ip.tcl» размещение IP-блоков (Рисунок 58-3).



Рисунок 58. Функция экспорта размещения всей схемы, ячеек ввода/вывода или макроблоков

## Использование полученного размещения

Для использования полученных файлов размещения необходимо в окне «Настройки запуска» выбрать меню «Размещение элементов», активировать требуемую опцию, изменив значение «Нет» на «Да», и добавить сгенерированный файл в соответствующее поле ввода (Рисунок 59).

| 🐐 Настройки запуска                                             |                                              |               |                 |     |          | Х  |
|-----------------------------------------------------------------|----------------------------------------------|---------------|-----------------|-----|----------|----|
|                                                                 |                                              | Размеш        | цение элементов |     |          |    |
| Логический синтез<br>Общие настройки<br>Кластеризация элементов | Использовать файл размещения IO ячеек        | [-inout] 1    | Да              |     | •        |    |
| Размещение элементов<br>Трассировка межсоединений               | Использовать файл размещения макро-блоков    | [-macro] 2    | Да              |     | •        |    |
| Временной анализ                                                | Использовать файл размещения всех элементов  | [-p]          | Нет             |     | •        |    |
|                                                                 | Использовать файл размещения ір-блоков       | [-ip_place] 3 | Да              |     | •        |    |
|                                                                 | Отключить алгоритм моделирования отжига      | [-sa]         | Нет             |     |          |    |
|                                                                 | Задать множитель циклов моделирования отжига | [-sa_lm]      | Нет             | 300 |          | \$ |
|                                                                 |                                              |               |                 |     |          |    |
| Дополнительные опции запуска                                    |                                              |               |                 |     |          |    |
| xcore.exe                                                       |                                              |               |                 |     |          |    |
| 💿 Значения по умолчанию                                         |                                              |               |                 |     | ОК Отмен | ia |

Рисунок 59. Настройки размещения элементов

# Лист регистрации изменений

| Дата       | Версия | Изменения              |
|------------|--------|------------------------|
| 19.05.2025 | 0.1    | Предварительная версия |
|            |        |                        |
|            |        |                        |
|            |        |                        |
|            |        |                        |
|            |        |                        |
|            |        |                        |
|            |        |                        |
|            |        |                        |
|            |        |                        |
|            |        |                        |
|            |        |                        |
|            |        |                        |
|            |        |                        |
|            |        |                        |
|            |        |                        |
|            |        |                        |
|            |        |                        |
|            |        |                        |
|            |        |                        |
|            |        |                        |
|            |        |                        |
|            |        |                        |
|            |        |                        |
|            |        |                        |
|            |        |                        |
|            |        |                        |
|            |        |                        |
|            |        |                        |
|            |        |                        |
|            |        |                        |
|            |        |                        |
|            |        |                        |
|            |        |                        |
|            |        |                        |
|            |        |                        |
|            |        |                        |
|            |        |                        |
|            |        |                        |
|            |        |                        |
|            |        |                        |