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

 
 
2 страниц V   1 2 >  
Reply to this topicStart new topic
> STM32, интерфейсы и прерывания, Куча вопросов
nya
сообщение Nov 11 2015, 08:36
Сообщение #1


Участник
*

Группа: Участник
Сообщений: 26
Регистрация: 17-04-07
Пользователь №: 27 107



Коллеги, а подскажите, как работать с прерываниями от внешних интерфейсов.
Возьмем, к примеру, CAN.
  1. Есть две функции приема по CAN: HAL_CAN_Receive() и HAL_CAN_Receive_IT(). В чем между ними разница? Генерит ли HAL_CAN_Receive() прерывания, если нет - как ей пользоваться?
  2. При каких условиях запускаются обработчики прерываний USB_LP_CAN1_RX0_IRQHandler() и CAN1_RX1_IRQHandler()?
  3. Как пользоваться HAL_CAN_RxCpltCallback() и почему Cube не создает эту функцию вместе с прочими обработчиками прерываний?

Примеров c HAL в интернетах очень мало, поэтому я не смог найти ответов на эти вопросы... заранее спасибо.

Сообщение отредактировал nya - Nov 11 2015, 08:41
Go to the top of the page
 
+Quote Post
Tanya
сообщение Nov 11 2015, 08:51
Сообщение #2


Гуру
******

Группа: Модераторы
Сообщений: 8 752
Регистрация: 6-01-06
Пользователь №: 12 883



Цитата(nya @ Nov 11 2015, 11:36) *
Примеров c HAL в интернетах очень мало, поэтому я не смог найти ответов на эти вопросы... заранее спасибо.

1. Из названия понятно, кажется мне. Если нет прерываний - ждем-опрашиваем.
3. Создает пустышку-затычку с атрибутом __weak. Ведь никто не может читать Ваши мысли... Вы сами у себя в программе пишите обработчик. Без атрибута, тогда Ваша код будет иметь приоритет.
Go to the top of the page
 
+Quote Post
nya
сообщение Nov 11 2015, 09:06
Сообщение #3


Участник
*

Группа: Участник
Сообщений: 26
Регистрация: 17-04-07
Пользователь №: 27 107



Но зачем два обработчика - Handler и Callback?
Go to the top of the page
 
+Quote Post
Tanya
сообщение Nov 11 2015, 09:23
Сообщение #4


Гуру
******

Группа: Модераторы
Сообщений: 8 752
Регистрация: 6-01-06
Пользователь №: 12 883



Цитата(nya @ Nov 11 2015, 12:06) *
Но зачем два обработчика - Handler и Callback?

Это для того, чтобы Вы не возились с регистрами. HAL - Hardware Abstraction Level (Layer).
Go to the top of the page
 
+Quote Post
nya
сообщение Nov 11 2015, 09:44
Сообщение #5


Участник
*

Группа: Участник
Сообщений: 26
Регистрация: 17-04-07
Пользователь №: 27 107



Цитата(Tanya @ Nov 11 2015, 12:23) *
Это для того, чтобы Вы не возились с регистрами. HAL - Hardware Abstraction Level (Layer).

Так это понятно. sm.gif Но я сейчас нашел таки рабочий пример для CAN - http://geektimes.ru/post/255534/
Похоже, в моем коде были неправильно выставлены настройки фильтров, вот прерывания и не вызывались.
Поэкспериментировав, выяснил, что оба этих обработчика работают одинаково хорошо. И запускаются одновременно. Поэтому все-такие непонятно в чем между ними разница и когда нужно использовать Handler, а когда - Callback. В обоих случаях "ручной труд" с регистрами равен нулю.
Go to the top of the page
 
+Quote Post
Tanya
сообщение Nov 11 2015, 09:46
Сообщение #6


Гуру
******

Группа: Модераторы
Сообщений: 8 752
Регистрация: 6-01-06
Пользователь №: 12 883



Цитата(nya @ Nov 11 2015, 12:44) *
когда нужно использовать Handler, а когда - Callback. В обоих случаях "ручной труд" с регистрами равен нулю.

Нужно использовать Callback. Предполагается, что всегда. Callback вызывается в самом конце обработчика.
Go to the top of the page
 
+Quote Post
nya
сообщение Nov 11 2015, 09:58
Сообщение #7


Участник
*

Группа: Участник
Сообщений: 26
Регистрация: 17-04-07
Пользователь №: 27 107



Цитата(Tanya @ Nov 11 2015, 12:46) *
Нужно использовать Callback. Предполагается, что всегда. Callback вызывается в самом конце обработчика.

То есть я должен писать обработчики Callback в main.c вместо того, чтобы лезть в stm32***_it.c?
Go to the top of the page
 
+Quote Post
Tanya
сообщение Nov 11 2015, 10:06
Сообщение #8


Гуру
******

Группа: Модераторы
Сообщений: 8 752
Регистрация: 6-01-06
Пользователь №: 12 883



Цитата(nya @ Nov 11 2015, 12:58) *
То есть я должен писать обработчики Callback в main.c вместо того, чтобы лезть в stm32***_it.c?

