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

 
 
2 страниц V  < 1 2  
Reply to this topicStart new topic
> STM32: запуск АЦП от TIM1
koyodza
сообщение Feb 8 2012, 20:41
Сообщение #16


Местный
***

Группа: Свой
Сообщений: 213
Регистрация: 28-02-07
Из: Киев
Пользователь №: 25 744



Цитата(Юрий_СВ @ Feb 7 2012, 21:38) *
У меня работает. (Надеюсь, таймер и канал сравнения настроены)

Ну и где там TIM1 ?
Проблема была не в запуске АЦП в принципе, а в его запуске от TIM1.
Цитата(Юрий_СВ @ Feb 8 2012, 13:33) *
В самый раз. Номер канала меняется в прерывании.
1) между преобразованиями надо, как минимум, управлять внешними коммутаторами.
4) переношу большую программу с другого ядра (AVR) - переписывать пол программы - ради чего ?

Я Вам уже на сахаре говорил: не нужно пытаться использовать здесь старые навыки. Это вам не АВР, какими ещё "внешними коммутаторами" Вы тут управляете? 16-канального встроенного мало?
Встроенным мультиплексором АЦП управляет сам, нужно только его настроить, дальше он будет переключать каналы и складывать результаты куда нужно (если ещё и DMA настроено).
Цитата(Юрий_СВ @ Feb 8 2012, 16:37) *
- для обычных (regular) каналов (5-й и 6-й)
- запуск от таймер 1, канал1
Последовательный перебор каналов не используется - следующий канал выбирается после очередного преобразования.

Это только вручную. Но ЗАЧЕМ делать через *опу если можно сделать нормально?
Цитата(Юрий_СВ @ Feb 8 2012, 14:10) *
Надеюсь, вы шутите. Если человек хоть пару раз пролистывал описание МК - то у него всё необходимое есть.

Человек даже не посчитал нужным сказать какие каналы он использует: обычные или вклинивающиеся.
(для них предусмотрены совершенно разные источники запуска)
А вы мне предлагаете трактат на 3 страницы писать ?

Да, не посчитал, и у меня были на то основания: TIM1 должен работать и с regular и с injected каналами (только разные модули сравнения используются).

Цитата(Юрий_СВ @ Feb 8 2012, 14:10) *
Для него ведь важно:
1) Что это хоть у кого-нибуть работоспособно (у меня работает)

Я использую этот МК с 2007г, Вы - только три недели. АЦП у меня используется в каждом проекте, просто не было необходимости запускать его именно от TIM1. Или Вы думаете, [CENSORED]?

Цитата(Юрий_СВ @ Feb 8 2012, 14:10) *
2) настройка битов регистра ADC1_CR2
// EXTTRIG=1 ; // запуск преобразования обычного канала по внешнему сигналу - разрешен
// EXTSEL=000; // источник внешнего запускающего сигнала для обычного канала - таймер 1, канал 1

Практически каждый бит подписан по-русски - неужели "убеждения" не позволят их поменять под себя?

Это меня не интересует.

Цитата(Юрий_СВ @ Feb 8 2012, 14:10) *
Трудностей с отключением инверсных выходов таймера 1 у меня тоже не было. Работает нормально.

Они обязательно появятся, когда Вам понадобится использовать одновременно 4 таймера с выводом 3-4 каналов каждого таймера наружу, 2 SPI, UART, несколько каналов АЦП и всё это в малоногом корпусе. Вот тогда и полезут глюки, связанные с ремапом и невозможностью использования некоторой периферии одновременно

Сообщение отредактировал IgorKossak - Feb 9 2012, 08:19
Go to the top of the page
 
+Quote Post
Юрий_СВ
сообщение Feb 9 2012, 12:13
Сообщение #17


Участник
*

Группа: Участник
Сообщений: 73
Регистрация: 4-05-08
Пользователь №: 37 272



Цитата(koyodza @ Feb 8 2012, 23:41) *
Ну и где там TIM1 ?

