УДК 681.32

# ОСОБЕННОСТИ МАЖОРИТИРОВАНИЯ В ПЛИС VIRTEX ФИРМЫ XILINX

# О. В. Гончаровский, С. Ф. Тюрин

Пермский национальный исследовательский политехнический университет

#### Поступила в редакцию 27.12.2016 г.

Аннотация. Анализируется способ тройного резервирования (TMR) с мажоритарным элементом из буферов с тремя состояниями, применяемый при создании проектов на программируемой логике типа FPGA для уменьшения радиационно-индуцированных переключений логических элементов (SET) и элементов памяти (SEU). Обсуждаются результаты моделирования таких мажоритарных элементов на уровне транзисторов и на логическом уровне. Предложен способ моделирования на логическом уровне мажоритарных элементов из буферов с тремя состояниями, позволяющий избежать неадекватных неопределенных состояний в процессе анализа проекта, созданного на VHDL. Ключевые слова: ПЛИС типа FPGA, мажоритирование, мажоритар, тристабильный буфер. Annotation. Analyzed Triple Module Redundancy Design Techniques with the majority element of the three-state buffers used when creating projects for the programmable logic Xilinx FPGAs Virtex type to reduce radiation-induced switching of logic elements (Single Event Transients-SET) and memory elements (Single Event Upset -SEU). Evaluated the results of the simulation of the majority elements on the transistor level and at a logical level. The paper proposed a method of modeling at the logical level of majority elements of the tri-state buffers, avoiding inappropriate undefined states in the process of analysis of the project, created in VHDL. Keywords: FPGA, Triple Module Redundancy, Majority Vote Circuit, 3-State Buffer.

#### 1. ВВЕДЕНИЕ

Научно-технологическое направление создания высоконадёжных, отказоустойчивых, радиационно-стойких микросхем для космических, специальных и военных применений в настоящее время чрезвычайно актуально. Радиационная стойкость - это свойство аппаратуры, комплектующих элементов и материалов выполнять свои функции и сохранять параметры в пределах установленных норм во время или после ионизирующего излучения [1]. Считается, что негативное воздействие тяжёлых заряженных частиц (ТЗЧ) на микросхемы цифровой аппаратуры систем управления привело к потере космического аппарата «Фобос-Грунт» [2]. Процессы накопления дозы радиации в микросхемах приводят к росту задержек внутри микросхемы, изменению логических уровней. Попадание одной единственной частицы приводит к так называемым одиночным событиям SEE (Single Event Effect) [3, 4]. Основные понятия в области радиационной стойкости представлены на рис. 1.

Одним из самых опасных подвидов SEE является защелкивание транзисторов (Single Effect Latchup, SEL) в пропускающем состоянии (тиристорный эффект). При этом возможны разрушения транзисторов и «разрыв» вентиля – SEGR (Single Event Gate Rupture). При воздействии ТЗЧ могут происходить кратковременные изменения выхода логического элемента – SET (Single Event Transient), элементов памяти – SEU (Single Event Upset), изменяющие состояние логических элементов [3, 4]. Лидером создания радиационно-стойких микросхем за рубежом является компания Atmel [3, 4]. Для создания радиационно стойких микросхем применяют доргостоящие технологии, например, «кремний на диэлектрике» (англ. Silicon-on-insulator, SOI), исключающие тиристорные эффекты. Хорошо зарекомендовала себя технология КНС –

<sup>©</sup> Гончаровский О. В., Тюрин С. Ф., 2017

