Кодирование шины - Bus encoding

Кодирование шины относится к преобразованию / кодированию части данных в другую форму перед запуском на автобус. Хотя кодирование шины может использоваться для различных целей, таких как уменьшение количества выводов, сжатие передаваемых данных, уменьшение перекрестных помех между битовыми линиями и т. Д., Это один из популярных методов, используемых при проектировании системы для снижения динамической мощности. потребляется системная шина.[1][2] Кодирование шины направлено на уменьшение Расстояние Хэмминга между 2 последовательными значениями на шине. Поскольку активность прямо пропорциональна Расстояние Хэмминга, кодирование шины оказалось эффективным для снижения общего коэффициента активности, тем самым уменьшая динамическое энергопотребление в системе.

В контексте этой статьи система может относиться ко всему, где данные передаются от одного элемента к другому по шине (т. Е. Система на чипе (SoC), компьютерная система, Встроенная система на борту и т. д.).

Мотивация

Энергопотребление в электронных системах сегодня вызывает озабоченность по следующим причинам:

  1. Устройства с батарейным питанием: Из-за повсеместного распространения устройств с батарейным питанием и необходимости максимизировать продолжительность между двумя последовательными зарядками батареи, необходимо, чтобы система потребляла как можно меньше мощности (и энергии).
  2. Экологические ограничения: В попытке защитить окружающую среду нам необходимо экономить полезную энергию. Поскольку энергия, потребляемая электронными системами, резко возрастает, минимизация потребления энергии электронными системами имеет решающее значение для сохранения окружающей среды.
  3. Рассеяние мощности: В соответствии с Закон Мура, полупроводниковые устройства упаковывают все больше и больше транзисторов в меньшую площадь. Это приводит к увеличению рассеиваемой мощности на единицу площади и делает проектирование упаковки и системы термического охлаждения сложным и дорогостоящим. Следовательно, для решения этой проблемы необходимы электронные системы малой мощности.

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

Следовательно, кодирование шины важно для проектирования любой электронной системы.[нужна цитата ]

Примеры кодирования шины для достижения низкого энергопотребления

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

  1. Серая кодировка:[3] Адресные линии шины в большинстве вычислительных систем увеличивают последовательные числовые значения из-за пространственная местность. Если мы используем обычное двоичное кодирование для шины, мы не уверены в минимальном расстоянии Хэмминга между двумя последовательными адресами. Использование кодов Грея для кодирования адресных строк приведет к расстоянию Хэмминга 1 между любыми двумя последовательными значениями адресной шины (пока сохраняется пространственная локальность). Существуют варианты этой схемы, называемые кодированием смещенного серого, чтобы уменьшить накладные расходы на задержку.[4]
  2. Последовательная адресация или коды T0:[5] В случае адресной шины из-за пространственной локальности, которая существует в программах, большинство переходов связано с изменением адреса на следующее последовательное значение. Возможная схема кодирования заключается в использовании дополнительной строки INC на шине, указывающей, является ли текущий переход адресом следующего приращения или нет. Если это не последовательный адрес, то получатель может использовать значение на шине. Но если это последовательный адрес, передатчику не нужно изменять значение на шине, а просто установить строку INC равной 1. В таком случае для схемы непрерывной адресации на шине нет никакого перехода, ведущего к коэффициент активности автобуса 0.
  3. Представление числа: Рассмотрим пример системы, которая получает одни из своих данных от датчика. В большинстве случаев датчик может измерять некоторый шум, и в этом примере учтите, что измеряемые значения равны (0) и (-1) поочередно. Для 32-битной шины данных значение 0 преобразуется в 0x00000000 (0000 0000 0000 0000 0000 0000 0000 0000), а (-1) преобразуется в 0xFFFFFFFF (1111 1111 1111 1111 1111 1111 1111 1111) в представлении с дополнением до 2. Мы видим, что расстояние Хэмминга в этом случае равно 32 (поскольку все 32-битные значения меняют свое состояние). Вместо этого, если мы закодируем шину для использования целочисленного представления со знаком (MSB - знаковый бит), мы можем представить 0 как 0x00000000 (0000 0000 0000 0000 0000 0000 0000 0000) и -1 как 0x80000001 (1000 0000 0000 0000 0000 0000 0000 0001) . В этом случае мы видим, что расстояние Хэмминга между числами равно 2. Следовательно, используя дополнение 2 к знаковой арифметической кодировке, мы можем снизить активность с 32 до 2 раз.
  4. Инверсионное кодирование:[6][7] Это еще одна реализация кодирования шины, в которой к линиям шины добавляется дополнительная линия с именем INV. В зависимости от значения строки INV, другие строки будут использоваться с инверсией или без нее. например если строка INV = 0, данные на шине выбираются как есть, но если строка INV = 1, данные на шине инвертируются перед любой обработкой на ней. Ссылаясь на пример, использованный в 3, вместо использования целочисленного представления со знаком мы могли бы продолжить использование дополнения до 2 и добиться того же снижения активности, используя инверсионное кодирование. Таким образом, 0 будет представлен как 0x00000000 с INV = 0, а -1 будет представлен как 0x00000000 с INV = 1. Поскольку INV = 1, получатель инвертирует данные перед их использованием, тем самым преобразуя их в 0xFFFFFFFF внутренне. В этом случае только 1 бит (бит INV) изменяется по шине, что приводит к активности фактора 1. Как правило, при инверсионном кодировании кодировщик вычисляет расстояние Хэмминга между текущим значением и следующим значением и на основе этого определяет, будет ли использовать INV = 0 или INV = 1.
  5. Кодировка кеша значений:[8] Это еще одна форма кодирования шины, которая в основном используется для внешних (внешних) шин. Словарь (кэш значений) поддерживается как на стороне отправителя, так и на стороне получателя о некоторых из часто используемых шаблонов данных. Вместо того, чтобы каждый раз передавать шаблоны данных, отправитель просто переключает один бит, указывающий, какая запись из кеша значений будет использоваться на стороне получателя. Только для значений, которых нет в кэше значений, полные данные передаются по шине. Были различные модифицированные реализации этого метода с целью максимизировать количество совпадений для кеша значений, но основная идея остается той же.[9][10]
  6. Другие техники как секторное кодирование,[11] также были предложены варианты инверсионного кодирования. Были проведены работы по использованию кодирования шины, которое также снижает потребление мощности утечки, а также уменьшает перекрестные помехи с минимальным влиянием на задержки тракта.[12][13]

