Прерывания, сигнализируемые сообщениями - Википедия - Message Signaled Interrupts

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

Прерывания с сообщением поддерживаются в PCI bus, начиная с его версии 2.2, и в более поздних версиях PCI Express автобус. Некоторые архитектуры, отличные от PCI, также используют прерывания с сообщением.

Обзор

Обычно устройство имеет линию прерывания (вывод), которую оно устанавливает, когда хочет сообщить о прерывании в среду обработки хоста. Эта традиционная форма сигнализации прерывания является внеполосной формой сигнализации управления, поскольку она использует выделенный путь для отправки такой информации управления отдельно от основного пути данных. MSI заменяет эти выделенные линии прерываний на внутриполосную сигнализацию, обмениваясь специальными сообщениями, указывающими на прерывания по основному тракту данных. В частности, MSI позволяет устройству записывать небольшой объем данных, описывающих прерывания, в специальный ввод-вывод с отображением памяти адрес, а затем набор микросхем доставляет соответствующее прерывание процессору.[1][2][3]

Распространенное заблуждение относительно MSI заключается в том, что он позволяет устройству отправлять данные процессору как часть прерывания. Данные, которые отправляются как часть транзакции записи в память, используются набором микросхем, чтобы определить, какое прерывание запускать на каком процессоре; эти данные недоступны устройству для передачи дополнительной информации обработчику прерывания.[1][2][3]

Например, PCI Express вообще не имеет отдельных контактов прерывания; вместо этого он использует специальные внутриполосные сообщения, позволяющие имитировать подтверждение вывода или отмену подтверждения. Некоторые архитектуры без PCI также используют MSI; в качестве другого примера, HP GSC устройства не имеют контактов прерывания и могут генерировать прерывания только путем записи непосредственно в регистр прерывания процессора в пространстве памяти.[нужна цитата ] В Гипертранспорт протокол также поддерживает MSI.[4]

Преимущества

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

MSI увеличивает количество возможных прерываний. В то время как обычный PCI был ограничен четырьмя прерываниями на карту (и, поскольку они были разделены между всеми картами, большинство из них используют только одну), прерывания с сигнализацией сообщений допускают десятки прерываний на карту, когда это полезно.[1]

Также есть небольшое преимущество в производительности. В программном обеспечении прерывание на основе вывода может раса с отправил писать на память. То есть устройство PCI записывает данные в память, а затем отправляет прерывание, чтобы указать DMA запись была завершена. Однако мост PCI или контроллер памяти могут буферизовать запись, чтобы не мешать другому использованию памяти. Прерывание могло появиться до завершения записи DMA, и процессор мог прочитать устаревшие данные из памяти.[5] Чтобы предотвратить эту гонку, обработчики прерываний должны были читать с устройства, чтобы гарантировать, что запись DMA завершена. Это чтение имело умеренное снижение производительности. Запись MSI не может пройти запись DMA, поэтому гонка устраняется.[6]

Типы MSI

PCI определяет два дополнительных расширения для поддержки прерываний, сигнализируемых сообщением, MSI и MSI-X. PCI Express определяет свой собственный механизм на основе сообщений для эмуляции устаревших прерываний PCI.

MSI

MSI (впервые определенная в PCI 2.2) позволяет устройству выделять 1, 2, 4, 8, 16 или 32 прерывания. Устройство запрограммировано с адресом для записи (обычно это регистр управления в контроллер прерываний ), и 16-битное слово данных для его идентификации. Номер прерывания добавляется к слову данных для идентификации прерывания.[1] Некоторые платформы, такие как Windows, не используют все 32 прерывания, а используют только до 16 прерываний.[7]

MSI-X

MSI-X (впервые определенный в PCI 3.0) позволяет устройству выделять до 2048 прерываний. Единый адрес, используемый исходным MSI, оказался ограничивающим для некоторых архитектур. В частности, это затрудняло нацеливание отдельных прерываний на разные процессоры, что полезно в некоторых высокоскоростных сетевых приложениях. MSI-X допускает большее количество прерываний и дает каждому из них отдельный целевой адрес и слово данных. Устройства с MSI-X не обязательно поддерживают 2048 прерываний.[3][8][9][10]

Дополнительные функции MSI (64-битная адресация и маскирование прерываний) также являются обязательными для MSI-X.

Эмуляция устаревших прерываний PCI Express

PCI Express не имеет физических линий прерывания, но эмулирует 4 физические линии PCI через выделенные сообщения PCI Express, такие как Assert_INTA и Deassert_INTC. Будучи основанным на сообщениях (на уровне PCI Express), этот механизм обеспечивает некоторые, но не все, преимущества механизма MSI уровня PCI: 4 виртуальные линии на устройство больше не используются совместно на шине (хотя контроллеры PCI Express могут по-прежнему объединяют устаревшие прерывания внутри), и изменения прерывания больше не страдают от состояний гонки.

PCI Express позволяет устройствам использовать эти устаревшие сообщения о прерываниях, сохраняя программную совместимость с драйверами PCI, но они также должны поддерживать MSI или MSI-X на уровне PCI.

системы x86