| Nº | Термин | Расшифровка<br>англ.                       | Расшифровка<br>рус.                               | Определение                                                                                                                                                                                                                                                                                                                              |
|----|--------|--------------------------------------------|---------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1. | SEL    | Single<br>Event<br>Latch                   | Тиристорный<br>эффект,<br>вызванный<br>ионизацией | Переход микросхемы в состояние с высо-<br>ким потреблением тока. Требуется обяза-<br>тельное снятие питания для восстановле-<br>ния                                                                                                                                                                                                      |
| 2. | SEGR   | Single<br>Event<br>Gate Rupture            | «Разрыв»<br>вентиля,<br>вызванный<br>ионизацией   | Неисправность затвора или подзатворной<br>области в результате перехода транзистора<br>в состояние высокого потребления тока,<br>обусловленного тиристорным эффектом                                                                                                                                                                     |
| 3. | SET    | Single<br>Event<br>Transient               | Однократный<br>восстанавливаемый<br>отказ         | Кратковременное изменение состояния<br>логического выхода                                                                                                                                                                                                                                                                                |
| 4. | SEU    | Single<br>Event<br>Upset                   | Однократный<br>восстанавливаемый<br>сбой памяти   | Обратимое изменение состояния регистра<br>памяти, ОЗУ или триггера                                                                                                                                                                                                                                                                       |
| 5. | SHE    | Single<br>Event<br>Hard<br>Error           | Необратимое<br>изменение<br>состояния<br>регистра | Необратимое изменение состояния реги-<br>стра памяти, ОЗУ или триггера                                                                                                                                                                                                                                                                   |
| 6. | SEFI   | Single<br>Event<br>Functional<br>Interrupt | Функциональный<br>отказ<br>в результате SEU       | Отказ в работе прибора. Как правило, для<br>устранения этого отказа требуется либо<br>снятие и восстановление питания, либо<br>перегрузка системы                                                                                                                                                                                        |
| 7. | RH     | Radiation<br>Hard                          | Устойчивый<br>к радиации                          | Устройство, гарантированно сохраняю-<br>щее работоспособность при дозе погло-<br>щенного излучения вплоть до заданной<br>(обычно более 300 крад).                                                                                                                                                                                        |
| 8. | RT     | Radiation<br>Tolerant                      | Выдерживающий<br>(толерантный)<br>радиацию        | Устройство, гарантированно сохраняю-<br>щее работоспособность при дозе погло-<br>щенного излучения вплоть до заданной<br>(обычно более 300 крад.)                                                                                                                                                                                        |
| 9. | RHBD   | Radiation<br>Hardened<br>By<br>Design      | Устойчивый<br>к радиации<br>за счет дизайна       | Устройство, в котором для увеличения<br>радиационной стойкости применяются<br>специальные схемные/технологические ре-<br>шения, например, троирование триггеров<br>со схемой восстановления после ошибок,<br>применение RC-фильтров для устойчиво-<br>сти к импульсам тока, постоянный опрос<br>конфигурации с восстановление ее и т. д. |

# О. В. Гончаровский, С. Ф. Тюрин

Рис. 1. Основные понятия радиационной стойкости

кремний на сапфире. Применяют отключение питания на период воздействия ТЗЧ, помехоустойчивые коды, используют сохранение нескольких состояний шины данных с некоторым интервалом и последующее голосование «по большинству голосов», например, «два из трёх», «три из пяти». Методы обеспечения радиационной отказоустойчивости – RHBD (Radiation Hardened By Design) включают парирования SEU ячеек статической опера-



*Рис. 2. Тристабильный буфер (3-state buffers, BUFT) на основе инвертора. Разрешение E1 = 0 (активно). а) Передача D1 = 1; б) передача D1 = 0* 



Рис. 3. Тристабильный буфер (3-state buffers, BUFT) на основе инвертора. Разрешение E1 = 1 (неактивно). а) Попытка передачи D1 = 1; б) попытка передачи D1 = 0

тивной памяти SRAM путем особого дублирования – DICE (Dual Inter\_locked Storage) [3, 4]. Для парирования отказов используют тройное резервирование (Triple Modular Redundancy, TMR) или мажоритирование (функция голосования V= AB + AC + BC, где A, B, C – три канала, «+» логическая операция дизъюнкции) [3, 4]. Такое резервирование используется в программируемых логических интегральных схемах (ПЛИС) типа FPGA [5] (field-programmable gate array) серии VirtexTM фирмы Xilinx [6–8]. Вызывает интерес анализ особенностей мажоритирования, применяемого в этой серии.

# 2. ТРИСТАБИЛЬНЫЕ БУФЕРЫ

