реклама на сайте
подробности

 
 
> Прерывание PCI, Разбираемся в процессе обработки прерывания PCI
GrAlexI
сообщение Jun 18 2012, 08:50
Сообщение #1


Участник
*

Группа: Участник
Сообщений: 65
Регистрация: 22-06-11
Пользователь №: 65 818



Я решил реализовать обработку прерывания по шине PCI от своего устройства. Почитав различные материалы, выяснил, что так как устройство у меня одно функциональное, то мне достаточно использовать только линую INTA, причем линия является для вывода (другие INTx могу я не подключать вообще), и в неактивном состояние должен находится в состоянии ‘Z’, а при вызове на порывание перевести в состояние ‘0’, и быть в состоянии ‘0’ до тех пор пока не будет, обработана драйвером устройства, в моем случаи прочитать с порта ввода-вывода.

Так же при конфигурации устройства моему устройстве выделяется порывание на INTA с номером 14.

Правильно я все понял?

А как реагирует контроллер обрабатывающий pci при приходе прерывания с линии? Он сперва определяет через команду “0000” Interrupt Acknowledge какой номер прерывания, после чего сообщает процессору номер прерывания. Или все же сообщает процессору о прерывании, а операционная система вызывает обработчики прерывании каждого pci устройства, а те в свою очередь определяет их устройство востребовало прерывные через команду Interrupt Acknowledge или возможно нет в этой команде необходимости, достаточно на пример считать с моего устройства какой-то регистр, с тот в свою очередь (устройство) сбросить прерывание в ‘Z’. Как вообще происходит процесс обработки прерывания и надо ли обрабатываться команду “0000” Interrupt Acknowledge.

При выполнение команды lspci -vvv (в терминале Linux), увидел параметры Control: ….. DisINTx-, и еще один Status: …… INTx-, я так понимаю это значения из конфигураций устройства, я не нашел описание этих значений их необходимо конфигурировать, как?
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
gerber
сообщение Jun 18 2012, 09:59
Сообщение #2


Знающий
****

Группа: Участник
Сообщений: 750
Регистрация: 1-11-11
Пользователь №: 68 088



Прокладыванием сигналов прерываний от PCI устройств до линий IRQ процессора (а точнее, контроллера прерываний) занимается BIOS, т. к. только разработчику BIOS-а известна схемотехника платы. Это называется "IRQ Routing". После того, как прерывание от найденного PCI устройства проложено до определённой линии IRQ, в ячейку памяти PCI платы BIOS-ом записывается этот номер IRQ, чтобы драйвер мог узнать, на какой номер IRQ нужно подвешивать свой обработчик прерывания.
Необходимо понимать, что ячейка памяти в конфиг-пространстве платы PCI - это только байтовая ячейка памяти, и не более того. То есть, если вы туда запишете самостоятельно вместо IRQ 14 число 13 - от этого плата "не пересядет" на IRQ 13.
Когда будут возникать и когда сбрасываться прерывания - это определяется полностью дизайном PCI-устройства, т. е. вашей фантазией. Так как PCI прерывания - это прерывания "по уровню" (level-sensitive), то процессор будет входить в обработчик прерывания до тех пор, пока плата не снимет активный низкий уровень на линии #INT. Этим гарантируется, что все источники прерывания рано или поздно будут обслужены, даже если событие прерывания произойдёт между тем, как процессор прочитал статус-регистр (а PCI плата в этот момент сняла прерывание) и затем вышел из обработчика прерывания.


--------------------
"... часами я мог наблюдать, как люди работают." (М. Горький)
Go to the top of the page
 
+Quote Post



Reply to this topicStart new topic
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 


RSS Текстовая версия Сейчас: 23rd July 2025 - 18:58
Рейтинг@Mail.ru


Страница сгенерированна за 0.01368 секунд с 7
ELECTRONIX ©2004-2016