# Подсистема анализа самосинхронных схем АСИАН

Ю.В. Рождественский, Н.В. Морозов, Ю.А. Степченков, А.В. Рождественскене

Институт проблем информатики PAH, YRogdest@ipiran.ru

Аннотация — Предмет доклада - анализ асинхронных схем на независимость их поведения от задержек элементов. Такие схемы называются самосинхронными. Схема определяется как совокупность булевых уравнений (логических элементов), удовлетворяющих гипотезе Маллера относительно характера их задержек. Анализ основан на построении диаграмм переходов, покрывающих все возможные состояния схемы, и относится к методам анализа схемы в глобальных состояниях. Главное преимущество этих методов заключается в их универсальности – возможности применения для анализа всех классов самосинхронных схем. Подсистема АСИАН представляет собой комплекс позволивший многократно программ. сократить временные затраты на процедуру анализа по сравнению с существующими аналогами и, по существу, реализовать максимально возможную эффективность анализа.

## **І. В**ВЕДЕНИЕ

Самосинхронные (СС) схемы (self-time circuits) — схемы, поведение которых не зависит от задержек их элементов — имеют ряд преимуществ по сравнению с их синхронными аналогами. Они более надежны, сохраняют работоспособность (устойчивость работы без сбоев) в предельно широких условиях эксплуатации, характеризуются потенциально более высоким быстродействием и рядом других достоинств [1].

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

Система автоматизированного проектирования (САПР) интегральных схем на базе СС-подхода может основываться на стандартной САПР, но при этом должны учитываться некоторые специфические технологии особенности этой [2]. Они прослеживаются на всех этапах, от моделирования и подготовки тестов до изготовления топологии. проектирование упрощается Иногда (тесты, моделирование), в других случаях - несколько усложняется (топология). Однако все эти задачи систем решаются рамках имеющихся в проектирования.

Существуют две программные подсистемы, необходимые для организации проектирования ССсхем и не покрываемые существующими средствами САПР: подсистема проверки наличия нарушений самосинхронности в проектируемой схеме и подсистема синтеза СС-схем. Настоящий доклад посвящен подсистеме анализа логических схем АСИАН 1.0 для подтверждения их самосинхронности.

# II. ТЕОРЕТИЧЕСКИЕ ПРИНЦИПЫ АНАЛИЗА НАРУШЕНИЙ САМОСИНХРОННОСТИ

Существуют методологии проектирования асинхронных схем, которые не всегда обоснованно относят к классу самосинхронных [1]. В табл. 1 представлены основные классы схем, нередко идентифицирующиеся как self-timed.

Таблица 1

# Классификация методологий проектирования

| Название класса                                                        | Пример                                     |  |  |  |
|------------------------------------------------------------------------|--------------------------------------------|--|--|--|
| Квазисамосинхронные методологии                                        |                                            |  |  |  |
| На базе использования локальных генераторов                            | СС-интерфейс S/390 [3]                     |  |  |  |
| Модели с ограниченной<br>задержкой элементов                           | CC-микроконвейеры и схемы<br>Haffman [4]   |  |  |  |
| Объединение СС-модулей с<br>использованием задержек<br>или генераторов | I-net [4]                                  |  |  |  |
| СС-методологии                                                         |                                            |  |  |  |
| Универсальные на базе<br>"глобальных моделей"                          | ДП (ТРАНАЛ) [5]<br>ДР сетей Петри [4]      |  |  |  |
| Дистрибутивные схемы<br>(ДС)                                           | STG (сети Петри) [4],<br>ДИ (ТРАСПЕКТ) [5] |  |  |  |
| Расширенные ДС<br>Комбинационные схемы                                 | STG/IC [4]<br>CAMAH [2]                    |  |  |  |

В качестве примера в первых трех строчках приведены методологии, базирующиеся на моделях с ограниченной задержкой. Подобно синхронным схемам, они вынуждены ориентироваться на худший случай срабатывания элементов (правда, не глобально, во всей схеме, а локально, в отдельных ее частях), т.е. не являются схемами, полностью независимыми от задержек элементов. Такие решения схемотехнические будем называть квазисамосинхронными (КСС). Согласованная работа отдельных частей КСС обеспечивается за счет использования линий задержек или локальных генераторов. Проектирование таких схем полностью покрывается традиционными средствами САПР.

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

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

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

