找回密码
 注册
关于网站域名变更的通知
查看: 384|回复: 3
打印 上一主题 下一主题

有没有什么方法能让arm编译器一次读16bit的数据啊?

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2019-10-14 15:53 | 只看该作者 |只看大图 回帖奖励 |倒序浏览 |阅读模式

EDA365欢迎您登录!

您需要 登录 才可以下载或查看,没有帐号?注册

x
最近在学习网卡驱动的编写,调试的时候发现接收数据的时候隔了16bit(本身的读写宽度是16bit),查看反汇编文件发现编译器在编译的时候把读取16bit数据的一次操作分成了2次8bit的读取操作,导致网卡读数据间隔16bit就是类似一下的情形) H: |' ?" ]2 c2 J! }

5 {/ x: T5 N* s2 A- j9 r$ Cint a = (*(volatile u16_t *) 0x20000000)3 a. _8 T8 b9 P/ J
& q( A5 l& n- F# b; A& Y9 n
编译后

' l. G# k: ~3 qldrb        r3, [r4]
9 e9 z* _1 [* W7 q/ qldrb        r1, [r4, #1]. F8 G0 G: u7 |( l1 v
orr        r1, r3, r1, lsl #8; l9 j; D' b: q4 F' _2 a7 y3 X

/ P: o5 Z) c. L" L有没有什么方法能让编译器一次读这16bit的数据啊?
4 `5 r5 V, f- ~: U( {" H
2 q2 m) Z- [3 _  u( C2 r' ^! |9 W+ _

$ U  R7 {& k( ]3 M# z
4 G# T: ^6 l; l  X& C
有没有什么方法能让ARM编译器一次读这16bit的数据啊?& A) X; y8 _- U, \/ y

该用户从未签到

2#
发表于 2019-10-14 18:46 | 只看该作者
这就比较奇怪了,编译器咋不用一条 LDRH 指令呢,得到答案之后@我一下,我也想知道

该用户从未签到

3#
发表于 2019-10-14 21:23 | 只看该作者
意思就是 *(volatile U16*)0x20000000强制转换16bit

该用户从未签到

4#
发表于 2019-10-14 21:24 | 只看该作者
5 M3 }1 y% p8 X
会不会是类型不一样
/ t( r3 w1 Z9 o# R4 i. K  N" f3 a
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

推荐内容上一条 /1 下一条

EDA365公众号

关于我们|手机版|EDA365电子论坛网 ( 粤ICP备18020198号-1 )

GMT+8, 2025-11-25 01:24 , Processed in 0.171875 second(s), 26 queries , Gzip On.

深圳市墨知创新科技有限公司

地址:深圳市南山区科技生态园2栋A座805 电话:19926409050

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