串口1中断服务函数的解析
来源:互联网 发布:最终信仰知轩 编辑:程序博客网 时间:2024/04/19 06:10
//串口1中断服务函数的解析
void USART1_IRQHandler(void)
u8 Res;
if(USART_GetITStatus(USART1, USART_IT_RXNE) != RESET) //接收到的数据必须是0x0d 0x0a结尾,RESET=0
{
Res =USART_ReceiveData(USART1); //读取接收到的数据
if((USART_RX_STA&0x8000)==0) //接收未完成
{
if(USART_RX_STA&0x4000) //接收到了0x0d
{
if(Res!=0x0a)USART_RX_STA=0; //接收错误重新开始
else USART_RX_STA|=0x8000; //接收完成了
}
else //还没接收到0x0d
{
if(Res==0x0d)USART_RX_STA|=0x4000;
else
{
USART_RX_BUF[USART_RX_STA&0X3FFF]=Res ;
USART_RX_STA++;
if(USART_RX_STA>(USART_REC_LEN-1))USART_RX_STA=0; //在接收数据超过 USART_REC_LEN 的时候,则会
丢弃前面的数据,重新接收。
}
}
}
}
// typedef enum {RESET = 0, SET = !RESET} FlagStatus, ITStatus; //RESET=0;
// u16 USART_RX_STA=0; //接收状态标记
///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
当接收到从电脑发过来的数据,把接收到的数据保存在 USART_RX_BUF 中,
同时在接收状态寄存器(USART_RX_STA)中计数接收到的有效数据个数,当
收到回车(回车的表示由 2 个字节组成:0X0D 和 0X0A)的第一个字节 0X0D
时,计数器将不再增加,等待0X0A 的到来,而如果 0X0A 没有来到,则认为
这次接收失败,重新开始下一次接收。如果顺利接收到 0X0A,则标记 USART_RX_STA
的第 15 位,这样完成一次接收,并等待该位被其他程序清除,从而开始下一次的接收,
而如果迟迟没有收到 0X0D,那么在接收数据超过 USART_REC_LEN 的时候,则会
丢弃前面的数据,重新接收。
计算机向串口发送一串字符,一般不止一个,例如发送”abcdefg回车“。那么串口中断
函数会执行9次,回车要执行两次串口中断。
当串口中断函数第一次执行时,USART1->DR里面装的是字符a,下面以串口第一次执行来分析这
个串口中断函数。
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
if(USART_GetITStatus(USART1, USART_IT_RXNE) != RESET); //这是判断读数据寄存器是否空,因为接受到了a,所以不是空的,这个判断成立。
Res =USART_ReceiveData(USART1); //(USART1->DR); 既然接受到了字符a,那么就要把他读取出来
if((USART_RX_STA&0x8000)==0); //因为现在接受的是第一个字符,所以接收肯定没有完成,USART_RX_STA还是它的初始化值,于是第15位还是0,
这个判断语句成立。于是要执行下面这句话
if(USART_RX_STA&0x4000) ; // USART_RX_STA的第14位仍然是0,所以这个判断不成立,所以会执行下面这句话
if(Res==0x0d); //当然这个判断也不成立,所以要执行下面这句话
USART_RX_BUF[USART_RX_STA&0X3FFF]=Res ; //计算出接收的是第几个字符,然后装到缓存里面
//0x3fff=0011 1111 1111 1111
USART_RX_STA++; //加1表明已经接收好了几个数据
void USART1_IRQHandler(void)
u8 Res;
if(USART_GetITStatus(USART1, USART_IT_RXNE) != RESET) //接收到的数据必须是0x0d 0x0a结尾,RESET=0
{
Res =USART_ReceiveData(USART1); //读取接收到的数据
if((USART_RX_STA&0x8000)==0) //接收未完成
{
if(USART_RX_STA&0x4000) //接收到了0x0d
{
if(Res!=0x0a)USART_RX_STA=0; //接收错误重新开始
else USART_RX_STA|=0x8000; //接收完成了
}
else //还没接收到0x0d
{
if(Res==0x0d)USART_RX_STA|=0x4000;
else
{
USART_RX_BUF[USART_RX_STA&0X3FFF]=Res ;
USART_RX_STA++;
if(USART_RX_STA>(USART_REC_LEN-1))USART_RX_STA=0; //在接收数据超过 USART_REC_LEN 的时候,则会
丢弃前面的数据,重新接收。
}
}
}
}
// typedef enum {RESET = 0, SET = !RESET} FlagStatus, ITStatus; //RESET=0;
// u16 USART_RX_STA=0; //接收状态标记
///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
当接收到从电脑发过来的数据,把接收到的数据保存在 USART_RX_BUF 中,
同时在接收状态寄存器(USART_RX_STA)中计数接收到的有效数据个数,当
收到回车(回车的表示由 2 个字节组成:0X0D 和 0X0A)的第一个字节 0X0D
时,计数器将不再增加,等待0X0A 的到来,而如果 0X0A 没有来到,则认为
这次接收失败,重新开始下一次接收。如果顺利接收到 0X0A,则标记 USART_RX_STA
的第 15 位,这样完成一次接收,并等待该位被其他程序清除,从而开始下一次的接收,
而如果迟迟没有收到 0X0D,那么在接收数据超过 USART_REC_LEN 的时候,则会
丢弃前面的数据,重新接收。
计算机向串口发送一串字符,一般不止一个,例如发送”abcdefg回车“。那么串口中断
函数会执行9次,回车要执行两次串口中断。
当串口中断函数第一次执行时,USART1->DR里面装的是字符a,下面以串口第一次执行来分析这
个串口中断函数。
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
if(USART_GetITStatus(USART1, USART_IT_RXNE) != RESET); //这是判断读数据寄存器是否空,因为接受到了a,所以不是空的,这个判断成立。
Res =USART_ReceiveData(USART1); //(USART1->DR); 既然接受到了字符a,那么就要把他读取出来
if((USART_RX_STA&0x8000)==0); //因为现在接受的是第一个字符,所以接收肯定没有完成,USART_RX_STA还是它的初始化值,于是第15位还是0,
这个判断语句成立。于是要执行下面这句话
if(USART_RX_STA&0x4000) ; // USART_RX_STA的第14位仍然是0,所以这个判断不成立,所以会执行下面这句话
if(Res==0x0d); //当然这个判断也不成立,所以要执行下面这句话
USART_RX_BUF[USART_RX_STA&0X3FFF]=Res ; //计算出接收的是第几个字符,然后装到缓存里面
//0x3fff=0011 1111 1111 1111
USART_RX_STA++; //加1表明已经接收好了几个数据
阅读全文
1 0
- 串口1中断服务函数的解析
- 中断服务函数的写法
- 串口中断服务程序代码集
- 嵌入式中断服务函数的编写要求
- 中断服务函数的编写要求
- stm32中断服务函数的机制
- 中断服务函数的过程_20160206
- 嵌入式中断服务函数的一些特点
- STM32中断入口地址与中断服务函数的关系
- ADS中调试中断函数时进不了中断服务函数的解决办法
- STM32的串口中断发送
- 串口的中断和接收
- STM32的串口空闲中断
- request_irq() 注册中断服务函数
- GCC-AVR 编写中断服务函数的注意事项
- 关于中断服务函数带来返回值的思考
- STM32是如何进入中断服务函数xxx_IRQHandler的
- 嵌入式软件-STM32串口中断函数
- 继承ViewGroup实现Scroll滑动效果
- 使用Kotlin编写6.0权限检查框架学习总结
- 初学者入门学习java的简介笔记(2)
- Git : Distributed version control system
- javac错误:javac不是内部或外部命令 也不是可运行的程序 解决方法
- 串口1中断服务函数的解析
- C# 之泛型详解
- 人脸识别之light_cnn
- spring session和Redis数据库实现单点登录功能
- Git使用(2)创建版本库
- 6 逻辑运算符
- Linux主流架构运维工作简单剖析
- Unity Animator与Animation对比
- AlertDialog自定义布局