Другие примеры кодирования шины

Многие другие типы кодирования шины были разработаны по разным причинам:

  • улучшенная EMC: дифференциальная сигнализация используется во многих автобусах, а в более общем код постоянного веса используется в MIPI C-PHY Последовательный интерфейс камеры[14] оба более устойчивы к внешним помехам и излучают меньше помех другим устройствам.
  • мультиплексирование шины: многие ранние микропроцессоры и многие ранние чипы DRAM снизили затраты за счет использования мультиплексирования шины, вместо того, чтобы выделять вывод для каждого бита адреса и бита данных системная шина. Один подход повторно использует контакты шины адреса в разное время для контактов шины данных, подход, используемый обычный PCI. Другой подход повторно использует одни и те же контакты в разное время для верхней и нижней половины адресной шины, подход, используемый многими динамическая память с произвольным доступом микросхемы, добавляющие 2 пина к шине управления - строб адрес строки (РАН) и строб адреса столбца (CAS).


Метод реализации

В случае конструкций SoC схемы кодирования шины могут быть лучше всего реализованы в RTL путем создания экземпляров выделенных кодеров и декодеров по шине. Другой способ реализации - передача подсказки в инструмент синтеза либо в виде следа моделирования.[15] или с помощью прагмы синтеза, чтобы определить необходимый тип кодирования.

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

Свойства функции кодирования

Функция кодирования / декодирования шины должна быть биекция. По сути, это требует, чтобы функция кодирования имела следующее поведение:[3]

  1. Каждые данные, запускаемые по шине, должны иметь уникальное закодированное значение, и каждое закодированное значение должно уникальным образом декодироваться в одно и то же исходное значение.
  2. Должна быть возможность кодирования и декодирования всех значений, которые могут быть сгенерированы источником.