// EXTSEL=000; // источник внешнего запускающего сигнала для обычного канала - таймер 1, канал 1

Если бы вы более точно выражали свои мысли - ответ был бы более точным.
Вас могло интересовать:
1) сама возможность запуска (т.е. не являются ли ваши трудности ошибкой кристалла) - я ответил
2) настройки АЦП (иногда влияет полседовательность действий или в очередной доке могло быть изменено значение EXTSEL) - я ответил
3) настройка таймера 1 (сами знаете - очень объёмная, для обычных каналов АЦП - особенностей нет) - решил пока не вываливать - если нужно будет - спросите
4) разрешение синхронизации и настройка выводов (тут вообще всё просто - если надо спросите)

А раз вы не уточнили что из этого вам нужно - дал наиболее актуальное (на своё усмотрение) 2 пункта из 4-х.
На зеркало пинять....

Цитата(koyodza @ Feb 8 2012, 23:41) *
Я Вам уже на сахаре говорил: не нужно пытаться использовать здесь старые навыки. Это вам не АВР, какими ещё "внешними коммутаторами" Вы тут управляете? 16-канального встроенного мало?
Встроенным мультиплексором АЦП управляет сам, нужно только его настроить, дальше он будет переключать каналы и складывать результаты куда нужно (если ещё и DMA настроено).
Это только вручную. Но ЗАЧЕМ делать через *опу если можно сделать нормально?

Я знаю, что вселенская мудрость доступна только вам biggrin.gif

А на АВР нет встроенного коммутатора ? Есть. Значит, наверное, есть причины использовать внешний ?
(мне 16 не надо, мне надо 4 входа, но внешний)
ПДП здесь .. не очень полезен. Требуется расчитывать и выставлять управляющее воздействие между выборками.

А на счёт "не нужно пытаться использовать здесь старые навыки".
Знать бы ещё что вы имеете в виду. Надеюсь, что-то более содержательное, чем многократное повторения этой фразы.
На сахере я задавал вопрос о том где описано время исполнения инструкций.
Вместо ответа вы многократно повторяли фразу "не нужно пытаться использовать здесь старые навыки".
Другой человек дал исчерпывающий ответ на вопрос. Ему огромное спасибо.

Ведь принципиальных различий между AVR и Cortex M3 не так и много.
Прежде всего:
- разрядность
- особенности работы конвеера, выборки команд и буферезации
- общее поле памяти и возможность запуска из ОЗУ (и отсутствие EEPROM в STM32F10x)

Даже набор регистров у них похож, не в пример различиям между STM32 и STM8.

Сообщение отредактировал Юрий_СВ - Feb 9 2012, 12:18
Go to the top of the page
 
+Quote Post
koyodza
сообщение Feb 9 2012, 15:28
Сообщение #18


Местный
***

Группа: Свой
Сообщений: 213
Регистрация: 28-02-07
Из: Киев
Пользователь №: 25 744



Цитата(Юрий_СВ @ Feb 9 2012, 14:13) *
// EXTSEL=000; // источник внешнего запускающего сигнала для обычного канала - таймер 1, канал 1

Дело не в выборе источника запуска. Я использовал Timer 2 CC2 event, Timer 3 TRGO event, Timer 4 CC4 event и даже EXTI line 11, проблем не было. Проблемы были не в настройке АЦП, а в таймере, который не отдавал Timer 1 CCх event. И именно об этом и ставился тогда вопрос.

Цитата(Юрий_СВ @ Feb 9 2012, 14:13) *
А раз вы не уточнили что из этого вам нужно - дал наиболее актуальное (на своё усмотрение) 2 пункта из 4-х.

Спасибо, больше можете не беспокоиться. Ваши советы меня не интересуют.

Цитата(Юрий_СВ @ Feb 9 2012, 14:13) *
мне 16 не надо, мне надо 4 входа, но внешний

