关于对齐

本文详细探讨了在cortexA9的UBoot上直接操作内存时遇到的地址对齐问题,通过实例说明如何正确进行四字节对齐以避免程序崩溃,并提供了强制转换的方法以实现对任意地址的访问。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

昨天在cortex A9的uboot上直接操作内存是遇到了一些问题,跟对齐有关,现总结如下。我当初是这样操作的:*(vu_long *)0x0fffffff = 0xa5;但是此操作会失败,cpu重启,开始的时候以为是数据对齐的问题,把 *(vu_long *)0x0fffffff = 0xa5改为*(vu_long *)0x0fffff00 = 0xa5可以正常操作,因位cortex A9是32位的,所以,访问的时候要4字节对齐,这其实就是地址对齐,其实只要地址的最后两位是00也就是地址是4的倍数,就是四字节对齐,也就是说只要地址是0xxxxxxxxc的都是合法的地址。但是这样不能对任意字节进行访问,发现了(vu_long *),这就是强制转换使地址为四字节对齐,把vu_long *改为char *之后就可以对任意地址进行访问了。

很基础的问题,总结一下...

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值