В системах Intel LAPIC должен быть включен для работы PCI (и PCI Express) MSI / MSI-X даже в однопроцессорных (одноядерных) системах.[11][12] В этих системах MSI обрабатываются путем записи вектора прерывания непосредственно в LAPIC процессора / ядра, который должен обслуживать прерывание. Intel LAPIC 2009 года поддерживала до 224 прерываний на основе MSI.[12] Согласно тесту Intel 2009 года с использованием Linux, использование MSI сократило задержку прерываний почти в три раза по сравнению с доставкой ввода-вывода APIC.[13]

Поддержка операционной системы

В семействе операционных систем Microsoft Виндоус виста и более поздние версии поддерживают как MSI, так и MSI-X. Поддержка была добавлена ​​в Longhorn цикл разработки около 2004 года.[14] MSI не поддерживается в более ранних версиях, например Windows XP или же Windows Server 2003.[15]

Solaris Express в выпуске 6/05 добавлена ​​поддержка MSI и MSI-X как часть их новых интерфейс драйвера устройства (DDI) структура прерывания.[16]

FreeBSD 6.3 и 7.0 добавили поддержку MSI и MSI-X.[17]

OpenBSD 5.0 добавлена ​​поддержка MSI.[18] 6.0 добавлена ​​поддержка MSI-X.[19]

Linux получил поддержку MSI и MSI-X примерно в 2003 году.[20] Ядро Linux Известно, что версии до 2.6.20 имеют серьезные ошибки и ограничения в реализации MSI / MSI-X.[21]

Хайку получил поддержку MSI примерно в 2010 году.[22] Поддержка MSI-X была добавлена ​​позже, в 2013 году.[23]

NetBSD В 8.0 добавлена ​​поддержка MSI и MSI-X.

VxWorks 7 поддерживает MSI и MSI-X

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

  1. ^ а б c d Спецификация локальной шины PCI, редакция 2.2. Раздел 6.8 (MSI). PCI-SIG. Декабрь 1998 г.
  2. ^ а б Версия 2.3 спецификации локальной шины PCI. Раздел 6.8 (MSI). PCI-SIG. 2002 г.
  3. ^ а б c Версия 3.0 Спецификации локальной шины PCI. Раздел 6.8 (MSI и MSI-X). PCI-SIG. Август 2002 г.
  4. ^ Дон Андерсон; Джей Тродден (2003). Архитектура системы HyperTransport. Эддисон-Уэсли Профессионал. п. 200. ISBN  978-0-321-16845-0.
  5. ^ Коулман, Джеймс (2009). «Обзор методов доставки прерываний, устаревших прерываний XT-PIC, ограничений XT-PIC». Сокращение задержки прерывания за счет использования прерываний, сигнализируемых сообщением (PDF). Корпорация Intel. п. 10.
  6. ^ Корбет, Джонатан; Рубини, Алессандро; Кроа-Хартман, Грег (2009). «Глава 15: Отображение памяти и DMA». Драйверы устройств Linux (3-е изд.). O'Reilly Media. Получено 2019-04-20.
  7. ^ Microsoft. «Включение прерываний, сигнализируемых сообщениями, в реестре». Корпорация Майкрософт. Получено 12 апреля 2013.
  8. ^ «Раздел 6.1: MSI и MSI-X». Базовая спецификация PCI Express, редакция 1.0a. PCI-SIG. Апрель 2003 г.
  9. ^ «Раздел 6.1: MSI и MSI-X». Версия 1.1 базовой спецификации PCI Express. PCI-SIG. Март 2005 г.
  10. ^ «Уведомление об инженерных изменениях MSI-X». Версия 2.3 спецификации локальной шины PCI (PDF). PCI-SIG.
  11. ^ Подсистемы прерываний на базе APIC на однопроцессорных ПК
  12. ^ а б Коулман, Джеймс (2009). Сокращение задержки прерывания за счет использования прерываний, сигнализируемых сообщением (PDF). Корпорация Intel. С. 10, 11.
  13. ^ Коулман, Джеймс (2009). «Результаты, платформа класса рабочих станций». Сокращение задержки прерывания за счет использования прерываний, сигнализируемых сообщением (PDF). Корпорация Intel. п. 19.
  14. ^ Улучшения архитектуры прерывания в Microsoft Windows Vista, 11 августа 2004 г.
  15. ^ PCI, PCI-X и PCI Express: часто задаваемые вопросы, 18 ноября 2005 г., стр. 4
  16. ^ Джон Стернс, Говинда Татти, Эдвард Джиллетт и Аниш Гупта (27 марта 2006 г.) Изменения, внесенные для поддержки MSI в расширенных обработчиках прерываний Solaris Express в ОС Solaris Express 6/05
  17. ^ Джон Х. Болдуин, «Прерывания PCI для машин x86 под FreeBSD», раздел "доступность"
  18. ^ Марк Кеттенис (май 2011 г.) Прерывания MSI для многих устройств на тех архитектурах, которые могут их поддерживать (пока только amd64, i386, sparc64)
  19. ^ Марк Кеттенис (май 2016 г.) Добавлена ​​начальная поддержка MSI-X.
  20. ^ MSI-HOWTO.txt первая версия
  21. ^ Могу ли я использовать прерывания MSI-X с Myri10GE в Linux 2.6.18 и ранее?
  22. ^ [1] Haiku добавляет поддержку MSI
  23. ^ [2] Haiku добавляет поддержку MSI-X

внешняя ссылка