Компромисс / анализ

  • В то время как добавление кодирования шины снижает коэффициент активности по шине и приводит к снижению динамической мощности, добавление кодеров и декодеров вокруг шины приводит к добавлению дополнительных схем в конструкцию, которые также потребляют определенное количество динамической мощности. Мы должны учитывать это при вычислении экономии энергии.
  • Дополнительная схема также увеличит мощность утечки конструкции / схемы / системы / SoC. Если базовый коэффициент активности системной шины не очень высок, кодирование шины может быть не очень жизнеспособным вариантом, поскольку оно снизит общее энергопотребление из-за более высокой мощности утечки.
  • Если синхронизация шины находится в критическом тракте данных, добавление дополнительных схем в тракт ухудшит тракт хронирования и может оказаться вредным. Этот анализ необходимо провести осторожно, чтобы определить, какую кодировку шины использовать.

Смотрите также

Рекомендации

  1. ^ Педрам, Масуд; Абдоллахи, А., Методы синтеза с низким энергопотреблением на уровне RT: Учебное пособие (PDF)
  2. ^ Девадас; Малик (1995), "Обзор методов оптимизации, нацеленных на схемы СБИС малой мощности", ЦАП 32: 242–247
  3. ^ а б Ченг, Вэй-Чунг; Педрам, Масуд, Кодирование шины памяти для низкого энергопотребления: Учебное пособие (PDF)
  4. ^ Го, Хуэй; Парамешваран, Шри (апрель – июнь 2010 г.). «Кодирование со сдвигом Грея для уменьшения коммутации шины адресов памяти команд для маломощных встраиваемых систем». Журнал системной архитектуры. 56 (4–6): 180–190. Дои:10.1016 / j.sysarc.2010.03.003.
  5. ^ Бенини, Лука; Де Микели, Джованни; Macii, Enrico; Sciuto, D .; Сильвано, К. (март 1997 г.). «Асимптотическое кодирование активности нулевого перехода для адресных шин в маломощных микропроцессорных системах». Труды седьмого симпозиума Великих озер по СБИС: 77–82.
  6. ^ Stan, Mircea R .; Бурлесон, Уэйн П. (март 1995 г.). «Кодирование с инвертированием шины для ввода / вывода с низким энергопотреблением». Транзакции IEEE в системах с очень крупномасштабной интеграцией (СБИС). 3 (1): 49–58. CiteSeerX  10.1.1.89.2154. Дои:10.1109/92.365453. 1063-8210/95$04.00.
  7. ^ http://www.eng.auburn.edu/~agrawvd/COURSE/E6270_Fall07/PROJECT/JIANG/Low%20power%2032-bit%20bus%20with%20inversion%20encoding.ppt. Отсутствует или пусто | название = (помощь)
  8. ^ Yang, J .; и другие. (Август 2001 г.). «Кодирование FV для ввода / вывода данных с низким энергопотреблением». Islped 2001: 84–87.
  9. ^ Басу; и другие. (2002). «Протокол питания: снижение рассеиваемой мощности на внешних шинах данных». МИКРО.
  10. ^ Lin, C.-H .; и другие. (2006). «Иерархическое кодирование кэша значений для внешней шины данных». ISLPED.
  11. ^ Агагири, Яздан; Фаллах, Фарзан; Педрам, Масуд. «Уменьшение количества переходов в шинах памяти с использованием методов кодирования на основе секторов» (PDF).
  12. ^ Deogun, H .; Rao, R .; Сильвестр, Д .; Блаау, Д. (июнь 2004 г.). «Кодирование шины с учетом утечек и перекрестных помех для полного снижения мощности». Материалы 41-й конференции по автоматизации проектирования.: 779–782.
  13. ^ Хан, З .; Арслан, Т .; Эрдоган, А. (январь 2005 г.). «Новая схема кодирования шины с точки зрения энергоэффективности и эффективности перекрестных помех для универсальных систем SoC на основе AMBA». Материалы 18-й Международной конференции по проектированию СБИС.: 751–756.
  14. ^ «Демистификация подсистемы MIPI C-PHY / DPHY - компромиссы, проблемы и принятие» (зеркало )
  15. ^ Бенини, Лука; Де Микели, Джованни; Macii, Enrico; Пончино, Массимо; Quer, Стефано (декабрь 1998 г.). «Оптимизация энергопотребления систем на базе ядра с помощью кодирования адресной шины» (PDF). Транзакции IEEE в системах с очень крупномасштабной интеграцией (СБИС). 6 (4).

дальнейшее чтение