OpenEdv-开源电子网

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

有关数组设置字节对齐的问题

[复制链接]

30

主题

1170

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1993
金钱
1993
注册时间
2016-2-16
在线时间
527 小时
发表于 2016-9-21 11:07:17 | 显示全部楼层 |阅读模式
1金钱
本帖最后由 憨厚诚实大叔 于 2016-9-21 11:30 编辑

__align(32) u8 mem1base[MEM1_MAX_SIZE];            
__align(32) u8 mem2base[MEM2_MAX_SIZE] __attribute__((at(0X68000000)));   
类似这个,定义了2个u8的内存池,我硬件调试了下,发现他们每一个数组里面u8数据和u8数据都是挨着的,并不是一个u8占了32个字节,剩下的填充不用。也就是他们占了MEM1_MAX_SIZE和MEM2_MAX_SIZE个空间,而不是MEM1_MAX_SIZE*32和MEM2_MAX_SIZE*32个。也就是这个32字节对齐对于他们数组内部的数据存储是没有什么作用的。

这个字节对齐,首尾都要对齐,我的看法是对于第一个 __align(32) u8 mem1base[MEM1_MAX_SIZE]是内部内存池,加上32字节对齐后,内存为他分配的首地址就是32倍数的地址,然后内存块是32个一块。
加上这个__align(32)使得他分配出来的地址全部都是32字节对齐的,也就是地址是32的倍数。然后分配到的空间,4,8,16,32字节对齐都可以使用。

对于第二个__align(32) u8 mem2base[MEM2_MAX_SIZE] __attribute__((at(0X68000000))),我们已经为他分配了首地址了,而且分配的首地址已经是32字节对齐的了,所以我们把这一个__align(32)去掉也是没问题的。
不知道我说的对不对,求来个大神解答一下。
至于那些字节对齐的好处什么的就不要多说了,我只想知道我上面说的这些对么。不对的话,为什么这里要加__align(32)呢?


如果是这样的话,是不是在项目中,我们给结构体分配空间,要分配合适的首地址给他,就是4字节对齐的结构体,首地址要分配4的倍数的,8字节对齐的结构体,首地址要分配8的倍数的给他,是这样的么。

最佳答案

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

C语言的字节对齐 分配32字节的话先要和u8比较下 谁小按谁对齐 如果你是分配的4字节就和u8比较 发现比u8小 就按照4字节对齐 应该是这样的吧 我以前好像看过
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

13

主题

50

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
368
金钱
368
注册时间
2014-3-20
在线时间
76 小时
发表于 2016-9-21 11:07:18 | 显示全部楼层
C语言的字节对齐 分配32字节的话先要和u8比较下 谁小按谁对齐  如果你是分配的4字节就和u8比较 发现比u8小  就按照4字节对齐  应该是这样的吧  我以前好像看过
回复

使用道具 举报

30

主题

1170

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1993
金钱
1993
注册时间
2016-2-16
在线时间
527 小时
 楼主| 发表于 2016-9-21 11:11:41 | 显示全部楼层
回复

使用道具 举报

30

主题

1170

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1993
金钱
1993
注册时间
2016-2-16
在线时间
527 小时
 楼主| 发表于 2016-9-21 14:08:07 | 显示全部楼层
本帖最后由 憨厚诚实大叔 于 2016-9-21 14:14 编辑
陌上_花开 发表于 2016-9-21 13:24
C语言的字节对齐 分配32字节的话先要和u8比较下 谁小按谁对齐  如果你是分配的4字节就和u8比较 发现比u8小  ...

..............你多看看吧,按谁对齐是结构体里面总占内存的吧,那个需要内存大向那个对齐。
u8占一个字节,已经是最小的了。另外,你根本都没看我问什么。
回复

使用道具 举报

30

主题

1170

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1993
金钱
1993
注册时间
2016-2-16
在线时间
527 小时
 楼主| 发表于 2016-9-21 15:43:26 | 显示全部楼层
八嘎,没人解答的,不过根据我百度到的,以及看以前论坛大神的一些帖子,发现应该就是这样的了。
看完fatfs文件系统,叔就看实时系统去了。
回复

使用道具 举报

30

主题

1170

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1993
金钱
1993
注册时间
2016-2-16
在线时间
527 小时
 楼主| 发表于 2016-9-22 09:40:44 | 显示全部楼层
置顶,为什么这种问题没人帮忙的
回复

使用道具 举报

25

主题

683

帖子

0

精华

论坛大神

Rank: 7Rank: 7Rank: 7

积分
1351
金钱
1351
注册时间
2012-4-25
在线时间
195 小时
发表于 2016-9-22 15:06:30 | 显示全部楼层
根据我的经验,一般不需要强制写关键字 对齐,编绎器会帮你对齐的,你这只是申请内存池。无所谓对齐格式。
1-1
回复

使用道具 举报

25

主题

683

帖子

0

精华

论坛大神

Rank: 7Rank: 7Rank: 7

