专家
公告
财富商城
电子网
旗下网站
首页
问题库
专栏
标签库
话题
专家
NEW
门户
发布
提问题
发文章
STM32
串口通信,包头+数据+加校验
2019-08-12 17:56
发布
×
打开微信“扫一扫”,打开网页后点击屏幕右上角分享按钮
站内问答
/
STM32/STM8
8395
4
1172
搞了好久,查各种资料,终于搞好了
友情提示:
此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
4条回答
Anyint
2019-08-13 03:55
请问楼主一个问题,你的串口1中断代码里面有RxBuffer,在串口1接受中断读取电脑发过来的数据,uart_check()函数中却没有对RxBuffer这个变量操作,而且还有这个函数中还对USART_RX_BUF这个变量操作了,请问这个USART_RX_BUF是原子哥之前写的那个中断服务程序里接受的那个变量,你在串口1中断服务程序里没有读过USART_RX_BUF,为什么在uart_check里有对USART_RX_BUF又读操作?我有点不明白,还望楼主指点迷津
void USART1_IRQHandler(void) //串口1中断服务程序
{
u8 Res;
//接收中断
if( USART_GetITStatus(USART1,USART_IT_RXNE) )
{
USART_ClearITPendingBit(USART1,USART_IT_RXNE);//??????
Res =USART_ReceiveData(USART1);
//串口检验
// USART_SendData(USART1, Res);//向串口1发送数据
// while(USART_GetFlagStatus(USART1,USART_FLAG_TC)!=SET);//等待发送结束
RxBuffer[conter]=Res;
conter++;
//Data_Receive_Prepare(Res);
}
int uart_check(u8* data_rec)
{
u8 i=0;u16 sum_check=0;
u8 state=0;u8 x=0;
// u8* data_rec=USART_RX_BUF;
while(conter>=4)
{
for(x=0;x<4-1;x++) //去掉最后一个数(校验和)
{
sum_check+=data_rec[x]; //校验和
}
sum_check=sum_check;
if(USART_RX_BUF[i]==0x0D) //帧头
{
i++;
state+=1;
}
else { conter =0;i=0;return 0; }
if(USART_RX_BUF[i]!=0x0A&&state==1) //帧头
{
state=2;
}
else {conter=0;i=0;return 0;}
if(sum_check==data_rec[3]&&state==2) return 1; //校验和
else {conter=0;i=0;return 0;}
}
}
加载中...
查看其它4个回答
一周热门
更多
>
相关问题
STM32F4上I2C(在PROTEUS中模拟)调试不通的问题
6 个回答
芯片供应紧张,准备换个MCU,MM32L系列替换STM32L系列的怎么样?
7 个回答
STM32同时使用两个串口进行数据收发时数据丢包的问题
5 个回答
STM32F103串口通信死机问题
4 个回答
STM32WLE5CC连接SX1268在LoRa模式下能与 SX1278互通吗?
2 个回答
相关文章
ST公司第一款无线低功耗单片机模块有效提高物联网设计生产效率
0个评论
如何实现对单片机寄存器的访问
0个评论
通过USB用STM32片内自带Bootloader下载程序及注意事项
0个评论
欲练此功必先自宫之STM32汇编启动,放慢是为了更好的前行
0个评论
×
关闭
采纳回答
向帮助了您的知道网友说句感谢的话吧!
非常感谢!
确 认
×
关闭
编辑标签
最多设置5个标签!
STM32
保存
关闭
×
关闭
举报内容
检举类型
检举内容
检举用户
检举原因
广告推广
恶意灌水
回答内容与提问无关
抄袭答案
其他
检举说明(必填)
提交
关闭
×
打开微信“扫一扫”,打开网页后点击屏幕右上角分享按钮
×
付费偷看金额在0.1-10元之间
确定
×
关闭
您已邀请
0
人回答
查看邀请
擅长该话题的人
回答过该话题的人
我关注的人
void USART1_IRQHandler(void) //串口1中断服务程序
{
u8 Res;
//接收中断
if( USART_GetITStatus(USART1,USART_IT_RXNE) )
{
USART_ClearITPendingBit(USART1,USART_IT_RXNE);//??????
Res =USART_ReceiveData(USART1);
//串口检验
// USART_SendData(USART1, Res);//向串口1发送数据
// while(USART_GetFlagStatus(USART1,USART_FLAG_TC)!=SET);//等待发送结束
RxBuffer[conter]=Res;
conter++;
//Data_Receive_Prepare(Res);
}
int uart_check(u8* data_rec)
{
u8 i=0;u16 sum_check=0;
u8 state=0;u8 x=0;
// u8* data_rec=USART_RX_BUF;
while(conter>=4)
{
for(x=0;x<4-1;x++) //去掉最后一个数(校验和)
{
sum_check+=data_rec[x]; //校验和
}
sum_check=sum_check;
if(USART_RX_BUF[i]==0x0D) //帧头
{
i++;
state+=1;
}
else { conter =0;i=0;return 0; }
if(USART_RX_BUF[i]!=0x0A&&state==1) //帧头
{
state=2;
}
else {conter=0;i=0;return 0;}
if(sum_check==data_rec[3]&&state==2) return 1; //校验和
else {conter=0;i=0;return 0;}
}
}
一周热门 更多>