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

 
 
> Прерывание от TC, ищу совета в организации обработки
sailor
сообщение Dec 19 2007, 10:23
Сообщение #1


Участник
*

Группа: Новичок
Сообщений: 20
Регистрация: 12-10-07
Пользователь №: 31 289



Имеем: AT91SAM7(X256 - но это уже не важно). Опыт работы с ним пока небольшой.
Используем таймер-счетчик. Нужно считать частоту. Т.е. работаем в режиме захвата. Используем прерывание. При этом при прохождении импульсов от 1 до N-1 в обработчике прерываний производим только фильтрацию, а по приходу N-го импульса, необходимо выполнить гораздо большую обработку: фильтрация + собственно вычисление частоты + расчет управляющего(их) воздействия(ий). Причем последняя часть довольно весома. И так по кругу.
Так вот вопрос связан с тем, как это все сорганизовать, что б задача расчета в обработчике прерывания не мешала работе самого ТС (подсчет интерчала следующего цикла) и в тго же время, что б решение не было б "тяжелым" по ресурсоемкости.
Есть конечно варинт с выставлением флага в обработчике при приходе N-го импульса, с проверкой данного флага в фоновой задаче и выполнением расчетов в фоновой задаче. Но, IMHO, не очень красиво.
Может кто-то подскажет что-то более оптимальное и красивое?
Не знаю, возможен ли вариант, когда в обработчике прерывания TC генерится программное прерывание, сам обработчик ТС при этом завершает работу, а расчет производится в обработчике программногго прерывания?
С уважением.
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
_dem
сообщение Dec 19 2007, 12:15
Сообщение #2


Местный
***

Группа: Свой
Сообщений: 263
Регистрация: 2-02-07
Из: CN, Ukraine
Пользователь №: 24 970



Цитата
Или речь шла о софтварном прерывании при помощи AIC

Именно это я и имел в виду - обработка вешается на прерывание с более низким приоритетом.


Цитата
но решение таких задач (имеется ввиду весь регулятор) с использованием операционки, IMHO, очень громоздкое и посему чрезвычайно "некрасивое" решение

Как раз очень удобное и предсказуемое по таймингам решение smile.gif Но, хозяин - барин.

Так почему же не использовать флаг ? Если нет операционки, то вам в любом случае надо подобие семафора. Можно вывернутся через AIC, но ... вешайте свою обработку на аппаратное прерывание-от-чего-угодно, например PIO или USART, далее либо вызывайте прерывание (дрыгнув ножкой), либо разрешайте его (например, сделайте один раз дрыг а потом разрешайте обработку).

После выхода из PIT AIC вызовет второй обработчик, в конце которого он отключит сам себя, _не сбрасывая_ активный уровень прерывания. Причем во время работы обработчика прерывание PITC будет работать, т.к. у него более высокий приоритет.

Это выход, но как-то некрасиво sad.gif

Цитата
И в т.ч. будут и прерывания (в т.ч. и от USART-а, от других ТС etc.). Они будут "отодвигать" фоновую задачу на неопределенные интервалы. Т.е. интервал между измерением и вычислением воздействия будет "плавающим", возможно с большим разбросом, что для данного типа задач не есть хорошо. С прерыванием (соответствующего приоритета), как мне кажется, данный интервал будет боле-мене стабилен.

Тут я чего-то не понимаю. Если у вас получается так, что из-за "USART-а, от других ТС" может не хватить времени на основную задачу, то "что-то неладно в датском королевстве". Такая проблема решается блокировкой "лишних" прерываний на время выполнения критичного кода.
Go to the top of the page
 
+Quote Post



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

 


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


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