Вычисление мажоритарной функции по выходам трёх каналов с раздельным питанием A, B, C в ПЛИС типа FPGA (field-programmable gate array) может выполняться в так называемых LUT (Look Up Table), которые представляют собой ПЗУ на основе мультиплексора, входы данных которого и фиксируют заданную логическую функцию [5]. В архитектуре VirtexTM фирмы Xilinx [6] описано использование для этих целей внутренних тристабильных буферов (3-state buffers, BUFT). Рассмотрим модель тристабильного буфера в системе схемотехнического моделирования National Instruments Electronics Workbench Group [9] – рис. 2, 3.

Таким образом, на рис. 3 показана реализация третьего состояния (высокоимпедансного состояния) на выходе буфера. Модель второго типа тристабильного буфера на основе передающих транзисторов в системе схемотехнического моделирования National Instruments Electronics Workbench Group [9] представлена на рис. 4.

Таким образом, на рис. 5 показана реализация третьего состояния (высокоимпедансного состояния) на выходе буфера, построенного на основе передающих транзисторов. О. В. Гончаровский, С. Ф. Тюрин



Рис. 4. Тристабильный буфер на основе передающих транзисторов. Разрешение E1 = 1 (активно). а) Передача D1 = 1; б) передача D1 = 0



Рис. 5. Тристабильный буфер на основе передающих транзисторов. Разрешение E1 = 0 (неактивно). а) Попытка передачи D1 = 1; б) попытка передачи D1 = 0

# 3. МАЖОРИТИРОВАНИЕ НА ОСНОВЕ ТРИСТАБИЛЬНЫХ БУФЕРОВ

Итак, согласно [6] мажоритирование (Triple Module Redundancy-TMR), реализуется следующей схемой на основе тристабильных буферов – рис. 6.



Схема рис. 6. предполагает монтажное «И» с использованием нагрузочного резистора (типа Pullup). Модель мажоритарного устройства на основе тристабильных буферов в системе схемотехнического моделирования National Instruments Electronics Workbench Group [9] представлена на рис. 7, 8.

Таким образом, мажоритарная функция на выходе схемы рис. 7 не реализуется. Однако, в [6] указано, что в ПЛИС Virtex используется так называемая логика горизонтальной шины (Virtex Horizontal Bus Logic) – рис. 8.

Таким образом реализуется мажоритарная функция в виде: AB + AC + BC = (A + B)(A + C)(B + C). То есть выполнено преобразование с использованием дистрибутивного закона. Четвертый буфер с четвертого конфигурируемого логического блока не используется. Соответствующая схема в системе схемотехнического моделирования National

Особенности мажоритирования в ПЛИС VIRTEX фирмы XILINX



*Рис. 7. Мажоритарный элемент на основе тристабильных буферов. а) На наборе 000 на выходе 0; б) На наборе 100 на выходе 1* 



Рис. 8. Логика горизонтальной шины (Virtex Horizontal Bus Logic). а) Схема подключения буферов на выходе конфигурируемых логических блоков к горизонтальным шинам; б) эквивалентная схема мажоритарного устройства, T- сигнал управления третьим состоянием, I-информационный сигнал

Instruments Electronics Workbench Group [9] представлена на рис. 9.

Таким образом, мажоритарная функция на выходе схемы Рис.96, имеющей элементы И, реализуется. Модель схемы рис. 6 с резистором pullups на языке VHDL имеет вид табл. 1.

Результаты моделирования в САПР ActivHDL подтверждают реализацию мажоритарной функции при условии (o<='1' when i='Z' else '0'when i='X' else i) и представлены на рис. 10.

Однако аппаратная реализация схемы рис. 10, обеспечивающая условие (o<='1' when i='Z' else '0'when i='X' else i) скрыта от пользователя. Возможное соответствие элементов схемы рис. 6 и рис. 8 показано на рис. 11.

О. В. Гончаровский, С. Ф. Тюрин



Рис. 9. Мажоритарный элемент на основе тристабильных буферов. а) На наборе 101 дизъюнкция А + В = 1; б) На наборе 010 на выходе 0

library IEEE;

use IEEE.STD\_LOGIC\_1164.all;

| Подключение библиотеки IEEE                                                                                                                                    |  |  |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Подключение пакета IEEE.STD_LOGIC_1164.<br>all с описанием типа STD_LOGIC (стандарт<br>1164), где имеются буферы и резисторы pullups                           |  |  |  |
| Раздел описания связей устройства pullups с<br>внешним миром (порты ввода-вывода: их на-<br>правленность, тип) – интерфейс<br>i -вход буфера<br>о-выход буфера |  |  |  |
| Раздел описания (архитектура) функциониро-                                                                                                                     |  |  |  |