Один из способов сокращения размера описания учет специфики исследуемой схемы и использование модельного представления, эффективного именно для данного класса схем. Очень часто в практике реального проектирования встречаются схемы, обладающие однозначностью предыстории каждого переключения – так называемые дистрибутивные схемы (ДС) [5]. Этому классу схем соответствует подкласс диаграмм изменений (ДИ) – сигнальные графы (СГ), в которых все вершины – изменения имеют тип "И" а вершины типа "ИЛИ" отсутствуют. В сетях Петри используется другой подкласс ДИ – графы сигнальных переходов (Signal Transition Graphs, STG) [4], которые имеют определенные ограничения по сравнению с СГ: они не могут специфицировать поведение любой ДС. И СГ, и STG относятся к "событийным моделям", алгоритмы анализа которых существенно проще. Если сложность алгоритма анализа ДП находится в экспоненциальной зависимости от степени параллельности всей схемы, то для ДИ – зависит от степени параллельности одного события (элемента). Для схем с высоким параллелизмом количество параллельных изменений на входе одного элемента существенно меньше параллелизма всей схемы. Этим и объясняется высокая эффективность событийных моделей по сравнению с моделями в глобальных состояниях.

Для анализа чисто комбинационных схем эффективно использование функционального подхода [2]. Схемотехнические решения БИС БМК

"Микроядра" не относятся ни к классу дистрибутивных, ни к классу комбинационных схем. Поэтому было принято решение разработать подсистему анализа СС-схем АСИАН на базе универсального подхода.

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

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

Следовательно, задержка цепи приводится к выходу элемента, и разброс задержек в ветвлениях цепи меньше времени срабатывания вентиля. В принципе в широком классе применений такая гипотеза справедлива. Для того, чтобы гипотеза Маллера была справедлива и для схем субмикронного диапазона, необходимо использовать дополнительные топологические И логические приемы [6]. контроля соединений Возможность трасс в технологии БМК позволяет обеспечить правильную работу СС-схем независимо от задержек соединительных проводов после разветвления.

По Маллеру схемой называется совокупность логических элементов  $\{Z_1, ..., Z_n\}$ , где каждый вход логического элемента присоединен к одному выходу, и никакие два выхода не соединены между собой. Состояние схемы в каждый момент представляет собой набор значений сигналов в ее узлах – выходах двоичных логических элементов. Входы схемы также можно считать логическими элементами без входов – генераторами нулей или единиц.

Состояние выхода элемента определяется значениями сигналов на его входах. Поведение i-того элемента схемы можно описать булевым уравнением:

$$Z'_{i} = Fi (Z_{1}, ..., Z_{i}, ..., Z_{n}),$$

где  $Z_1$ , ...  $Z_{i-1}$ ,  $Z_{i+1}$ ,.... $Z_n$  – значения сигналов во входных узлах i-того элемента в момент времени t;  $Z_i$  – значение выхода i-того элемента в момент времени t;  $Z'_I$  – значение, которое должен принять выход i в следующий момент времени t'; Fi – собственная функция i-того элемента.

Для схемы, состоящей из п элементов, моделью Маллера называется система из п уравнений вида Z'<sub>i</sub>, i= 1,...n. В качестве примера на рис. 1 приведена схема индикатора окончания переходных процессов для трех сигналов – так называемого гистерезисного триггера (одного из наиболее распространенных элементов в СС-схемотехнике).

Функциональная схема



 имитация внешней среды
отсутствие связи приводит к нарушению самосинхронности
знак инверсии

Входное описание (модель Маллера):

D1=^D5; D2=^D5; D3=^D5; D4=^D1\*D2\*D3+D5(D1+D2+D3); D5=^D4; \$D1\*D2\*D3\*D4^\*D5

Рис. 1. Гистерезисный тригтер на три входа

Функционирование схемы описывается процедурой ее перехода из одного состояния в другое. Наглядная отображения функционирования схемы, форма заданной моделью Маллера ee ДП, ориентированный граф, вершины которого соответствуют состояниям схемы. Два последовательных состояния схемы ДΠ на соединяются дугой, а возбужденные переменные помечаются звездочками (см. рис. 2).

Критерий нарушения самосинхронности в этом случае – появление ситуации, когда одновременные переключения входов какого-либо элемента схемы вызывают противоположные по знаку переключения выхода (режим "гонок") – см. рис. 3.

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

Полнота покрытия всех состояний достигается имитацией синхронного протокола взаимодействия с внешней средой путем "замыкания" выходного индикатора окончания переключений на входные цепи разрешения приема данных или фазы гашения.



