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

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

[复制链接]

该用户从未签到

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

EDA365欢迎您登录!

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

x
最近在学习网卡驱动的编写,调试的时候发现接收数据的时候隔了16bit(本身的读写宽度是16bit),查看反汇编文件发现编译器在编译的时候把读取16bit数据的一次操作分成了2次8bit的读取操作,导致网卡读数据间隔16bit就是类似一下的情形
0 ^/ y5 n* h( J. T* R: q/ A! B0 |
% v* o$ v( {/ p( u0 Wint a = (*(volatile u16_t *) 0x20000000)& d: t' V6 @1 a( O

6 J9 L5 m6 w5 V/ A2 P, i编译后
- u' E! z6 |5 W) U
ldrb        r3, [r4]6 ?+ U5 D: X  t+ _
ldrb        r1, [r4, #1]5 K% X0 @. W' s. r+ s4 w' p
orr        r1, r3, r1, lsl #8
% U" K. L9 m5 B; o% _, [# `& Q. k
% T$ t8 l5 G5 D! G! K( E! ]! d/ I有没有什么方法能让编译器一次读这16bit的数据啊?

" m) n8 P  }& p/ }6 G+ @
" d3 b4 P$ k, G5 T3 K# g+ K+ \7 f- U7 V6 n! b
( |! S2 ~9 j4 d
有没有什么方法能让ARM编译器一次读这16bit的数据啊?
: ]7 i" M) g& B0 V' F

该用户从未签到

4#
发表于 2019-10-14 21:24 | 只看该作者
2 }( O5 a+ J$ H, c3 h
会不会是类型不一样4 W* _) h: r: c- V

该用户从未签到

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

该用户从未签到

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

本版积分规则

关闭

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

EDA365公众号

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

GMT+8, 2025-11-25 02:04 , Processed in 0.171875 second(s), 27 queries , Gzip On.

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

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

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