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

 
 
> Прерывания по перепаду
Nix_86
сообщение Feb 6 2014, 17:19
Сообщение #1


Частый гость
**

Группа: Свой
Сообщений: 85
Регистрация: 7-04-11
Пользователь №: 64 200



Всем вечер добрый!
Подскажите, пожалуйста, как работать с прерываниями не по уровню, а по перепаду. Ядро - Cortex-M4F. Прочитал документацию, не обнаружил настроечного регистра, который бы настроил линию прерывания для работы по перепаду...
Есть периферийный блок, который устанавливает прерывание в активное состояние на несколько тактов, после чего сам же его деактивизирует.
Возможна ситуация, когда обработчик прерывания завершится и выйдет в основную программу раньше чем случится деактивизация сигнала прерывания и тогда случится повторное выполнение обработчика прерывания, которое нежелательно.
Необходимо сделать так, чтобы переход в обработчик прерывания происходил только по фронту сигнала прерывания.
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов (1 - 5)
ViKo
сообщение Feb 6 2014, 17:29
Сообщение #2


Универсальный солдатик
******

Группа: Модераторы
Сообщений: 8 634
Регистрация: 1-11-05
Из: Минск
Пользователь №: 10 362



Цитата(Nix_86 @ Feb 6 2014, 20:19) *
Всем вечер добрый!
Подскажите, пожалуйста, как работать с прерываниями не по уровню, а по перепаду. Ядро - Cortex-M4F. Прочитал документацию, не обнаружил настроечного регистра, который бы настроил линию прерывания для работы по перепаду...

А MCU какой? Если STM32, то в Reference Manual написано.
Go to the top of the page
 
+Quote Post
Nix_86
сообщение Feb 6 2014, 17:35
Сообщение #3


Частый гость
**

Группа: Свой
Сообщений: 85
Регистрация: 7-04-11
Пользователь №: 64 200



Цитата(ViKo @ Feb 6 2014, 20:29) *
А MCU какой? Если STM32, то в Reference Manual написано.

В том-то и дело, что MCU проектирую сам. За обработку прерываний обвечает ядро. Ядро в исходниках.
Go to the top of the page
 
+Quote Post
ViKo
сообщение Feb 6 2014, 17:43
Сообщение #4


Универсальный солдатик
******

Группа: Модераторы
Сообщений: 8 634
Регистрация: 1-11-05
Из: Минск
Пользователь №: 10 362



Цитата(Nix_86 @ Feb 6 2014, 20:35) *
В том-то и дело, что MCU проектирую сам. За обработку прерываний обвечает ядро. Ядро в исходниках.

Вот у STM32 есть NVIC (в ядре) и EXTI (в периферийных устройствах). Второй контроллер отвечает за внешние прерывания, в нем есть настройки фронтов. Для ознакомления можно скачать руководство на конкретный микроконтроллер.
Для других периферийных устройств устанавливается флаг прерывания, который стирается при входе в прерывание. Обычно программно.
Go to the top of the page
 
+Quote Post
Nix_86
сообщение Feb 6 2014, 18:04
Сообщение #5


Частый гость
**

Группа: Свой
Сообщений: 85
Регистрация: 7-04-11
Пользователь №: 64 200



Цитата(ViKo @ Feb 6 2014, 20:43) *
Вот у STM32 есть NVIC (в ядре) и EXTI (в периферийных устройствах). Второй контроллер отвечает за внешние прерывания, в нем есть настройки фронтов. Для ознакомления можно скачать руководство на конкретный микроконтроллер.
Для других периферийных устройств устанавливается флаг прерывания, который стирается при входе в прерывание. Обычно программно.

спасибо.
в моём случае периферийное устройство - тоже стронний IP-блок, у которого, к сожалению, настройки вида прерываний нет sad.gif
В ядре имеется тот самый NVIC, думал что посредством его настройки можно ему как-то объяснить, что определённую линию прерываний нужно обрабатывать как "прерывание по перепаду"...
Go to the top of the page
 
+Quote Post
Tarbal
сообщение Feb 6 2014, 19:37
Сообщение #6


Профессионал
*****

Группа: Свой
Сообщений: 1 351
Регистрация: 21-05-10
Пользователь №: 57 439



D-триггер со входом присоединенным к единице, на тактовый вход подаете сигнал прерывания.

Сообщение отредактировал Tarbal - Feb 6 2014, 19:48
Go to the top of the page
 
+Quote Post

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

 


RSS Текстовая версия Сейчас: 21st August 2025 - 13:16
Рейтинг@Mail.ru


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