## Рис. 2. Диаграмма переходов

АНАЛИЗ ЗАВЕРШЕН 08.05.2006 в 18.50.59 за 0.00.000 Проанализировано состояний: 26, слоев: 14 Схема полумодулярна Параметры схемы: прошли раб.циклов - 1

В рабочем цикле: состояний - 18, слоев - 10 Ширина слоя в раб. цикле: мин. - 0, макс. - 0

#### а) Результат анализа: схема самосинхронна

АНАЛИЗ ЗАВЕРШЕН 08.05.2006 в 18.48.59 за 0.00.00.00 Проанализировано состояний: 9, слоев: 4 Полумодулярность нарушается в состоянии 001\*11\* 00111 2: 2 4 > конфликтное состояние: 1. D1 = 0 2. D2 = 0 3. D3 = 1\* 4. D4 = 1 5. D5 = 1\* Переменная, вызвавшая конфликт: D5 Переменные, с которых снимается возбуждение: D3

б) Результат анализа: нарушение самосинхронности

#### Рис. 3. Результат анализа подсистемы ТРАНАЛ

### III. Анализ существующих подсистем

Из сказанного видны сильные и слабые стороны такого алгоритмического подхода к проверке нарушений самосинхронности:

– в качестве средства анализа используется определение понятия нарушения самосинхронности,

что делает алгоритм теоретически завершенным, фундаментальным;

процессе работы просматриваются — B все временные состояния схемы без учета величины конечных задержек, что гарантирует полноту анализа; – главный недостаток экспоненциальная зависимость числа просматриваемых состояний от параллельных процессов; одновременно числа идущих в схеме; при этом фактически включается полный перебор состояний с показателем 2N, где N максимальная степень параллельности схемы.

Прототипом для подсистемы АСИАН была программа TRANAL в составе САПР СС-схем FORSAGE [7]. Разработанная в начале 90-х годов, эта программа была ориентирована на максимальное использование вычислительных ресурсов ПЭВМ того времени, однако реально обеспечивала решение задач, содержащих не более 5÷6 одновременных степень параллельных процессов (CП параллельности). Это обусловило сильную ограниченность ее использования, в основном – для анализа библиотечных элементов базовых матричных Кроме того, работа c низкой кристаллов. параллельностью не позволила ee авторам обнаружить одну функциональную ошибку в цикле проверок нарушения самосинхронности. Для некоторого класса схем эта программа не обнаруживает существующих нарушений самосинхронности.

реального CC-Работы по созданию микропроцессора потребовали максимально расширить возможности программных средств для самосинхронности схемных проверки решений различных узлов И блоков микропроцессора. Первоначально была разработана подсистема анализа БТРАН, позволившая увеличить СП анализируемой схемы до 16 [8]. В рамках подсистемы АСИАН максимально возможная СП была увеличена до 24.

Вторая проблема, требовавшая решения в связи с ростом сложности схем, заключалась в трудности понимания причин нарушения самосинхронности в терминах и представлениях аппарата ДП. Требовалась мощная диагностическая система, наглядно демонстрирующая разработчику причину и предысторию процессов, приведших к нарушению самосинхронности.

Эти задачи должна была решать новая подсистема проверки нарушений самосинхронности АСИАН.

# IV. АЛГОРИТМЫ РАБОТЫ АСИАН

Анализ алгоритма ТРАНАЛ показал, что основные затраты процессорного времени и памяти уходят на

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

Для организации упорядоченного поиска вся доступная оперативная память ПЭВМ разбивается на  $2^{N}$  кластеров с помощью специально рассчитываемой хэш-функции по текущим состояниям схемы. Это позволяет сократить время доступа к конкретному состоянию до  $\sim 2^{N}$  раз. Существующая версия АСИАН обеспечивает сейчас анализ схем с разбиением на кластеры до N=24.

В ряде случаев доступной оперативной памяти оказывается мало, и АСИАН позволяет организовать постраничное хранение массива данных слоя состояний на жестком диске, сохраняя при этом высокую эффективность доступа ко всем состояниям слоя с помощью хеш-функции страничной организации на 2<sup>к</sup> страницах. Параметр К может достигать величины 4.

Для исправления существующих ошибок был переработан весь цикл основных проверок TRANAL с целью ускорения счета и обеспечения эффективной работы с памятью ПЭВМ.

