Телесистемы
 Разработка, производство и продажа радиоэлектронной аппаратуры
На главную   | Карта сайта | Пишите нам | В избранное
Требуется программист в Зеленограде
- обработка данных с датчиков; ColdFire; 40 тыс.
e-mail:jobsmp@pochta.ru

Телесистемы | Электроника | Конференция «Микроконтроллеры и их применение»

У меня тоже обычно 1 мс. Кстати, вопрос:

Отправлено Леонид Иванович 26 апреля 2007 г. 16:20
В ответ на: 1 мсек, изредка 100 мксек отправлено <font color=gray>Михаил Е.</font> 26 апреля 2007 г. 15:50

Вы как-то говорили, что обработчик таймера короткий и служит лишь для того, чтобы передавать сообщения процессам. А софтовые таймера принадлежат процессам и обрабатываются ими. Какой механизм передачи сообщений Вы используете?
Я делаю очень похоже:
В обработчике прерываний выставляю глобальный флаг.
В начале основного цикла (такой примитивный диспетчер задач кооперативной ОС :) копирую флаг в переменную, принадлежащую главному модулю и сбрасываю флаг. Затем как параметр передаю ее при вызове метода execute каждого процесса. Таким образом, раз в миллисекунду во все процессы попадает tick = true. В этом случае там инкрементируются софтовые таймеры и делаются другие зависимые от времени операции.


//Основной цикл:

while(1)
{
tick = Main_GetTick();
Process1_Exe(tick);
ProcessN_Exe(tick);
}

bool Main_GetTick(void)
{
if(!fTick) return(0);
fTick = 0;
return(1);
}

#pragma vector = TIMER0_COMP_vect
__interrupt void Sys_Timer(void)
{
fTick = 1;
}



Составить ответ | Вернуться на конференцию

Ответы


Отправка ответа
Имя*: 
Пароль: 
E-mail: 
Тема*:

Сообщение:

Ссылка на URL: 
URL изображения: 

если вы незарегистрированный на форуме пользователь, то
для успешного добавления сообщения заполните поле, как указано ниже:
введите число 234:

Перейти к списку ответов | Конференция | Раздел "Электроника" | Главная страница | Карта сайта

Rambler's Top100 Рейтинг@Mail.ru
 
Web telesys.ru