|
|
  |
Вложенные прерывания в embedded RTOS, по следам обсуждения TNKernel |
|
|
|
Apr 4 2007, 06:56
|

Странник
   
Группа: Свой
Сообщений: 766
Регистрация: 29-08-05
Из: Екатеринбург
Пользователь №: 8 051

|
Начало: http://electronix.ru/forum/index.php?showt...=29375&st=0Отсутствие вложенных прерываний иногда может привести к непомерной потребности производительности МК. Пример: Есть 8 источников прерываний. Самым тяжелым случаем будет момент (его нельзя исключать), когда одновременно будут выставлены все флаги запроса прерывания. Без вложенийОбрабатываться прерывания будут последовательно, в определенном аппаратными средствами порядке. Если окажется что самое критичное прерывание будет последним в этой очереди, то придется жестко контролировать время выполнения всех прерываний. Шаг в сторону -- прерывание потеряно... Код 1-2-3-4-5-6-7-8 С возможностью одного вложения
Самому критичному присваиваем высокий приоритет - поэтому оно будет обработано всегда первым - выигрыш по производительности получается в 8 раз Код 8(!)-1-2-3-4-5-6-7 - все одновременно 1>8(!)<1-2-3-4-5-6-7 - запрос 8-го чуть позже, во время выполнения обработчика первого. К чему я это? К тому, что иметь такую возможность не помешает именно в embedded приложениях, когда требуется "утоптать" в имеющийся аппарат, а не брать монстра. PS: Вложенные прерывания на некоторых системах достаточно "дороги" за счет потребления RAM, если затруднительно организовать отдельный стек для прерываний.
--------------------
"Как много есть на свете вещей, которые мне не нужны!" Сократ
|
|
|
|
|
Apr 4 2007, 08:59
|

Adept
     
Группа: Свой
Сообщений: 3 469
Регистрация: 6-12-04
Из: Novosibirsk
Пользователь №: 1 343

|
Цитата(spf @ Apr 4 2007, 10:56)  Отсутствие вложенных прерываний иногда может привести к непомерной потребности производительности МК. Пример: Есть 8 источников прерываний. Самым тяжелым случаем будет момент (его нельзя исключать), когда одновременно будут выставлены все флаги запроса прерывания. Без вложенийОбрабатываться прерывания будут последовательно, в определенном аппаратными средствами порядке. Если окажется что самое критичное прерывание будет последним в этой очереди, то придется жестко контролировать время выполнения всех прерываний. Шаг в сторону -- прерывание потеряно... Код 1-2-3-4-5-6-7-8 С возможностью одного вложения
Самому критичному присваиваем высокий приоритет - поэтому оно будет обработано всегда первым - выигрыш по производительности получается в 8 раз Код 8(!)-1-2-3-4-5-6-7 - все одновременно 1>8(!)<1-2-3-4-5-6-7 - запрос 8-го чуть позже, во время выполнения обработчика первого. К чему я это? К тому, что иметь такую возможность не помешает именно в embedded приложениях, когда требуется "утоптать" в имеющийся аппарат, а не брать монстра. PS: Вложенные прерывания на некоторых системах достаточно "дороги" за счет потребления RAM, если затруднительно организовать отдельный стек для прерываний. Это все классно, когда есть аппаратная поддержка такой схемы, как в твоем любимом  FR. А вот если этого нет, если контроллер прерываний одноуровневый, то тут лепить вложенные прерывния - это зачастую приключения на известное место.
--------------------
«Отыщи всему начало, и ты многое поймёшь» К. Прутков
|
|
|
|
|
Apr 4 2007, 09:32
|

embarrassed systems engineer
    
Группа: Свой
Сообщений: 1 083
Регистрация: 24-10-05
Из: Осокорки
Пользователь №: 10 038

|
Цитата(spf @ Apr 4 2007, 06:56)  К чему я это? К тому, что иметь такую возможность не помешает именно в embedded приложениях, когда требуется "утоптать" в имеющийся аппарат, а не брать монстра. PS: Вложенные прерывания на некоторых системах достаточно "дороги" за счет потребления RAM, если затруднительно организовать отдельный стек для прерываний. Дык, например, для ARM никаких проблем нет - в безопасном месте обрабочика вставляем функцию типа (вариант для IAR 4.3x): Код public irq_Reenable irq_Reenable: mov R1, LR mrs R2, SPSR mrs R0, CPSR bic R0, R0, #NOINT msr CPSR_c, R0 nop nop nop orr R0, R0, #NOINT msr CPSR_c, R0 msr SPSR_cxsf, R2 mov PC, R1 И живем долго и счастливо с вложенными прерываниями  К RTOS это имеет несколько косвенное отношение - упомянутый TNKernel, cкорее всего, даже без модификации будет работать с такими обработчиками (возможно, сегодня выясню это практически).
|
|
|
|
|
Apr 4 2007, 09:41
|

