STM32F103定义的全局变量 ,运行一段时间 ,全局变量被修改

在自己的产品测试中 子机正常模式下运行毫无问题 都正常

但是远程主机端 一直发送数据 ,就会导致产品lcd花屏 串口死机

而且显示lcd花屏 串口后面才死机的的 两者死机间隔时间有长有短 不必深究,通过其他没有接在总线上的子机对比来看 是串口惹的货。

lcd花屏 肯定是全局变量自己变化了的 是内存泄露或者覆盖问题

串口接收死机 并非子机死机 ,而是串口接收不到数据了。

实验中 接收不到数据的现象可以分为下面原因

1 这里的接收不到数据我们不能单一的理解为串口中断死掉了 这是不可能的(通常情况下)

2 我们接收中断被发射中断阻挡了即 发送中断 一直在发数据(之前是死循环等待发送完成 而呈现中有看门狗 所以这种情况也很小 不过现在我还是加上超时处理了)

3 接收中断中接收的 管道形式的buf 一直接收超出了管道值 那么管道没有清空的同时 管道没有继续接收了 算是溢出了吧 同时造成了内存泄露(非常有可能)

当前修改了修改了接收中断中数据进行初步过滤来处理每时每刻总线上的无用数据。

当前修改了这个的方面测函数 程序正在测试中 耐心等待吧

STM32F103定义的全局变量 ,运行一段时间 ,全局变量被修改_第1张图片

STM32F103定义的全局变量 ,运行一段时间 ,全局变量被修改_第2张图片

测试了 发现lcd不花屏了 但是某一时刻 还是出现了 “ 串口死掉 ”的现象

然后我在程序中 估计仍然是接收问题 程序设计中管道接收满了 就不接收了 。即当子机数据只进不出的现象出现时 一段时间后管道就装满了 这之后 就造成了接收的数据丢掉了。当前的措施是管道移动 就是丢掉头上的数据 尾巴上放入新的数据 这样就的现象就是老的数据 你不来取 我就扔掉了。后面的新的数据 依次接入 当前思路是这样的 不知道行不行 待测试中

STM32F103定义的全局变量 ,运行一段时间 ,全局变量被修改_第3张图片

 

 

你可能感兴趣的:(stm32,串口总线)