OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 2555|回复: 5

stm32f103c8t6接收mqtt丢失数据

[复制链接]

2

主题

10

帖子

0

精华

新手上路

积分
34
金钱
34
注册时间
2020-7-24
在线时间
4 小时
发表于 2020-7-24 16:36:34 | 显示全部楼层 |阅读模式
1金钱
在usart3接收emqtt客户端发送过来的数据会出现丢失的情况,在模拟mqtt客户端数据接收时候又不会出现数据丢失。相同的代码,在socket接收数据的时候也不会出现丢失
以下是我的串口中断
void DEBUG_USART3_IRQHandler()
{
        u8 RxData=0;
  if(USART_GetITStatus(USART3, USART_IT_RXNE) != RESET)
        {       
                RxData = USART_ReceiveData(USART3);
                uDatas.USART3_RX_BUF[uDatas.USART3_RX_STA]=RxData;
                uDatas.USART3_RX_STA++;
                uDatas.USART3_RX_STA &= 0x3F;
        }
        if(USART_GetFlagStatus(USART3,USART_FLAG_ORE) == RESET)
  {
    USART_ClearFlag(DEBUG_USART2,USART_FLAG_ORE);
  }
}


接收示例

发送心跳
心跳返回数据:208-0-0-0


这个是通讯猫接收的数据
[20/7/24 16:08:17 518]  MQTT[TOPIC:/njg/car]接收62字节:
[20/7/24 16:08:17 550]  {"macId":"CJXM19080001","message":{"w":1},"ty":0,"ot":3,"w":0}

这个是串口打印出来的信息,通讯猫是正常的

receive1接收:":3,"w":0}ar{"macId":"CJXM19080001","message":{"w":1},"ty":0,"ot-10-48
receive2接收:":3,"w":0}ar{"macId":"CJXM19080001","message":{"w":1},"ty":0,"ot-10-48
34-58-51-44
led1无数据
led2无数据
sg90无数据
l298n无数据



最佳答案

正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

2

主题

10

帖子

0

精华

新手上路

积分
34
金钱
34
注册时间
2020-7-24
在线时间
4 小时
 楼主| 发表于 2020-7-24 16:36:35 | 显示全部楼层
回复

使用道具 举报

2

主题

10

帖子

0

精华

新手上路

积分
34
金钱
34
注册时间
2020-7-24
在线时间
4 小时
 楼主| 发表于 2020-7-24 16:37:32 | 显示全部楼层
用的是stm32F103C8t6+esp8266+emqtt,别沉了
回复

使用道具 举报

2

主题

10

帖子

0

精华

新手上路

积分
34
金钱
34
注册时间
2020-7-24
在线时间
4 小时
 楼主| 发表于 2020-7-24 16:43:00 | 显示全部楼层
USART_ClearFlag(USART3,USART_FLAG_ORE);这边是这样的。贴上去的时候,我忘记修改了
回复

使用道具 举报

2

主题

10

帖子

0

精华

新手上路

积分
34
金钱
34
注册时间
2020-7-24
在线时间
4 小时
 楼主| 发表于 2020-7-25 11:18:41 | 显示全部楼层
原子哥啊,帮忙看看。谢谢
我进入仿真调试,第一个数据是0x30,但是实际上应该收到的数据是0x7B,这边就已经错了。在下一次进入的时候,
u8 ore = USART_GetFlagStatus(DEBUG_USART2,USART_FLAG_ORE);
u8 rxne = USART_GetITStatus(DEBUG_USART2, USART_IT_RXNE);
ore就变成1,rxne就变成了0.
我在这边卡了好久了。
回复

使用道具 举报

2

主题

10

帖子

0

精华

新手上路

积分
34
金钱
34
注册时间
2020-7-24
在线时间
4 小时
 楼主| 发表于 2020-7-25 11:19:48 | 显示全部楼层
但是在发送心跳包的时候,返回数据并不会进入溢出。
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-6-8 10:09

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表