完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
扫一扫,分享给好友
USART串口中断插着RX线说啥也不进,一拔下来就进去了
下面是 中断函数 void USART1_IRQHandler() { printf("successful!!!!n"); Delay_Ms(1000); } 中断配置 void Init_NVIC(void) { NVIC_InitTypeDef NVIC_InitStructure; NVIC_InitStructure.NVIC_IRQChannel = USART1_IRQn; NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 2; NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0; NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE; NVIC_Init(&NVIC_InitStructure); } USART配置void Init_Usart(void) { RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA | RCC_APB2Periph_USART1,ENABLE); //使能各个端口时钟,重要!!! GPIO_InitTypeDef GPIO_InitStructure; //定义一个GPIO结构体变量 GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING; //浮空输入(复位状态); GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10; GPIO_Init(GPIOA, &GPIO_InitStructure); //根据参数初始 PIOA寄存器 GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; //配置端口速度50M GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP; //复用功能输出开漏 GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9; //配置串口接收端口挂接到9端口TX GPIO_Init(GPIOA, &GPIO_InitStructure); //根据参数初始化GPIOA寄存器 } void Usart_Configuration(uint32_t BaudRate) { USART_InitTypeDef USART_InitStructure; //定义一个串口结构体 USART_InitStructure.USART_BaudRate =BaudRate ; //波特率115200 USART_InitStructure.USART_WordLength = USART_WordLength_8b; //传输过程中使用8位数据 USART_InitStructure.USART_StopBits = USART_StopBits_1; //在帧结尾传输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_ITConfig(USART1,USART_IT_RXNE,ENABLE); USART_Init(USART1, &USART_InitStructure); //根据参数初始化串口寄存器 USART_Cmd(USART1, ENABLE); //使能串口外设 } main函数(): int main(void) { SystemInit(); Init_Usart(); Usart_Configuration(115200); Init_NVIC(); Init_LED(); while(1); while(1)//只要插着RX就始终在这个循环里,一拔下来就跳到中断里 { LED1=~LED1; Delay_Ms(200); } } 求大神指教,实在不知道哪里出了问题!! |
|
相关推荐
3个回答
|
|
中断服务函数里要检查一下读数据寄存器非空位是否被置位if(USART_GetITStatus(USART1, USART_IT_RXNE) != RESET),如果被置位则说明接收寄存器中有数据需要读取,读取数据后该位自动清零(USART_ReceiveData(USART1)),你的程序里好像没有读数据功能,所以该位一直为高。不读数据也行,用上面的If后用USART_ClearITPendingBit(USART1, USART_IT_RXNE);清除中断标志位,当再用串口发数据时才会中断
最佳答案
|
|
|
|
这个中断主要依靠接受完成位置一,置1又需要接受到8位数据加一位停止位,顺这个路一个一个排除咯
|
|
|
|
中断服务函数里应该加上判断USART_IT_RXNE标志位,
if(USART_GetITStatus(USART1, USART_IT_RXNE) != RESET) { printf("successful!!!!n"); } |
|
|
|
你正在撰写答案
如果你是对答案或其他答案精选点评或询问,请使用“评论”功能。
1950 浏览 1 评论
AD7686芯片不传输数据给STM32,但是手按住就会有数据。
1809 浏览 3 评论
4389 浏览 0 评论
如何解决MPU-9250与STM32通讯时,出现HAL_ERROR = 0x01U
1960 浏览 1 评论
hal库中i2c卡死在HAL_I2C_Master_Transmit
2463 浏览 1 评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2024-12-18 10:14 , Processed in 0.742628 second(s), Total 76, Slave 60 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号