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

 
 
 
Reply to this topicStart new topic
> stm32f100 Проблемы с настройкой DAC в RCC
shev
сообщение Oct 22 2010, 14:50
Сообщение #1





Группа: Новичок
Сообщений: 5
Регистрация: 23-08-07
Из: Minsk
Пользователь №: 30 011



Имеется плата с контроллером stm32f100c8, отладчик ULINK 2.
Код для настройки Reset and clock control (RCC) следующий:
Цитата
/******************* Clock Init ***********************/
void ClockInit(void){
RCC->CR = RCC_CR_HSION; /* Enable HSI */
while(!(RCC->CR & RCC_CR_HSIRDY)); /* Wait till HSI is ready */

RCC->APB2ENR = (RCC_APB2ENR_AFIOEN | RCC_APB2ENR_IOPAEN | RCC_APB2ENR_IOPBEN |
RCC_APB2ENR_IOPCEN | RCC_APB2ENR_IOPDEN | RCC_APB2ENR_ADC1EN | RCC_APB2ENR_TIM1EN);
RCC->APB1ENR = (RCC_APB1ENR_TIM2EN | RCC_APB1ENR_TIM3EN | RCC_APB1ENR_TIM4EN |
RCC_APB1ENR_SPI2EN | RCC_APB1ENR_TIM6EN | RCC_APB1ENR_TIM7EN | RCC_APB1ENR_DACEN);
}/******************* Clock Init ***********************/

Устанавливаются все биты кроме, тех что отвечают за DAC и TIM6,TIM7.
Контроллер работает, АЦП, таймеры, GPIO,
НО ЦАП не работает!!!
Обращение к его регистрам типа
Цитата
/void DACInit(void){
DAC->CR = DAC_CR_TEN1 ;
DAC->CR |= 0x7<<TSEL1_pos;
DAC->CR |= DAC_CR_EN1;

DAC->DHR12R1 = 0xfff/2; //for data
DAC->SWTRIGR |= DAC_SWTRIGR_SWTRIG1;
}/******************* DAC initialization ***********************/
ни к чему не приводит. Все регистры равны нулю.
Да впрочем это и логично, если бит DACEN(№29) в регистре RCC_APB1ENR равен 0.
Но почему он не устанавливается???

Кто нибудь работал с ЦАПом с stm32f100 ?
Помогите советом.
Go to the top of the page
 
+Quote Post
shev
сообщение Oct 25 2010, 11:22
Сообщение #2





Группа: Новичок
Сообщений: 5
Регистрация: 23-08-07
Из: Minsk
Пользователь №: 30 011



Народ! Неужели никто ЦАП не запускал в stm32f100 !??
Go to the top of the page
 
+Quote Post
scifi
сообщение Oct 25 2010, 19:30
Сообщение #3


Гуру
******

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



Цитата(shev @ Oct 22 2010, 18:50) *
Да впрочем это и логично, если бит DACEN(№29) в регистре RCC_APB1ENR равен 0.
Но почему он не устанавливается???

Кто нибудь работал с ЦАПом с stm32f100 ?
Помогите советом.

У меня ЦАП в STM32F100C4 работает. Чужие библиотеки не очень люблю, поэтому мой код инициализации выглядит так (лишнее убрано):
Код
#define REG32(addr)     (*(uint32_t volatile*)(addr))
#define PERIPH_BASE     0x40000000
#define REGBIT(reg,bit) REG32(PERIPH_BASE+0x2000000+((uint32_t)&(reg)-PERIPH_BASE)*32+(bit)*4)
#define RCC_BASE        (PERIPH_BASE + 0x21000)
#define RCC_APB1ENR     REG32(RCC_BASE + 0x1C)
#define DAC_BASE        (PERIPH_BASE + 0x7400)
#define DAC_CR          REG32(DAC_BASE + 0)
#define GPIOA_BASE      (PERIPH_BASE + 0x10800)
#define GPIOA_CRL       REG32(GPIOA_BASE + 0)

REGBIT(RCC_APB1ENR, 29) = 1; /* enable clocking of DAC */
DAC_CR = 1 << 16; /* DAC2 enable */
GPIOA_CRL = GPIOA_CRL & 0xFF0FFFFF; /* PA5 is AIN (DAC output) */
Go to the top of the page
 
