vak: (Улыбка)
[personal profile] vak
Почему-то считается, что асинхронную логику нельзя засунуть в традиционную FPGA. Я решил поисследовать этот вопрос. Чем дольше разбираюсь, тем яснее становится, что это просто предубеждение. Я взял популярную плату Digilent Basys3 на основе чипа Xilinx Virtex-7, и стал смотреть, что тут можно сделать.

Основа асинхронной логики - несколько базовых примитивов: C-элемент, арбитр, S-элемент, T-элемент. Все их удалось реализовать на имеющейся FPGA. Вот, к примеру, как выглядит двухвходовый С-элемент Мюллера:


Это трёхвходовый С-элемент:


Арбитр штука более сложная. К счастью, нынешние чипы FPGA, так называемое семейство Xilinx 7 Series, в качестве базового элемента имеют логическую таблицу LUT6_2 с двумя независимыми выходами. Это даёт возможность построить асинхронный арбитр со стабильными характеристиками:


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


Т-элемент вообще помещается в одну ячейку LUT6_2:

Date: 2016-09-12 07:26 (UTC)
spamsink: (Default)
From: [personal profile] spamsink
Логично. Интересно, что Xilinx-овские тулы говорят о таком бешеном количестве комбинационных циклов.

Date: 2016-09-12 14:01 (UTC)
spamsink: (Default)
From: [personal profile] spamsink
Если LUT equation не зависит от какого-то входа, зачем его вообще заводить? Проще GND к нему присоединить.

Date: 2016-09-12 19:20 (UTC)
spamsink: (Default)
From: [personal profile] spamsink
Похоже, что инстансы с именами примитивов синтезатор вообще не трогает, и константа превращается в ничто. Значит, нужно явно к GND подключать.

Date: 2016-09-12 20:22 (UTC)
spamsink: (Default)
From: [personal profile] spamsink
Выходит, наоборот, если пин не используется, то его вообще отключить надо? В каждой версии у них свои заморочки, бардак какой-то.