Гуру
     
Группа: Свой
Сообщений: 13 372
Регистрация: 27-11-04
Из: Riga, Latvia
Пользователь №: 1 244

|
Цитата(spf @ Apr 4 2007, 05:56)  Без вложений Обрабатываться прерывания будут последовательно, в определенном аппаратными средствами Обрабатываться будут в порядке приоритетов и самое приоритетное обработается максимум после завершения одного из предыдуших, а отнюдь не всех семи предыдущих. Цитата - выигрыш по производительности получается в 8 раз Код 8(!)-1-2-3-4-5-6-7 - все одновременно 1>8(!)<1-2-3-4-5-6-7 - запрос 8-го чуть позже, во время выполнения обработчика первого. Причем здесь поминание слова "производительность"? Почему скромно в 8 раз? А пусть самое первое обрабатывается в 8000 раз дольше самого приоритетного, тогда мы получим "производительность" аж 8008 раз большую, а если написать, что 8 миллионов раз, то... Цитата К тому, что иметь такую возможность не помешает именно в embedded приложениях, когда требуется "утоптать" в имеющийся аппарат, а не брать монстра. Прежде всего нужно НЕ РОЖДАТЬ монстра на уровне продумывания системы. И не потребуется "утаптывать".
--------------------
Feci, quod potui, faciant meliora potentes
|
|
|
|
|
Apr 4 2007, 10:20
|

Местный
  
Группа: Свой
Сообщений: 304
Регистрация: 5-07-04
Из: г. Москва
Пользователь №: 259

|
Цитата(zltigo @ Apr 4 2007, 10:41)  Прежде всего нужно НЕ РОЖДАТЬ монстра на уровне продумывания системы. И не потребуется "утаптывать". Полностью согласен. К тому же - к обсуждаемому вопросу - не обязательно выполнять все действия по обслуживанию прерывания немедленно - есть то, что отложить нельзя - например, забрать символ из приемного буфера, или наоборот - положить в передающий, и действия, которые могут быть проделанны позже - отсюда - многоуровневая процедура обработки, с буферами, очередями и приоритетами, т.е. теми механизмами, которые нам дает использование многозадачной системы.
--------------------
Водку пьянствовать и безобразия нарушать!!!
|
|
|
|
|
Apr 4 2007, 12:02
|
Частый гость
 
Группа: Свой
Сообщений: 163
Регистрация: 24-08-05
Пользователь №: 7 937

|
Цитата(v_shamaev @ Apr 4 2007, 10:20)  Полностью согласен. К тому же - к обсуждаемому вопросу - не обязательно выполнять все действия по обслуживанию прерывания немедленно - есть то, что отложить нельзя - например, забрать символ из приемного буфера, или наоборот - положить в передающий, и действия, которые могут быть проделанны позже - отсюда - многоуровневая процедура обработки, с буферами, очередями и приоритетами, т.е. теми механизмами, которые нам дает использование многозадачной системы. Я где-то читал, что RTOS с preemptive scheduler и разными приоритетами задач есть по сути софтовая реализация аппаратного многоприоритетного контроллера прерываний. Как вам такая идея ?
|
|
|
|
|
Dec 14 2008, 13:09
|

Участник

Группа: Validating
Сообщений: 27
Регистрация: 12-12-08
Из: Ижевск
Пользователь №: 42 419

|
Цитата(yuri_t @ Apr 4 2007, 16:02)  Я где-то читал, что RTOS с preemptive scheduler и разными приоритетами задач есть по сути софтовая реализация аппаратного многоприоритетного контроллера прерываний. Как вам такая идея ? Хорошая идея, но тут есть одно но! Если у вас написано для многопиоритетных прерываний -> вы это переложите на ОСРВ, а если написано на ОСРВ то не факт что переложите на прерывания ибо обработчик прерывания запустился и окончился (все его локальные переменные что были исчезли), а поток может не закончиться никогда(локальные препеменные всегда лежать в его персональном стеке).
|
|
|
|
|
  |
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0
|
|
|