+Quote Post
shev
сообщение Oct 26 2010, 08:02
Сообщение #4





Группа: Новичок
Сообщений: 5
Регистрация: 23-08-07
Из: Minsk
Пользователь №: 30 011



Попробовал у себя - не работает sad.gif
Пара вопросов:
Запускаете через отладчик ULINK 2 или через USART ?
Какая ревизия микросхемы (в правом нижнем углу на корпусе)?
Дело в том что на сайте st.com есть errata на rev. Z, а у меня rev. Y.
Может здесь проблема...?
Go to the top of the page
 
+Quote Post
scifi
сообщение Oct 26 2010, 09:25
Сообщение #5


Гуру
******

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



Цитата(shev @ Oct 26 2010, 12:02) *
Запускаете через отладчик ULINK 2 или через USART ?
Какая ревизия микросхемы (в правом нижнем углу на корпусе)?
Дело в том что на сайте st.com есть errata на rev. Z, а у меня rev. Y.
Может здесь проблема...?

Запускаю через ST-LINK, но это сути не меняет, так как всё работает и под отладчиком, и в боевом режиме.
Ревизию посмотрю чуть позже, но сомневаюсь, что дело в этом.
Может быть, у Вас STM32F101? Это почти такой же микроконтроллер, только ЦАПа там нет.
Я бы потщательнее поотлаживал. К примеру, в тестирующей программе делал бы запись регистров и их чтение (для контроля). Причём считанные значения сохранял бы в volatile-массиве и отладчиком смотрел именно содержимое массива, чтобы не зависеть от работы отладчика с регистрами. Нужно убедиться, что сброшен бит DACRST в RCC_APB1RSTR, установлен бит DACEN в RCC_APB1ENR, установлен бит EN1 или EN2 в DAC_CR, PA4 или PA5 сконфигурированы как Analog Input. Также следует проверить, что не превышены максимально допустимые тактовые частоты. Также проверить, не могут ли мешать обработчики прерываний, сторожевые таймеры и прочее.
Go to the top of the page
 
+Quote Post
shev
сообщение Oct 26 2010, 10:22
Сообщение #6





Группа: Новичок
Сообщений: 5
Регистрация: 23-08-07
Из: Minsk
Пользователь №: 30 011



Всё это уже пробовал.
Не устанавливается бит DACEN в RCC_APB1ENR - дальше можно и не смотреть.
А это по сути - одна строчка (из вашего примера)...
Интересно, что бит DACRST в RCC_APB1RSTR также не устанавливается.
Я уже всё лишнее выкинул, от HSI без PLL работаю - всё по дефолту.
Может контроллер левый... Хотя на вид очень даже красивый с маркировкой ST:
STM32
F100C8T6
9907N 93
MYS 947
ST e4 Y
Go to the top of the page
 
+Quote Post
scifi
сообщение Oct 26 2010, 11:57
Сообщение #7


Гуру
******

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



У меня маркировка такая:
STM32F100
C4T6B
990H1 93
MYS 018
ST e4 Z

Цитата(shev @ Oct 26 2010, 14:22) *
Не устанавливается бит DACEN в RCC_APB1ENR - дальше можно и не смотреть.
А это по сути - одна строчка (из вашего примера)...
Интересно, что бит DACRST в RCC_APB1RSTR также не устанавливается.


А вот это интересно. Если биты DACEN и DACRST не устанавливаются, то логично предположить, что ЦАПа там нет. Про ревизию Y на сайте ST - молчок. Может быть, в этой ревизии ЦАПа не было?
Go to the top of the page
 
+Quote Post
shev
сообщение Oct 29 2010, 06:46
Сообщение #8





Группа: Новичок
Сообщений: 5
Регистрация: 23-08-07
Из: Minsk
Пользователь №: 30 011



Вопрос решился следующим образом. Ответ техподдержки:

if you confirm that there is no B at the end of the product reference, then it is normal that the DAC is not working, as it is not present in the chip.

The real and final Value-Line products are the F100 with a B at the end, e.g. STM32F100C8T6B.

Before that these version was available, a preliminary version based on the F101 Access-Line was released as intermediary version (no B at the end), it does not include the DAC for example, and less timers. I assume this the rootcause.


Так что кому нужен ЦАП в stm32f100, берите с буквой B.
Go to the top of the page
 
+Quote Post

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

 


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


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