OpenEdv-开源电子网

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

关于ZI-DATA过大的问题。

[复制链接]

6

主题

75

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
203
金钱
203
注册时间
2013-8-15
在线时间
44 小时
发表于 2017-12-24 22:07:02 | 显示全部楼层 |阅读模式
1金钱
本帖最后由 xyzjacky 于 2017-12-24 22:10 编辑

当前我有一个工程,用的是STM32F103RC的单片机。程序最近做了一点点改动,发现老是跑飞,当前分析后,可能是内存的使用出错(debug发现,程序并非停在某一句,而是完全不运行,反复点击RUN也没有用),朋友提醒说ZI-DATA过大,如下:

Program Size: Code=47984 RO-data=15872 RW-data=228 ZI-data=1049236  
在.map文件中看到的信息如下
    Total RO  Size (Code + RO Data)                63856 (  62.36kB)
    Total RW  Size (RW Data + ZI Data)           1050488 (1025.87kB)
    Total ROM Size (Code + RO Data + RW Data)      64084 (  62.58kB)

然后我的启动文件信息如下:
Stack_Size      EQU     0x00000400
Heap_Size       EQU     0x00000200


现在求教的是:
1. 有哪些原因会导致ZI-DATA过大?
2. 我程序跑飞是不是与Stack_Size小了,而ZI Data过大有关?

请原子哥和各位网友给个思路,在此拜谢!

最佳答案

查看完整内容[请看2#楼]

经过和原子哥的沟通,找到原因了,本来我只想使用mymemcpy和mymemset两个函数,但是我把开发板中内存管理的所有的代码全部复制过来了,导致编译后,编译器在内存中申请了很大的堆栈,虽然我只使用mymemcpy和mymemset两个函数。而今把其他没有用到的和内存管理相关的代码注释掉,ZI-DATA就小多了。 另一个办法是把启动文件中的Stack_Size改大,改成0x800,这样也没有问题。
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

6

主题

75

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
203
金钱
203
注册时间
2013-8-15
在线时间
44 小时
 楼主| 发表于 2017-12-24 22:07:03 | 显示全部楼层
经过和原子哥的沟通,找到原因了,本来我只想使用mymemcpy和mymemset两个函数,但是我把开发板中内存管理的所有的代码全部复制过来了,导致编译后,编译器在内存中申请了很大的堆栈,虽然我只使用mymemcpy和mymemset两个函数。而今把其他没有用到的和内存管理相关的代码注释掉,ZI-DATA就小多了。
另一个办法是把启动文件中的Stack_Size改大,改成0x800,这样也没有问题。
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165540
金钱
165540
注册时间
2010-12-1
在线时间
2117 小时
发表于 2017-12-25 00:38:12 | 显示全部楼层
用了内存管理吧??然后又没有外扩内存?
回复

使用道具 举报

6

主题

75

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
203
金钱
203
注册时间
2013-8-15
在线时间
44 小时
 楼主| 发表于 2017-12-25 15:12:53 | 显示全部楼层
正点原子 发表于 2017-12-25 00:38
用了内存管理吧??然后又没有外扩内存?

有用到了原子哥的malloc文件,但是只用了mymemcpy和mymemset两个函数。
mymemset这个函数是在初始化时用的,为的是把一些结构体变量清零。
其他的任何一个未用。
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165540
金钱
165540
注册时间
2010-12-1
在线时间
2117 小时
发表于 2017-12-26 00:54:23 | 显示全部楼层
xyzjacky 发表于 2017-12-25 15:12
有用到了原子哥的malloc文件,但是只用了mymemcpy和mymemset两个函数。
mymemset这个函数是在初始化时用 ...

在malloc.h里面,有定义数组的大小,好好看下我们教程,盖起来很简单
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

6

主题

75

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
203
金钱
203
注册时间
2013-8-15
在线时间
44 小时
 楼主| 发表于 2017-12-26 09:38:26 | 显示全部楼层
问题是我压根没有用内存管理这些个东西啊。
回复

使用道具 举报

6

主题

75

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
203
金钱
203
注册时间
2013-8-15
在线时间
44 小时
 楼主| 发表于 2017-12-26 09:39:20 | 显示全部楼层
正点原子 发表于 2017-12-26 00:54
在malloc.h里面,有定义数组的大小,好好看下我们教程,盖起来很简单

问题是我压根没有用内存管理这些个东西啊。
回复

使用道具 举报

3

主题

401

帖子

1

精华

金牌会员

Rank: 6Rank: 6

积分
1769
金钱
1769
注册时间
2015-6-11
在线时间
313 小时
发表于 2017-12-26 23:27:42 | 显示全部楼层
ZI-DATA都是声明为赋值的变量,如果你用战舰的程序改的,应该是内存管理文件里面有声明变量没注释掉,你全局搜attribute,看下
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165540
金钱
165540
注册时间
2010-12-1
在线时间
2117 小时
发表于 2017-12-27 01:21:23 | 显示全部楼层
xyzjacky 发表于 2017-12-26 09:39
问题是我压根没有用内存管理这些个东西啊。

和用不用无关,你不用就别添加这段代码。
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

6

主题

75

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
203
金钱
203
注册时间
2013-8-15
在线时间
44 小时
 楼主| 发表于 2017-12-27 10:05:18 | 显示全部楼层
正点原子 发表于 2017-12-27 01:21
和用不用无关,你不用就别添加这段代码。

我只保留了mymemcpy和mymemset两个函数,再重新编译,ZI-DATA就小多了。
下面是现在的编译信息,小多了。
Program Size: Code=49556 RO-data=15872 RW-data=236 ZI-data=6372
内存管理这些代码要占那么大的空间啊?仅仅编译了,就要占这么多?
有点沾染了放射物的感觉。以后见着这些东西,就慎用。
回复

使用道具 举报

6

主题

75

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
203
金钱
203
注册时间
2013-8-15
在线时间
44 小时
 楼主| 发表于 2017-12-27 10:11:06 | 显示全部楼层
zc123 发表于 2017-12-26 23:27
ZI-DATA都是声明为赋值的变量,如果你用战舰的程序改的,应该是内存管理文件里面有声明变量没注释掉,你全 ...

嗯嗯,找到原因了,感谢!
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-6-17 12:54

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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