Бывает и так, но это, скажем, "не совсем обычная задача", и тут уж Вам бы следовало описать её подробнее.

Цитата(Юрий_СВ @ Feb 9 2012, 14:13) *
Ведь принципиальных различий между AVR и Cortex M3 не так и много.
Даже набор регистров у них похож, не в пример различиям между STM32 и STM8.

Если бы я раньше не слышал от одного грамотея фразу "MSP и DSP похожи", признал бы это лучшим анекдотом про микроконтроллеры.
Хотя, конечно, чем-то они таки похожи: корпус и там и там квадратненький чёрненький. Регистры у AVR и ARM тоже с одинаковой буквы обозначены biggrin.gif

А ссылки на документацию по ядру я Вам на сахаре не дал сознательно, потому как считаю путь подсчёта тактов изначально ущербным применительно к ARM, и ещё потому, что не считаю эту информацию необходимой начинающему.
Обычно я пытаюсь дать не то, что просят, а то, что нужно просящему
Go to the top of the page
 
+Quote Post
MiklPolikov
сообщение Apr 13 2012, 22:00
Сообщение #19


Гуру
******

Группа: Свой
Сообщений: 2 015
Регистрация: 23-01-07
Из: Москва
Пользователь №: 24 702



Пытаюсь запустить АЦП от события TIM6_TRGO
Не понимаю : почему на схеме таймера событие TIM6_TRGO возникает в каком-то Trigger Controller , а не в нижней части
схемы, где счётный регистр сравнивается с auto-reload регистром ?

Выбрал в регистре CR2 в битах MMS возникновение события TRGO при Update .
Код
TIM6->CR2|=TIM_CR2_MMS_1;
АЦП запускается, но только один раз. Хотя прерывания от таймера происходят, т.е. он работает.
Эскизы прикрепленных изображений
Прикрепленное изображение
 


--------------------
Если у Вас нет практического опыта в данной теме- не вступайте в дискуссию и не пишите никаких теоретических рассуждений! Заранее спасибо !
Go to the top of the page
 
+Quote Post
scifi
сообщение Apr 14 2012, 08:24
Сообщение #20


Гуру
******

Группа: Свой
Сообщений: 3 020
Регистрация: 7-02-07
Пользователь №: 25 136



Цитата(MiklPolikov @ Apr 14 2012, 02:00) *
Не понимаю : почему на схеме таймера событие TIM6_TRGO возникает в каком-то Trigger Controller , а не в нижней части схемы, где счётный регистр сравнивается с auto-reload регистром ?

Потому что выход TRGO может выводить и другие сигналы, а не только сигнал переполнения (Update). Контроллер коммутирует соответствующий сигнал. Посмотрите на более полнофункциональные таймеры TIM1, TIM8 - там это очевидно. TIM6 - это урезанная версия таймера.

Цитата(MiklPolikov @ Apr 14 2012, 02:00) *
Выбрал в регистре CR2 в битах MMS возникновение события TRGO при Update .
Код
TIM6->CR2|=TIM_CR2_MMS_1;
АЦП запускается, но только один раз. Хотя прерывания от таймера происходят, т.е. он работает.

Тут нужно смотреть подробнее на конфигурацию таймера и АЦП.
Go to the top of the page
 
+Quote Post
MiklPolikov
сообщение Apr 14 2012, 10:53
Сообщение #21


Гуру
******

Группа: Свой
Сообщений: 2 015
Регистрация: 23-01-07
Из: Москва
Пользователь №: 24 702



Цитата(scifi @ Apr 14 2012, 11:24) *
Тут нужно смотреть подробнее на конфигурацию таймера и АЦП.


Посмотрите ?
Я правильно понимаю, что под отладкой в KEIL ни как нельзя посмотреть возникло ли событие TRGO , и создать его руками тоже нельзя ?


