OpenEdv-开源电子网

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

相同变量声明static和非static全局变量缓冲区,影响UDP Task挂起,ping不通

[复制链接]

6

主题

47

帖子

0

精华

初级会员

Rank: 2

积分
86
金钱
86
注册时间
2017-4-15
在线时间
12 小时
发表于 2021-6-24 13:00:54 | 显示全部楼层 |阅读模式
3金钱
芯片:STM32F767 512K RAM 512K FLASH开发板:正点原子阿波罗

IDE:STM32CubeIDE
工程:FreeRTOS + WLIP + UDP Task + TCP Task + Main Task + CAN Task,


描述:当前工程存在以上四个任务,每个任务都有对应信号量以及互斥锁。每个Task对应一个指定唯一的全局缓冲区结构体。大小不一。

遇到问题:
    1. 定义 static 全局静态变量缓冲区udpBuff,这个缓冲区为结构体嵌套。数据大小为 200 * 300字节。对应UDP任务接收缓存数据。
  
    2. UDP相关任务


   出现的现象:UDP任务while不执行,感觉init在accept中等待外部连接,但是通过ping,无法ping通,网络助手连接不上。导致UDP,无法正常运行。
   注意:Main 任务,CAN,任务正常运行,系统状态灯,运行!


   3.CubeIDE观察RAM使用, (为了验证是否是栈堆内存溢出,特意扩大缓冲区大小,几乎占满RAM)


超大缓冲区



   4. 将上面的缓冲区更改为,非static 的全局变量缓冲区,然后刷如系统,其余不做任何改变。发现可以ping通,然后可以通过,网络调试助手链接UDP。进行信息交互
   5. 查看RAM内存,发现非 static的内存地址变了,


其他,没做任何改变!现在UDP Task (Main,CAN这个一直都可以,在两种声明下)可以正常运行


综上所述,为什么static声明一个全局变量,会影响到 udp的task运行以及链接,为什么会ping不通???!!!!

第二种测试:那个缓冲区设置过32K。RAM总利用率48%,其他不变,和上面状况一样!验证缓冲区大小不影响这个,



求助大佬,给一些建议解惑一下!!!!!!

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

使用道具 举报

6

主题

156

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
464
金钱
464
注册时间
2021-4-28
在线时间
158 小时
发表于 2021-6-24 14:02:01 | 显示全部楼层
回复

使用道具 举报

12

主题

3344

帖子

1

精华

论坛元老

Rank: 8Rank: 8

积分
8465
金钱
8465
注册时间
2020-5-11
在线时间
3904 小时
发表于 2021-6-24 14:13:54 | 显示全部楼层
"静态全局变量则限制了其作用域, 即只在定义该变量的源文件内有效, 在同一源程序的其它源文件中不能使用它"
看看是不是别的文件又定义了同名的变量.
专治疑难杂症
回复

使用道具 举报

6

主题

47

帖子

0

精华

初级会员

Rank: 2

积分
86
金钱
86
注册时间
2017-4-15
在线时间
12 小时
 楼主| 发表于 2021-6-24 17:06:49 | 显示全部楼层
LcwSwust 发表于 2021-6-24 14:13
"静态全局变量则限制了其作用域, 即只在定义该变量的源文件内有效, 在同一源程序的其它源文件中不能使用 ...

最基本的这个还是能搞明白。不是这个原因
回复

使用道具 举报

12

主题

3344

帖子

1

精华

论坛元老

Rank: 8Rank: 8

积分
8465
金钱
8465
注册时间
2020-5-11
在线时间
3904 小时
发表于 2021-6-24 17:11:12 | 显示全部楼层
hanxi0529 发表于 2021-6-24 17:06
最基本的这个还是能搞明白。不是这个原因

工程发上来瞧瞧
专治疑难杂症
回复

使用道具 举报

6

主题

47

帖子

0

精华

初级会员

Rank: 2

积分
86
金钱
86
注册时间
2017-4-15
在线时间
12 小时
 楼主| 发表于 2021-6-24 17:12:52 | 显示全部楼层

目前工程暂时不能全发。。。公司的工程。。。
回复

使用道具 举报

6

主题

47

帖子

0

精华

初级会员

Rank: 2

积分
86
金钱
86
注册时间
2017-4-15
在线时间
12 小时
 楼主| 发表于 2021-6-24 17:13:19 | 显示全部楼层

q 809485914  我可以截图给你 能加嘛?谢谢
回复

使用道具 举报

12

主题

3344

帖子

1

精华

论坛元老

Rank: 8Rank: 8

积分
8465
金钱
8465
注册时间
2020-5-11
在线时间
3904 小时
发表于 2021-6-24 17:19:56 | 显示全部楼层
hanxi0529 发表于 2021-6-24 17:13
q 809485914  我可以截图给你 能加嘛?谢谢

不好意思,我突然想起来,我没用过FreeRTOS,也没有这开发板,恐怕帮不了你。
建议编译后打开.map文件看看两种定义方式下内存分配有啥区别。
专治疑难杂症
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-2-27 14:00

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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