|
|
  |
таймеры STM32F2xx |
|
|
|
May 31 2013, 21:34
|

Профессионал
    
Группа: Свой
Сообщений: 1 032
Регистрация: 13-03-08
Из: Маськва
Пользователь №: 35 877

|
Не получается разобраться с модулями таймеров в ST'шных контроллерах. Задача в следующем: по трём линиям сформировать три одиночных последовательных импульса длительностью T, "дёрнуть" прерывание, посчитать T на следующий цикл, снова сформировать импульсы и т.д. В общем случае количество линий может быть от 2 до 6, в данном случае, вроде б, ограничиваемся тремя.  На предыдущем изделии этим занимался модуль PWM в контроллере LPC, а тут - таймеров много, но как это сделать... Изучать, как запускать таймеры параллельно, не хочется. Должен быть более простой способ!
--------------------
Тут обсуждается творческий порыв, а не соответствие каким-либо стандартам ©
|
|
|
|
|
Jun 7 2013, 17:45
|
Участник

Группа: Участник
Сообщений: 59
Регистрация: 20-11-10
Пользователь №: 61 036

|
Если погрешность T может варьироваться в пределах до сотни тактов МК, то можно генерировать импульсы программно, как написал MK2.
|
|
|
|
|
Jul 3 2013, 20:34
|

Профессионал
    
Группа: Свой
Сообщений: 1 032
Регистрация: 13-03-08
Из: Маськва
Пользователь №: 35 877

|
Ну вот, платы готовы, таймер запущен.
Таймеры, надо заметить, крррайне замороченные. До меня дошли все тонкости только с третьего прочтения документации (до этого с STM не работал).
В итоге сделал на одном таймере и DMA, перезагружая TIM1->CCER новыми значениями.
Кстати, дурацкий вопрос: у меня очень странно заработал DMA: пока размер данных NDTR=1, регистры обновлялись в совершенно произвольные моменты времени. Переделал на NDTR=2, сделав 2 копии одной и той же переменной, стало хорошо. Размер данных - 16 бит в передатчике (память) и приёмнике (таймер). Как вариант, можно поставить 32 бита в приёмнике и передатчике, тогда работает с NDTR=1. Это какая-то бага, или я что-то где-то недочитал?
--------------------
Тут обсуждается творческий порыв, а не соответствие каким-либо стандартам ©
|
|
|
|
|
Jul 3 2013, 21:59
|
Участник

Группа: Участник
Сообщений: 59
Регистрация: 20-11-10
Пользователь №: 61 036

|
Cкорее всего, см. RM0008 (стр. 270) Addressing an AHB peripheral that does not support byte or halfword write operations
|
|
|
|
|
Jul 4 2013, 00:52
|
Местный
  
Группа: Свой
Сообщений: 294
Регистрация: 28-02-05
Из: Екатеринбург
Пользователь №: 2 925

|
Цитата(esaulenka @ Jun 1 2013, 03:34)  Не получается разобраться с модулями таймеров в ST'шных контроллерах. Задача в следующем: по трём линиям сформировать три одиночных последовательных импульса длительностью T, "дёрнуть" прерывание, посчитать T на следующий цикл, снова сформировать импульсы и т.д. В общем случае количество линий может быть от 2 до 6, в данном случае, вроде б, ограничиваемся тремя.  На предыдущем изделии этим занимался модуль PWM в контроллере LPC, а тут - таймеров много, но как это сделать... Изучать, как запускать таймеры параллельно, не хочется. Должен быть более простой способ! Проще всего, мне кажется, сделать на одном таймере, в обработчике прерывания дергать gpio.
|
|
|
|
|
Jul 4 2013, 08:18
|

Профессионал
    
Группа: Свой
Сообщений: 1 032
Регистрация: 13-03-08
Из: Маськва
Пользователь №: 35 877

|
Цитата(MarYuriy @ Jul 4 2013, 01:59)  Cкорее всего, см. RM0008 (стр. 270) Addressing an AHB peripheral that does not support byte or halfword write operations В RM0033 этого упоминания не нашёл. К тому же TIM1&TIM8 registers must be written by half-words (16 bits) or words (32 bits). (RM0033, page 332).
--------------------
Тут обсуждается творческий порыв, а не соответствие каким-либо стандартам ©
|
|
|
|
|
Jul 4 2013, 10:13
|
Участник

Группа: Участник
Сообщений: 59
Регистрация: 20-11-10
Пользователь №: 61 036

|
Цитата(esaulenka @ Jul 4 2013, 11:18)  В RM0033 этого упоминания не нашёл. К тому же TIM1&TIM8 registers must be written by half-words (16 bits) or words (32 bits). (RM0033, page 332). Извиняюсь, ночью было, не посмотрел, что серия F2.
|
|
|
|
|
  |
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0
|
|
|