Пишите, где хотите... в своем коде. Ведь их код может быть со временем изменен в новой версии.
Go to the top of the page
 
+Quote Post
Tarbal
сообщение Nov 11 2015, 15:53
Сообщение #9


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

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



Цитата(nya @ Nov 11 2015, 12:58) *
То есть я должен писать обработчики Callback в main.c вместо того, чтобы лезть в stm32***_it.c?


Да. Так будет правильно.
Go to the top of the page
 
+Quote Post
drozel
сообщение Nov 12 2015, 02:40
Сообщение #10


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

Группа: Свой
Сообщений: 108
Регистрация: 2-02-11
Пользователь №: 62 650



Цитата(Tarbal @ Nov 11 2015, 21:53) *
Да. Так будет правильно.

Да вот хз. По идее, даже не смотря на навороченный NVIC, обработчик прерывания должен быть разумно коротким, а в HAL мало того, что обработчик раздутый до нельзя, так еще и калбек вызывается прямо из него. А пользователь в калбеке воротит кучу кода и еще вызовы своих функций. Дай бог, без блокирующих задержек.
Go to the top of the page
 
+Quote Post
_Pasha
сообщение Nov 12 2015, 04:33
Сообщение #11


;
******

Группа: Участник
Сообщений: 5 646
Регистрация: 1-08-07
Пользователь №: 29 509



Цитата(drozel @ Nov 12 2015, 05:40) *
Да вот хз. По идее, даже не смотря на навороченный NVIC, обработчик прерывания должен быть разумно коротким, а в HAL мало того, что обработчик раздутый до нельзя, так еще и калбек вызывается прямо из него.

этот HAL переплюнул легендарный индусский код. Его даже в кач-ве справочника использовать нельзя.
но и это цветочки.
по идее, описание регистров всей линейки stm32 должно уместиться в пару файлов 25-30 кб, с весьма удобным API вместо 100 метровых библиотек ни о чем.

Сообщение отредактировал _Pasha - Nov 12 2015, 04:34
Go to the top of the page
 
+Quote Post
jcxz
сообщение Nov 12 2015, 04:42
Сообщение #12


Гуру
******

Группа: Свой
Сообщений: 5 228
Регистрация: 3-07-08
Из: Омск
Пользователь №: 38 713



Цитата(Tanya @ Nov 11 2015, 15:23) *
Это для того, чтобы Вы не возились с регистрами. HAL - Hardware Abstraction Level (Layer).

Как правило: тот кто не хочет возиться с регистрами, возится с кучей кривых исходников написанных школьниками. А потом ещё идёт и строчит в форумы "хелп ми!"....

Цитата(_Pasha @ Nov 12 2015, 10:33) *
по идее, описание регистров всей линейки stm32 должно уместиться в пару файлов 25-30 кб, с весьма удобным API вместо 100 метровых библиотек ни о чем.

согласен с Вами.
Go to the top of the page
 
+Quote Post
drozel
сообщение Nov 12 2015, 05:08
Сообщение #13


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

Группа: Свой
Сообщений: 108
Регистрация: 2-02-11
Пользователь №: 62 650



Цитата(jcxz @ Nov 12 2015, 10:42) *
Как правило: тот кто не хочет возиться с регистрами, возится с кучей кривых исходников написанных школьниками.

Я за среднее. Не люблю возиться с регистрами (тем не менее, знаю их и могу анализировать исходники), но и HAL - ужас.
Должна быть либа, абстрагирующая от регистров с четким todo. stdlib был ближе к моему идеалу, нежели HAL. libopencm3 - ничего
Go to the top of the page
 
+Quote Post
Tarbal
сообщение Nov 12 2015, 23:17
Сообщение #14


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

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



А у меня подход простой. Срочно надо сделать проект -- берем то, что проще заставить работать. По ходу те части, что работают неудовлетворительно перепишем. К сожалению нет времени заниматься перфекционизмом. Остаются компромисы.
Go to the top of the page
 
+Quote Post
MikleV
сообщение Nov 17 2015, 06:28
Сообщение #15


Участник
*

Группа: Участник
Сообщений: 66
Регистрация: 15-05-15
Пользователь №: 86 697



Подниму тему по аналогичному вопросу.
Есть STM32 с bsp кокос. Есть пины подключенные в ISM приемопередатчику и отслеживающие его состояния(помимо SPI связи с ним) Задача в обработчике прерывания запрещать и разрешать прерывания(в т.ч. в обработчике скажем void EXTI2_IRQHandler(void) его же и запрещать) ну и дополнительно переключать срабатывания по фронтам. Т.е четко отслеживать передний фронт и потом переключиться на отслеживание заднего фронта.
По запрещению и разрешению:
Сначала пробовал с помощью NVIC_EnableIRQ(); NVIC_DisableIRQ();
Потом написал поделку c использованием NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE/DISABLE
Работает на половину ((
Вопрос такой: надо ли после каждого такого телодвижения заново инициализировать PIN по пути GPIO->EXTI->NVIC?
К сожалению лог/анализатора нет и в схему также вносит значительные искажения отладка.
Go to the top of the page
 
+Quote Post

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

 


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


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