scorp 0 6 февраля, 2014 Опубликовано 6 февраля, 2014 · Жалоба Всем вечер добрый! Подскажите, пожалуйста, как работать с прерываниями не по уровню, а по перепаду. Ядро - Cortex-M4F. Прочитал документацию, не обнаружил настроечного регистра, который бы настроил линию прерывания для работы по перепаду... Есть периферийный блок, который устанавливает прерывание в активное состояние на несколько тактов, после чего сам же его деактивизирует. Возможна ситуация, когда обработчик прерывания завершится и выйдет в основную программу раньше чем случится деактивизация сигнала прерывания и тогда случится повторное выполнение обработчика прерывания, которое нежелательно. Необходимо сделать так, чтобы переход в обработчик прерывания происходил только по фронту сигнала прерывания. Цитата Поделиться сообщением Ссылка на сообщение Поделиться на другие сайты Поделиться
ViKo 1 6 февраля, 2014 Опубликовано 6 февраля, 2014 · Жалоба Всем вечер добрый! Подскажите, пожалуйста, как работать с прерываниями не по уровню, а по перепаду. Ядро - Cortex-M4F. Прочитал документацию, не обнаружил настроечного регистра, который бы настроил линию прерывания для работы по перепаду... А MCU какой? Если STM32, то в Reference Manual написано. Цитата Поделиться сообщением Ссылка на сообщение Поделиться на другие сайты Поделиться
scorp 0 6 февраля, 2014 Опубликовано 6 февраля, 2014 · Жалоба А MCU какой? Если STM32, то в Reference Manual написано. В том-то и дело, что MCU проектирую сам. За обработку прерываний обвечает ядро. Ядро в исходниках. Цитата Поделиться сообщением Ссылка на сообщение Поделиться на другие сайты Поделиться
ViKo 1 6 февраля, 2014 Опубликовано 6 февраля, 2014 · Жалоба В том-то и дело, что MCU проектирую сам. За обработку прерываний обвечает ядро. Ядро в исходниках. Вот у STM32 есть NVIC (в ядре) и EXTI (в периферийных устройствах). Второй контроллер отвечает за внешние прерывания, в нем есть настройки фронтов. Для ознакомления можно скачать руководство на конкретный микроконтроллер. Для других периферийных устройств устанавливается флаг прерывания, который стирается при входе в прерывание. Обычно программно. Цитата Поделиться сообщением Ссылка на сообщение Поделиться на другие сайты Поделиться
scorp 0 6 февраля, 2014 Опубликовано 6 февраля, 2014 · Жалоба Вот у STM32 есть NVIC (в ядре) и EXTI (в периферийных устройствах). Второй контроллер отвечает за внешние прерывания, в нем есть настройки фронтов. Для ознакомления можно скачать руководство на конкретный микроконтроллер. Для других периферийных устройств устанавливается флаг прерывания, который стирается при входе в прерывание. Обычно программно. спасибо. в моём случае периферийное устройство - тоже стронний IP-блок, у которого, к сожалению, настройки вида прерываний нет :( В ядре имеется тот самый NVIC, думал что посредством его настройки можно ему как-то объяснить, что определённую линию прерываний нужно обрабатывать как "прерывание по перепаду"... Цитата Поделиться сообщением Ссылка на сообщение Поделиться на другие сайты Поделиться
Tarbal 4 6 февраля, 2014 Опубликовано 6 февраля, 2014 (изменено) · Жалоба D-триггер со входом присоединенным к единице, на тактовый вход подаете сигнал прерывания. Изменено 6 февраля, 2014 пользователем Tarbal Цитата Поделиться сообщением Ссылка на сообщение Поделиться на другие сайты Поделиться