Таблица 1

|                                                                                  | 1164), где имеются буферы и резисторы pullups                                                                                                                                                                       |
|----------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| entity pullups is<br>port (i : in STD_LOGIC; o : out STD_LOGIC);<br>end pullups; | Раздел описания связей устройства pullups с<br>внешним миром (порты ввода-вывода: их на-<br>правленность, тип) – интерфейс<br>i -вход буфера                                                                        |
|                                                                                  | о-выход буфера                                                                                                                                                                                                      |
| architecture pullups of pullups is begin                                         | Раздел описания (архитектура) функциониро-<br>вания, состоящий из одного условного парал-<br>лельного оператора присваивания значения<br>сигналу <= when else                                                       |
|                                                                                  | Выходу о присваивается (символ присвоения <=) значение 1 если значение входа і равно Z (плавающий потенциал с учетом подтяжки потенциал смещается к 1),                                                             |
| o<='1' when i='Z' else '0'when i='X' else i;                                     | иначе присваивается 0 если значение входа<br>i равно X (неопределённое состояние, когда<br>проводит один верхний и один нижний тран-<br>зисторы, конфликт сигналов),<br>иначе выхолу присваивается значение входа i |
| end pullups.                                                                     | Конец описания                                                                                                                                                                                                      |
| cita puttupo,                                                                    | Roney onneumn                                                                                                                                                                                                       |



Рис. 10. Моделирование мажоритарного элемента рис. 6 на основе тристабильных буферов с настраиваемым резистором pullups в САПР ActivHDL, t-управляющий сигнал



Рис. 11. Соответствие элементов схемы рис. 6 и рис. 8

# 4. МАЖОРИТИРОВАНИЕ НА ОСНОВЕ ТРИСТАБИЛЬНЫХ БУФЕРОВ С ИСПОЛЬЗОВАНИЕМ ФУНКЦИИ «МИНОРИТИ»

Отсутствие конфликтов сигналов (Х в модели на языке VHDL) на выходах буферов согласно [6] реализуется с использованием так



Рис. 12. Функция «минорити» (Minority Voted) а) схема реализации; б) таблица истинности

называемой функции минорити (голосование по меньшинству голосов, миноритарная функция, Minority) – рис. 12.

Реализация мажоритирования с использованием LUT-«минорити» (Minority Voted) для выдачи мажоритированного сигнала на выходы ПЛИС показана на рис. 13, 14.

Соединение буферных схем, например, изображённых на рис. 2, подтверждает возможность указанного на рис. 13, 14 соединение буферов без резистора – рис. 15.

### выводы

Таким образом, в ПЛИС Virtex фирмы Xilinx при реализации троирования (Triple Module Redundancy – TMR) с целью повышения радиационной стойкости используются встроенные схемы выбора «2 из 3-х» или мажоритирования (голосования по большинству голосов - Majority Voter Circuit). При этом мажоритарная функция может быть реализована на основе внутренних буферных элементов с тремя состояниями на выходе, отсутствующих в ПЛИС других производителей. Однако, моделирование такого мажоритара, использующего соединение выходов буферов с нагрузочным резистором (типа pullup), в системе в системе схемотехнического моделирования National Instruments Electronics Workbench Group показало, что такая схема неработоспособна в связи с конфликтом сигналов на выходах буферов. Тем не менее, производитель утверждает, что при использовании логики горизонтальной шины (Virtex Horizontal Bus Logic) конфликты исключены. Моделирование эквивалентной схемы, приведённой в [6] с помощью системы схемотехни-



Рис.13. Реализация мажоритирования с использованием схем «минорити» (Minority Voted) на наборах 000,001, 010,011



*Рис.* 14. Реализация мажоритирования с использованием схем «минорити» (Minority Voted) на наборах 100,101, 110,111

