Перейти к содержанию
    

Таймер для генерации импульсов

Сто раз уже эту байду обсуждали... :twak:

Никакой жёсткой синхронности такой метод не даёт, только с точностью +-трамвайная остановка и в тепличных условиях (когда CPU остановлен/спит, никакие другие bus-master-ы в системе не работают).

Достаточно хоть немного подумать головой что будет если в момент когда DMA нужно что-то переслать в GPIO-порт, шина окажется занятой (хоть всего на пару тактов). Будет постоянный джиттер фронтов сигналов, зависящий от приоритета DMA-каналов, работы других bus-master-ов в системе, кода выполняемого CPU, пятен на солнце...

Ну ну, там вполне измеряемый и вычисляемый джиттер, трамвайная остановка, это в прерывании ноги переключать.

Пятна на солнце призывать не надо, в системе не всегда один голый микроконтроллер.

 

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

А не надо ничего мудрить... и все получится...

Запустить два таймера синхронно... Первый формирует двойной импульс... второй - одиночный...

Началом отсчёта обоих таймеров принять спад второго импульса верхней эпюры...

 

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Задача решена на связке нескольких таймеров. За основу взяты три таймера TIM3, TIM2 и TIM1.

TIM3 отсчитывает длинные периоды по 15 мс по окончании счета тактирует TIM2 и TIM1 по ITR2.

TIM2 настроен как Slave, своим первым каналом он управляет портом МК в режиме PWM Generation. Обязательно включить One Pulse Mode.

TIM1 тоже настроен как Slave, и своим первым каналом он управляет портом МК в режиме PWM Generation. Обязательно включить One Pulse Mode и задать счет повторений Repetition Counter ( по моему эта функция есть только у Advanced-control timers).

Собственно все работает самостоятельно, без каких либо пользовательских прерываний. Поэтому синхронизация импульсов получается идеальная (видно на осциллограмме). Частоту можно задавать изменением тактирования частоты таймеров или изменением длительностей импульсов PWM.

Спасибо всем кто откликнулся на обсуждение. Если будут вопросы с удовольствием отвечу.

 

IMG_20180323_164425.jpg

 

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Задача решена на связке нескольких таймеров. За основу взяты три таймера TIM3, TIM2 и TIM1.

А почему так громоздко? На dual-SPI не получилось?

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Если не нужен дедтайм между каналами, то можно решить задачу на одном таймере и DMA. Первый сигнал представляется в виде двух последовательных широтно модулированных импульсов с различным периодом и скважностью. Второй сигнал аналогично, но в противоположной полярности, и с нулевой скважностью в одном такте из двух. Соотвественно настраиваем ШИМ режимы, и загрузку теневых ARR, CCR1, CCR2 через DMA burst при переполнении счётчика. DMA в кольцевом режиме на 6 слов по 16 бит.

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

А почему так громоздко? На dual-SPI не получилось?

Просто с таймерами я уже некоторое время провозился и более менее разобрался как их настраивать. А с dual-SPI мне нужно еще нужно разобраться, но я попробую. Если все получится то отпишусь в этой теме.

 

 

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Если не нужен дедтайм между каналами, то можно решить задачу на одном таймере и DMA. Первый сигнал представляется в виде двух последовательных широтно модулированных импульсов с различным периодом и скважностью. Второй сигнал аналогично, но в противоположной полярности, и с нулевой скважностью в одном такте из двух. Соотвественно настраиваем ШИМ режимы, и загрузку теневых ARR, CCR1, CCR2 через DMA burst при переполнении счётчика. DMA в кольцевом режиме на 6 слов по 16 бит.

Да нечто подобное подробно описано в Application note, который выложил A.Lex на первой страницы этого обсуждения глава называется: Arbitrary waveform generation using timer DMA-burst feature (стр. 45). Я не смог реализовать такую штуку для двух каналов одного таймера, но это скорее от недостатка опыта, думаю Ваша идея пригодится кому-то более опытному.

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Один таймер с двумя каналами и один элемент "исключающее или" в малом корпусе.

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Один таймер с двумя каналами и один элемент "исключающее или" в малом корпусе.

В предыдущем варианте устройства, было сделано на логике, сейчас была поставлена задача, все оптимизировать, если что-то может делать контроллер то логику исключить.

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Присоединяйтесь к обсуждению

Вы можете написать сейчас и зарегистрироваться позже. Если у вас есть аккаунт, авторизуйтесь, чтобы опубликовать от имени своего аккаунта.

Гость
Ответить в этой теме...

×   Вставлено с форматированием.   Вставить как обычный текст

  Разрешено использовать не более 75 эмодзи.

×   Ваша ссылка была автоматически встроена.   Отображать как обычную ссылку

×   Ваш предыдущий контент был восстановлен.   Очистить редактор

×   Вы не можете вставлять изображения напрямую. Загружайте или вставляйте изображения по ссылке.

×
×
  • Создать...