本帖最后由 颩色四葉愺 于 2015-2-4 20:35 编辑
STM32F411一共有三个串口,分别是串口一,串口二和串口六。这个串口折腾了好多好多天,说多了都是泪,我一开始就上串口二,没想到串口二是个坑!!!!!使劲调都调不通,最后还是放弃先,之后试了试串口一和串口六,一试就通!
别跟我说是不是硬件问题,或者说是不是串口二的时钟没开之类的!都不是!!!!!我调通串口一和串口六之后,试了试用stn32的专用库来试试,我擦想死的心都有,一下就成了!!!别烦我先,我一个人想静静,别问静静是谁! 为什么标准库不行!!!!请广大网友解决这个问题能发发善心告诉我,这里我奉上我调通的三个串口源码。(串口一和串口六我都写好接收中断了,串口二仅仅写好了发送的没写接收的)
(1)建立工程,新建工程的步骤就不说了!请参考我之前的帖子:
STM32F411【Nucleo】第一课--新建工程(基于keil 5.13)
(2)新建bsp_usart.c和bsp_usart.h
bsp_usart.c
- #include "bsp_usart.h"
- void NVIC_USART1_Config(void)
- {
- NVIC_InitTypeDef NVIC_InitStructure;
- NVIC_PriorityGroupConfig(NVIC_PriorityGroup_1);
-
- NVIC_InitStructure.NVIC_IRQChannel=USART1_IRQn;
- NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority=0x00;
- NVIC_InitStructure.NVIC_IRQChannelSubPriority=0x02;
- NVIC_InitStructure.NVIC_IRQChannelCmd=ENABLE;
- NVIC_Init(&NVIC_InitStructure);
- }
- void USART1_Config(void)
- {
- GPIO_InitTypeDef GPIO_InitStructure;
- USART_InitTypeDef USART_InitStructure;
-
-
- RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOA , ENABLE);
- RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1, ENABLE);
- //串口1对应引脚复用映射
- GPIO_PinAFConfig(GPIOA, GPIO_PinSource9, GPIO_AF_USART1);
- GPIO_PinAFConfig(GPIOA, GPIO_PinSource10, GPIO_AF_USART1);
-
- GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9|GPIO_Pin_10;
- GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF;
- GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
- GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;
- GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_NOPULL;
- GPIO_Init(GPIOA, &GPIO_InitStructure);
-
- NVIC_USART1_Config();
- USART_InitStructure.USART_BaudRate=115200;
- USART_InitStructure.USART_WordLength=USART_WordLength_8b;
- USART_InitStructure.USART_StopBits=USART_StopBits_1;
- USART_InitStructure.USART_Parity=USART_Parity_No;
- USART_InitStructure.USART_HardwareFlowControl=USART_HardwareFlowControl_None;
- USART_InitStructure.USART_Mode=USART_Mode_Rx|USART_Mode_Tx;
-
- USART_Init(USART1,&USART_InitStructure);
-
- USART_ITConfig(USART1,USART_IT_RXNE,ENABLE);
-
- USART_Cmd(USART1,ENABLE);
- }
- /// 重定向c库函数printf到USART1
- int fputc(int ch, FILE *f)
- {
- /* 发送一个字节数据到USART1 */
- USART_SendData(USART1, (uint8_t) ch);
-
- /* 等待发送完毕 */
- while (USART_GetFlagStatus(USART1, USART_FLAG_TC) == RESET);
-
- return (ch);
- }
- /// 重定向c库函数scanf到USART1
- int fgetc(FILE *f)
- {
- /* 等待串口1输入数据 */
- while (USART_GetFlagStatus(USART1, USART_FLAG_RXNE) == RESET);
- return (int)USART_ReceiveData(USART1);
- }
- /*********************************************END OF FILE**********************/
复制代码
bsp_usart.h
- #ifndef _BSP_USART_H_
- #define _BSP_USART_H_
- #include "stm32f4xx.h"
- #include <stdio.h>
- void USART1_Config(void);
- #endif
复制代码
(3)修改stm32f4xx_it.c
- void USART1_IRQHandler(void)
- {
- char c;
- if(USART_GetITStatus(USART1, USART_IT_RXNE) != RESET)
- {
- c=USART_ReceiveData(USART1);
- USART_SendData(USART1,c);
- }
- }
复制代码
编译下载后利用USB转串口下载器进行通信(大家可以利用市面上的开发板的串口部分),打开串口助手后,给板子复位后
温馨提示,如果你要用串口二则板子的A2 和A3外引接口是没有跟MCU链接的 不过ST-link中的RX ,TX就是连上MCU的串口二的 我们也可以往这连!
串å£1.zip
(8.55 MB, 下载次数: 2223)
|
你看吧 这个是我已经用串口二成功的了USART2的例程 硬件保持刚回来的样子 不用修改任何地方即可 附件后缀改7Z后解压
Nucleo411UART2.zip
2015-2-5 10:12 上传
点击文件名下载附件
251 KB, 下载次数: 571
如果是下载程序的串口 那么就可能你是说的用串口一了,答案是可以的,这样你就的外接一个USB转串口的东西了,其中串口一对应的引脚是PA9(TX),PA10(RX)。如果你的意思是使用那个板子上的下载器所虚拟出来的串口,那么就不能这么做了,下载器上所使用的串口是串口二,串口二对应的接口为PA2(TX),PA3(RX)。
然后我这里有一个工程,你可以直接选择下载进去,串口使用起来很方便的,就好像C语言里面的printf一样,举例:printf("Hello STM32 Nucleo!"); 就通过串口二向电脑输出了Hello STM32 Nucleo!
Nucleo411Model_åç¼æ¹7z.zip
2015-6-12 10:08 上传
点击文件名下载附件
251 KB, 下载次数: 140
串口二也不完全是坑,可以用的,我用串口2很久了。
看看你的ST-LINK什么版本,建议升级到最新的ST-LINK V2-1 在电脑里有一个虚拟串口,或者用TTL转USB串口连接也能实现的。
支持一下
标准库写的 还是HAL库 我用HAL库写的也没问题啊 用标准库写的就出问题了
好像找到原因了。我再研究研究
没事 能用就行了 嘿嘿 相互学习。。。
是软件上printf不能执行,还是软件编译烧写了但是串口没接收到数据? 如果你用到串口二那样硬件上要改动一下,如果是软件上printf不能执行,那可能你没有勾选使用USB MicroLIB这个选项