ческого моделирования National Instruments Electronics Workbench Group, а также в САПР ActivHDL подтвердило такую возможность, однако, конкретное схемное решение установить не удалось, вероятно производитель намеренно его не раскрывает. В то же время, указывается, что подобные буферные мажоритары обладают низким быстродействием, лучшие временные характеристики у стандартных логических элементов LUT. Вместе с тем, для выдачи мажоритированного сигнала на контакты ПЛИС без соответствующих бу-

#### Особенности мажоритирования в ПЛИС VIRTEX фирмы XILINX



Рис. 15. Реализация соединения буферных элементов по выходу без использования резистора

ферных элементов не обойтись. В этом случае в Virtex используется функция «минорити». При минорити, реализованных в трёх LUT, единичный сигнал формируется только в случае отличия данного входа от двух других, что обеспечивает на выходе буферов, не находящихся в третьем состоянии, всегда 0 или 1 без «смешения» и без использования резистора, то есть конфликты исключены. Моделирование такой схемы подтвердило её работоспособность.

# СПИСОК ЛИТЕРАТУРЫ

1. ГОСТ 18298-79. Стойкость аппаратуры, комплектующих элементов и материалов радиационная. Термины и определения. – URL: http://www.internet-law.ru/gosts/gost/4457/ (дата обращения 30.06.2016)

2. Основные положения Заключения Межведомственной комиссии по анализу причин нештатной ситуации, возникшей в процессе проведения летных испытаний космического аппарата «Фобос-Грунт». – URL: http:// www.federalspace.ru/18126/ (дата обращения 30.06.2016)

3. Donald C. Mayer, Ronald C. Lacoe. Designing Integrated Circuits to Withstand Space Radiation. Vol.4, № 2, Crosslink. – URL: http://www.aero. org/publications/crosslink/summer2003/06.html (дата обращения 20.10.2013) 4. Юдинцев В. Радиационно-стойкие интегральные схемы. Надёжность в космосе и на земле // Электроника: Наука, Технология, Бизнес: журнал. – 2007. – № 5. – С. 72–77. – URL: http://www.electronics.ru/files/article\_pdf/ 0/article\_592\_363.pdf

5. Строгонов А., Цыбин С. Программируемая коммутация ПЛИС: взгляд изнутри. – Режим доступа: http://www.kit-e.ru/ articles/plis/2010\_11\_56.php (дата обращения 16.12.2014)

6. *Carl Carmichael*. Triple Module Redundancy Design Techniques for Virtex FPGAs. – URL: https:// www.xilinx.com/support/documentation/ application\_notes/xapp197.pdf (дата обращения: 07.12.2016).

7. Xilinx Reduces Risk and Increases Efficiency for IEC61508 and ISO26262 Certified Safety Applications. WP461 (v1.0) April 9, 2015. – URL: http://www.xilinx.com/support/documentation/ white\_papers/wp461-functional-safety.pdf (дата обращения: 20.12.2016).

8. QPro Virtex-II 1.5V Platform FPGAs. DS122 (v3.0) April 7, 2014. – URL: http://www. xilinx.com/support/documentation/data\_sheets/ ds122.pdf (дата обращения: 20.12.2016).

9. Сайт разработчика National Instruments. – URL: // http://www.ni.com/multisim/ (дата обращения: 22.12.2016). Гончаровский Олег Владленович – доцент кафедры автоматики и телемеханики, канд. техн. наук, доцент, электротехнический факультет, Пермский национальный исследовательский политехнический университет. E-mail: 35911953@mail

Тюрин Сергей Феофентович – заслуженный изобретатель Российской Федерации, д-р техн. наук, профессор кафедры автоматики и телемеханики, электротехнический факультет, Пермский национальный исследовательский политехнический университет. Е-mail: tyurinsergfeo@yandex.ru

**Goncharovskij Oleg Vladlenovich** – Associate Professor, Ph.D., Associate Professor at the Department of Automation and Telemechanics, Electrical Engineering Faculty, Perm National Research Polytechnic University. E-mail: 35911953@mail

**Tyurin Sergey Feofentovich** – Honored Inventor of the Russian Federation, Doctor of Technical Sciences, Professor at the Department of Automation and Telemechanics, Electrical Engineering Faculty, Perm National Research Polytechnic University.

E-mail: tyurinsergfeo@yandex.ru