Читать «Разработка ядра Linux» онлайн - страница 103
Роберт Лав
• Указатель h
теперь указывает на второй элемент массива, а в битовой маске — второй бит стал первым. Теперь необходимо повторить все ранее проделанные шаги.
• Последовательное повторение производится до тех пор, пока битовая маска не станет равной нулю. В этот момент больше нет ожидающих отложенных прерываний, и наша работа выполнена. Заметим, что такой проверки достаточно для того, чтобы гарантировать, что указатель h
всегда указывает на законную запись в массиве softirq_vec
, так как битовая маска pending имеет 32 бит и цикл не может выполниться больше 32 раз.
Использование отложенных прерываний
Отложенные прерывания зарезервированы для наиболее важных и критичных ко времени выполнения обработчиков нижних половин в системе. Сейчас только две подсистемы — подсистема SCSI и сетевая подсистема — напрямую используют механизм softirq. В дополнение к этому, таймеры ядра и тасклеты построены на базе отложенных прерываний. Если есть желание добавить новое отложенное прерывание, то стоит себя спросить, почему будет недостаточно использования тасклетов. Тасклеты могут создаваться динамически, а также их легче использовать в связи с более простыми требованиями к блокировкам. Кроме того, их производительность все еще остается очень хорошей. Тем не менее для задач, критичных ко времени выполнения, которые способны сами обеспечивать эффективные блокировки, использование механизма softirq — будет правильным решением.
Назначение индексов
Отложенные прерывания должны объявляться на этапе компиляции с помощью соответствующего перечисления (enum
) в файле <linux/interrupt.h>
. Ядро использует указанный в перечислении индекс, который начинается с нуля, как значение относительного приоритета отложенных прерываний. Отложенные прерывания с меньшим номером выполняются раньше отложенных прерываний с большим номером.
Создание нового отложенного прерывания состоит в добавлении новой записи в этот перечень (enum
). Однако нужно не просто добавить новую строчку в конец списка, как в других местах. Вместо этого нужно вставить строчку в соответствии с приоритетом, который дается этому прерыванию. Исторически, HI_SOFTIRQ
— имеет наибольший приоритет, a TASKLET_SOFTIRQ
— наименьший. Новая запись, скорее всего, должна быть где-то ниже записей для сетевых устройств и выше записи для TASKLET_SOFTIRQ
. В табл. 7.2 показан список всех типов отложенных прерываний.
Таблица 7.2. Список отложенных прерываний
Отложенное прерывание | Приоритет | Описание |
---|---|---|
HI_SOFTIRQ | 0 | Высокоприоритетные тасклеты |
TIMER_SOFTIRQ | 1 | Обработчик нижних половин таймеров |
NET_TX_SOFTIRQ | 2 | Отправка сетевых пакетов |
NET_RX_SOFTIRQ | 3 | Прием сетевых пакетов |
SCSI_SOFTIRQ | 4 | Обработчик нижних половин подсистемы SCSI |
TASKLET_SOFTIRQ | 5 | Тасклеты |