CODE
//////////////настраиваем таймер 6//////////////////////////
void TIMER6_INIT(void)
{
RCC->APB1ENR |= RCC_APB1ENR_TIM6EN; // включаем тактирование TIM7

TIM6->CR1|=TIM_CR1_URS|TIM_CR1_CEN;
TIM6->DIER|=TIM_DIER_UIE; // разрешение прерывания
TIM6->PSC=0xFF; // делитель
TIM6->ARR=0xFF; // макс. значение
TIM6->CR2|=TIM_CR2_MMS_1;//выбрали событие Update в качестве триггера TRGO

NVIC_SetPriority(TIM6_IRQn, 1);
NVIC_EnableIRQ(TIM6_IRQn);

//////////////////настраиваем АЦП/////////////////////////
void ADC_INIT(void)
{
RCC->APB2ENR |= RCC_APB2ENR_ADC1EN; //включаем тактирование АЦП

ADC1->CR2|=ADC_CR2_ADON; //включили АЦП
while(!(ADC1->SR & ADC_SR_ADONS)){} // ждём пока включится

ADC1->CR1|=ADC_CR1_PDI; //power down между преобразованиями

ADC1->CR1|=ADC_CR1_RES_1; // 8 бит

ADC1->CR2|=ADC_CR2_EXTEN_0; // преобразование по переднему фронту внешнего сигнала
ADC1->CR2|=ADC_CR2_EXTSEL_1|ADC_CR2_EXTSEL_3; //преобразование по TIM6_TRGO event

ADC1->SQR5|=(1<<0); //1 преобразование в цепочке 1 канал

ADC1->CR2|=ADC_CR2_EOCS; //прерывание при завершении преобразование всей группы ???

ADC1->CR1|=ADC_CR1_EOCIE; // включаем прерывание end of conversion
}
}


Сообщение отредактировал IgorKossak - Apr 14 2012, 15:31
Причина редактирования: [codebox]


--------------------
Если у Вас нет практического опыта в данной теме- не вступайте в дискуссию и не пишите никаких теоретических рассуждений! Заранее спасибо !
Go to the top of the page
 
+Quote Post
MiklPolikov
сообщение Apr 14 2012, 21:20
Сообщение #22


Гуру
******

Группа: Свой
Сообщений: 2 015
Регистрация: 23-01-07
Из: Москва
Пользователь №: 24 702



Разобрался. Оказалось что АЦП не хочет запускатся второй раз , если выставлен флаг OVR в регистре SR.
Код который я привёл выше - работает, если добавить сброс OVR в прерывании от АЦП

Но я не понимаю :
1)Почему флаг OVR выставляется даже если я читаю регистр DR в прерывании.
2)Если в группу преобразований можно добавить несколько каналов, а регистр с данными DR всё равно только 1, то какой смысл в группе ?
И как потом в прерывании понять, от какого канала из группы данные в DR ?


--------------------
Если у Вас нет практического опыта в данной теме- не вступайте в дискуссию и не пишите никаких теоретических рассуждений! Заранее спасибо !
Go to the top of the page
 
+Quote Post
koyodza
сообщение Apr 15 2012, 13:29
Сообщение #23


Местный
***

Группа: Свой
Сообщений: 213
Регистрация: 28-02-07
Из: Киев
Пользователь №: 25 744



Цитата(MiklPolikov @ Apr 14 2012, 23:20) *
Но я не понимаю :
1)Почему флаг OVR выставляется даже если я читаю регистр DR в прерывании.
2)Если в группу преобразований можно добавить несколько каналов, а регистр с данными DR всё равно только 1, то какой смысл в группе ?
И как потом в прерывании понять, от какого канала из группы данные в DR ?

А зачем это делать в прерывании? В этом МК это лучше делать с помощью DMA, мультиплексор будет переключаться автоматически и данные будут сами перебрасываться в буфер. Это как раз то, что я имел в виду, когда говорил, что нужно отказываться от старого подхода в работе
Go to the top of the page
 
+Quote Post

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

 


RSS Текстовая версия Сейчас: 24th June 2025 - 17:18
Рейтинг@Mail.ru


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