13139|10

72

帖子

0

TA的资源

一粒金砂(初级)

楼主
 

为什么keil用__at()在固定地址定义const常量时RO-data数量会增加? [复制链接]

const  u8  HZK16[] /*__at(0x08020000)*/ ={ 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
#ifdef FONTS
0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
0,0,0,0,48,0,30,0,15,0,7,0,0,0,0,0,
0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
0,0,0,0,60,0,102,0,102,0,102,0,60,0,0,0,
............................
}//此为字库
此时编译
Program Size: Code=47628 RO-data=131344 RW-data=548 ZI-data=21228  
FromELF: creating hex file...
".\out\Center.axf" - 0 Error(s), 0 Warning(s).

然后
const  u8  HZK16[] __at(0x08020000) = {
..............................
}和上面为同一字库
此时编译
Program Size: Code=47628 RO-data=212628 RW-data=548 ZI-data=21228  
FromELF: creating hex file...
".\out\Center.axf" - 0 Error(s), 0 Warning(s).
其中两次RO-data差距很大.基本上差了一个字库的数据量,这是为什么呢?
此帖出自stm32/stm8论坛

最新回复

                                 重新试验结果 const  u8  HZK16[] /*__at(0x08010000)*/ = { 编译 Program Size: Code=48424 RO-data=131344 RW-data=552 ZI-data=21224   FromELF: creating hex file... ".\out\Center.axf" - 0 Error(s), 0 Warning(s). const  u8  HZK16[] __at(0x08010000) = { 编译 Program Size: Code=48424 RO-data=146296 RW-data=552 ZI-data=21224   FromELF: creating hex file... ".\out\Center.axf" - 0 Error(s), 0 Warning(s). const  u8  HZK16[] __at(0x08020000) = { 编译 Program Size: Code=48424 RO-data=211832 RW-data=552 ZI-data=21224   FromELF: creating hex file... ".\out\Center.axf" - 0 Error(s), 0 Warning(s). 结果如下: 211832 - 146296 = 65536 = 0x10000,也就是说编译器将数组最后一个字节存储地址之前的没有用到的地方全部算为RO-data.应该是这个样子的. 非常感谢各位的关注!!  详情 回复 发表于 2009-12-30 20:03
点赞 关注
 

回复
举报

74

帖子

0

TA的资源

一粒金砂(初级)

沙发
 
                                 补充一下,keil版本为3.8a.
此帖出自stm32/stm8论坛
 
 

回复

74

帖子

0

TA的资源

一粒金砂(初级)

板凳
 
                                 你知道RO-data是什么吗?
此帖出自stm32/stm8论坛
 
 

回复

59

帖子

0

TA的资源

一粒金砂(初级)

4
 
                                 是不是Read Only啊
此帖出自stm32/stm8论坛
 
 
 

回复

73

帖子

0

TA的资源

一粒金砂(初级)

5
 
                                 const数据要归到RO-DATA的,虽然可能还是在ram里,通过指针一样能修改,但是这部分数据的属性就是RO-DATA
此帖出自stm32/stm8论坛
 
 
 

回复

75

帖子

0

TA的资源

一粒金砂(初级)

6
 
                                 但是为什么用不用__at的编译结果不同呢?
此帖出自stm32/stm8论坛
 
 
 

回复

68

帖子

0

TA的资源

一粒金砂(初级)

7
 
怀疑是这个数组没有被使用过,如果不用__at的话就直接给优化掉了。
只是江湖术士的猜测,请勿采信。
此帖出自stm32/stm8论坛
 
 
 

回复

80

帖子

0

TA的资源

一粒金砂(初级)

8
 
                                 程序中是有调用的,而且两种的汉字显示都正常.
此帖出自stm32/stm8论坛
 
 
 

回复

72

帖子

0

TA的资源

一粒金砂(初级)

9
 
                                 直接打开link list或者map文件查查就知道了。
此帖出自stm32/stm8论坛
 
 
 

回复

70

帖子

0

TA的资源

一粒金砂(初级)

10
 
把map文件贴出来就一目了然了。
猜测是虽然强制定位到后面,但是计算的依然是完整块的大小。
此帖出自stm32/stm8论坛
 
 
 

回复

75

帖子

0

TA的资源

一粒金砂(初级)

11
 
重新试验结果
const  u8  HZK16[] /*__at(0x08010000)*/ = {
编译
Program Size: Code=48424 RO-data=131344 RW-data=552 ZI-data=21224  
FromELF: creating hex file...
".\out\Center.axf" - 0 Error(s), 0 Warning(s).

const  u8  HZK16[] __at(0x08010000) = {
编译
Program Size: Code=48424 RO-data=146296 RW-data=552 ZI-data=21224  
FromELF: creating hex file...
".\out\Center.axf" - 0 Error(s), 0 Warning(s).

const  u8  HZK16[] __at(0x08020000) = {
编译
Program Size: Code=48424 RO-data=211832 RW-data=552 ZI-data=21224  
FromELF: creating hex file...
".\out\Center.axf" - 0 Error(s), 0 Warning(s).

结果如下:
211832 - 146296 = 65536 = 0x10000,也就是说编译器将数组最后一个字节存储地址之前的没有用到的地方全部算为RO-data.应该是这个样子的.

非常感谢各位的关注!!
此帖出自stm32/stm8论坛
 
 
 

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

随便看看
查找数据手册?

EEWorld Datasheet 技术支持

相关文章 更多>>
关闭
站长推荐上一条 1/10 下一条

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

About Us 关于我们 客户服务 联系方式 器件索引 网站地图 最新更新 手机版

站点相关: 国产芯 安防电子 汽车电子 手机便携 工业控制 家用电子 医疗电子 测试测量 网络通信 物联网

北京市海淀区中关村大街18号B座15层1530室 电话:(010)82350740 邮编:100190

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved
快速回复 返回顶部 返回列表