сообственно настраивал uart используя Standart Peripherals Library Drivers. Подключаю к ПК. Впринципе передача данных идёт, но не нашёл ни какой зависимости между тем что я шлю с stm32f407 Discovery и тем что получаю на ПК. Вот код на всякий случай. Когда МК посылает 1, ПК принимает FC00,2 - FE00,3-C000(E000),4-FE00,5-1C00(3C00),6-E000,7-0,8-FE00,9-FCFE00(FCFC00),10-1E00. У ПК настройки(baud rate, stop bits,etc) такие же как и UART1. Где здесь ошибка?
void main()
{
GPIO_InitTypeDef gpio;
// Запускаем тактирование
RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1, ENABLE);
RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOA, ENABLE);
// Инициализация нужных пинов контроллера, для USART1
gpio.GPIO_Pin = GPIO_Pin_9 | GPIO_Pin_10;
gpio.GPIO_Mode = GPIO_Mode_AF;
gpio.GPIO_Speed = GPIO_Speed_2MHz;
gpio.GPIO_OType = GPIO_OType_PP;
gpio.GPIO_PuPd = GPIO_PuPd_NOPULL;
GPIO_Init(GPIOA, &gpio);
GPIO_PinAFConfig(GPIOA, GPIO_PinSource9, GPIO_AF_USART1);
GPIO_PinAFConfig(GPIOA, GPIO_PinSource10, GPIO_AF_USART1);
usart.USART_Mode = USART_Mode_Rx | USART_Mode_Tx;
usart.USART_WordLength = USART_WordLength_8b;
usart.USART_BaudRate = 9600;
usart.USART_StopBits = USART_StopBits_1;
usart.USART_Parity = USART_Parity_No;
usart.USART_HardwareFlowControl = USART_HardwareFlowControl_None;
USART_Init(USART1, &usart);
// запускаем USART
USART_Cmd(USART1, ENABLE);
volatile uint16_t i=0;
while(1)
{
USART_SendData(USART1,i);
i++;
if(i>10)
i=0;
}
}
Програмирование UART1(STM32f407)
baud rate минимальный попробуйте
у меня "на проводах" уарт выше 2400 чепуху получает
у меня "на проводах" уарт выше 2400 чепуху получает
-
- Сообщения: 2
Не помогло. Единственное что изменилось,когда уменьшил baud rate на 600 и 1200,то что в режиме отладки, в пошаговом режиме, ПК принимает только '0'. Что интересно, когда запускаешь программу МК на исполнение НЕ в пошаговом режиме, значения, которые приходят на ПК, отличаются от тех, что в пошаговом.
-
- Сообщения: 88
- Откуда: Москва-Киров
1. Проверь адекватность baudrate. Для этого передавай 0x55 или 0xAA (т.е. меандр) и посмотри осцилографом реальный baudrate.
2. После передачи символа введи задержку в длину пакета. Тогда и в отладке и без отладки результат должен быть один и тот же.
2. После передачи символа введи задержку в длину пакета. Тогда и в отладке и без отладки результат должен быть один и тот же.
Добрый день,
1) проверьте тактовую частоту, если тактируетесь от внешнего кварца, проверьте правильность задания его частоты в заголовочнике либ.
2) вы примеры смотрели ? или хотя бы внутрь функции USART_SendData заглядывали ?
В ней не проверяется окончание передачи данных, следовательно не успев передать один байт вы уже впихиваете следующий и т.д.
1) проверьте тактовую частоту, если тактируетесь от внешнего кварца, проверьте правильность задания его частоты в заголовочнике либ.
2) вы примеры смотрели ? или хотя бы внутрь функции USART_SendData заглядывали ?
Код: Выделить всё
void USART_SendData(USART_TypeDef* USARTx, uint16_t Data)
{
/* Check the parameters */
assert_param(IS_USART_ALL_PERIPH(USARTx));
assert_param(IS_USART_DATA(Data));
/* Transmit Data */
USARTx->DR = (Data & (uint16_t)0x01FF);
}
В ней не проверяется окончание передачи данных, следовательно не успев передать один байт вы уже впихиваете следующий и т.д.
Вот может поможет
http://ziblog.ru/2011/04/18/stm32-ndash-usart-fifo.html
http://ziblog.ru/2011/04/18/stm32-ndash-usart-fifo.html
Вернуться в «Микроконтроллеры и ПЛИС»
Кто сейчас на конференции
Сейчас этот форум просматривают: нет зарегистрированных пользователей и 7 гостей