Сравнительная оценка подсистем TRANAL, БТРАН и АСИАН приведена в таблице 2.

# V. ДИАГНОСТИЧЕСКАЯ ЧАСТЬ ПОДСИСТЕМЫ АСИАН

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

В АСИАН диагностика нарушений выполняется в графа переключений элементов схемы с виле использованием графических средств Windows. Это делает наглядным весь процесс зарождения "гонок" в динамике и позволяет определять первопричину, а не только констатировать нарушения самосинхронности, которые могут произойти значительно позднее. Такая диагностическая среда естественна для разработчиков обучения схемы, не требует специального И быстро изменения позволяет вносить в схемотехническое решение тестируемого узла.

Таблица 2

| Сравнение | подсистем | анализа |
|-----------|-----------|---------|
|-----------|-----------|---------|

| Подсистема<br>анализа | СП схем | Уровень тестируемых схем                     | Объем памяти<br>(max) под один слой<br>состояний | Количество<br>анализируемых<br>состояний в час | Операционная<br>система |
|-----------------------|---------|----------------------------------------------|--------------------------------------------------|------------------------------------------------|-------------------------|
| TRANAL                | 5 ÷ 6   | Библиотечные элементы БМК                    | 640 Кбит                                         | 200-300 тыс.                                   | DOS                     |
| БТРАН                 | 12-16   | БЭ, макроэлементы и<br>функциональные модули | 2 Гбайт                                          | 700-1000 тыс.                                  | Windows 2000            |
| АСИАН                 | 18 ÷ 24 | Функциональные узлы и блоки                  | ~48 Гбайт (под<br>Windows XP)                    | 5-100 млн                                      | Windows 2000/XP         |

На рис. 4 и 5 приведены диаграммы изменений для корректной (СС-) схемы Г-триггера и варианта реализации с нарушением самосинхронности (окончание переходного процесса — формирование низкого уровня на выходе элемента D3 не отслеживается). Сопоставление рис. 3,6 и рис. 5 делает наглядной диагностику в подсистеме АСИАН.



Рис. 4. Диаграмма изменений СС-схемы



Рис. 5. Диаграмма изменений несамосинхронной схемы

## VI. Выводы

1. Разработана подсистема анализа нарушений самосинхронности АСИАН, позволяющая практически приступить к проектированию блоков и узлов СС-схем.

2. Исправлены ошибки программы анализа самосинхронности TRANAL.

Работа выполнена при финансовой поддержке по Государственному контракту № 1.4/03 (регистрация РАН: № 10002-251/ОИТВС-04/103-098/260503-201).

## Литература

- [1] Степченков Ю.А., Петрухин В.С., Дьяченко Ю.Г. Опыт разработки самосинхронного ядра микроконтроллера на базовом матричном кристалле // Сборник научных трудов под общ, ред. А.Л. Стемпковского "Проблемы разработки перспективных микроэлектронных систем – 2005". – М.: ИППМ РАН, 2005. – С. 235–242.
- [2] Плеханов Л.П. САПР строго самосинхронных электронных схем РОНИС // В настоящем сборнике.
- J.M. Nick, B.B. Moore, et al. S/390 Cluster Technology: Parallel Sysplex // IBM Systems Journal. – 1997. - V. 36. -№ 2. - C. 172-201.
- [4] S. Hauck. Asynchronous design methodologies: An overview // Proceedings of the IEEE. January 1995. V. 83. № 1. C. 69-93.
- [5] Varshavsky V., Kishinevsky M., Marakhovsky V. et al. Self-timed Control of Concurrent Processes. - Kluver Academic Publishers, 1990. – 245 p.
- [6] Степченков Ю.А., Денисов А.Н., Дьяченко Ю.Г., Гринфельд Ф.И. и др. Библиотека элементов базовых матричных кристаллов для критических областей применения // Сб.: Системы и средства информатики. – М.: Наука, 2004. - Вып. 14. - С. 318-361.
- [7] Варшавский В.И., Карпов С.А., Кондратьев А.Ю., Степченков Ю.А.. и др. Инструментальные средства автоматизации проектирования самосинхронных схем. // Сборник "Системы и средства информатики". - М.: Наука, 1993. - Вып. 5. - С. 196-213.
- [8] Морозов Н.В., Рождественский Ю.В. Средство анализа системы булевых уравнений на полумодулярность и дистрибутивность // Свидетельство об официальной регистрации программы для ЭВМ № 2001610157 от 02.2001.