积分
1351
金钱
1351
注册时间
2012-4-25
在线时间
195 小时
发表于 2016-9-22 15:10:31 | 显示全部楼层
mygod 发表于 2016-9-22 15:06
根据我的经验,一般不需要强制写关键字 对齐,编绎器会帮你对齐的,你这只是申请内存池。无所谓对齐格式。
...

在程序中有时候会字节对齐出错,那是RAM相当吃紧时候 才会出现的。
举个例子。当前的结构体大小过大,全局变量过多。
平时使用时候定义结构体 就要注意让结构体大小为8的倍数.
1-1
回复

使用道具 举报

30

主题

1170

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1993
金钱
1993
注册时间
2016-2-16
在线时间
527 小时
 楼主| 发表于 2016-9-22 17:22:54 | 显示全部楼层
mygod 发表于 2016-9-22 15:10
在程序中有时候会字节对齐出错,那是RAM相当吃紧时候 才会出现的。
举个例子。当前的结构体大小过大,全 ...

申请内存池,你给一个4字节对齐的结构体申请了一个不是4的倍数的首地址,不会出问题么
回复

使用道具 举报

25

主题

683

帖子

0

精华

论坛大神

Rank: 7Rank: 7Rank: 7

积分
1351
金钱
1351
注册时间
2012-4-25
在线时间
195 小时
发表于 2016-9-23 08:35:40 | 显示全部楼层
憨厚诚实大叔 发表于 2016-9-22 17:22
申请内存池,你给一个4字节对齐的结构体申请了一个不是4的倍数的首地址,不会出问题么

stm32 中 结构体是4字节对齐的,如果你强制1字节对齐就有可能会出问题(概率也是很小的)
一般写MALLOC动态分配,都分考虑到 申请块是小单位 8字节,
1-1
回复

使用道具 举报

30

主题

1170

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1993
金钱
1993
注册时间
2016-2-16
在线时间
527 小时
 楼主| 发表于 2016-9-23 09:44:46 | 显示全部楼层
mygod 发表于 2016-9-23 08:35
stm32 中 结构体是4字节对齐的,如果你强制1字节对齐就有可能会出问题(概率也是很小的)
一般写MALLOC ...

考虑到最小单位是8字节的意思是,分配出来的首地址是8的倍数么
回复

使用道具 举报

25

主题

683

帖子

0

精华

论坛大神

Rank: 7Rank: 7Rank: 7

积分
1351
金钱
1351
注册时间
2012-4-25
在线时间
195 小时
发表于 2016-9-23 10:19:34 | 显示全部楼层
憨厚诚实大叔 发表于 2016-9-23 09:44
考虑到最小单位是8字节的意思是,分配出来的首地址是8的倍数么

能不要纠结这个问题行不
1-1
回复

使用道具 举报

36

主题

1105

帖子

5

精华

论坛大神

Rank: 7Rank: 7Rank: 7

积分
2200
金钱
2200
注册时间
2012-2-8
在线时间
35 小时
发表于 2016-9-23 10:20:22 | 显示全部楼层
我认为首地址对齐的说法是对的

"如果是这样的话,是不是在项目中,我们给结构体分配空间,要分配合适的首地址给他,就是4字节对齐的结构体,首地址要分配4的倍数的,8字节对齐的结构体,首地址要分配8的倍数的给他,是这样的么。"

我记得浮点数有 8 字节对齐的要求。具体要参考 STM32 的汇编相关的文档里面对对齐的说明,自己找找看.
https://github.com/roxma
回复

使用道具 举报

25

主题

683

帖子

0

精华

论坛大神

Rank: 7Rank: 7Rank: 7

积分
1351
金钱
1351
注册时间
2012-4-25
在线时间
195 小时
发表于 2016-9-23 10:22:47 | 显示全部楼层
憨厚诚实大叔 发表于 2016-9-23 09:44
考虑到最小单位是8字节的意思是,分配出来的首地址是8的倍数么

你问下别人搞单片机 这么多年的,做过这么多项目的,有多少人加这个_align(32) 关键字。
会出问题,肯定 你是RAM资源很紧张,或是你定义了大结构的结构体(是结构体,不是数组)
1-1
回复

使用道具 举报

30

主题

1170

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1993
金钱
1993
注册时间
2016-2-16
在线时间
527 小时
 楼主| 发表于 2016-9-23 10:34:35 | 显示全部楼层
mygod 发表于 2016-9-23 10:22
你问下别人搞单片机 这么多年的,做过这么多项目的,有多少人加这个_align(32) 关键字。
会出问题,肯定 ...

谢谢了,不过我百度到了比较详细的解释说明了
回复

使用道具 举报

12

主题

101

帖子

0

精华

高级会员

Rank: 4

积分
963
金钱
963
注册时间
2016-3-16
在线时间
109 小时
发表于 2016-11-23 19:54:26 | 显示全部楼层
  顶帖
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-5-25 10:29

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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