TA的每日心情 | 难过 2019-11-20 15:02 |
---|
签到天数: 1 天 [LV.1]初来乍到
|
EDA365欢迎您登录!
您需要 登录 才可以下载或查看,没有帐号?注册
x
在学习网卡驱动的编写,调试的时候发现接收数据的时候隔了16bit(本身的读写宽度是16bit),查看反汇编文件发现编译器在编译的时候把读取16bit数据的一次操作分成了2次8Bit的读取操作,导致网卡读数据间隔16bit就是类似一下的情形
" r6 q4 j, W9 R& {" K( }: v
. [3 J( f2 t% r2 A9 X- ?/ T7 j6 Lint a = (*(volatile u16_t *) 0x20000000)
) B' b4 J9 G" B! ?8 P2 {( I0 q
" i( s( E- J, G1 m/ z编译后+ {: N% g- L$ _# Z/ b& W
ldrb r3, [r4]
$ w7 d7 e" _& \2 Qldrb r1, [r4, #1]
. m3 M6 y" N' W2 V5 n$ X @orr r1, r3, r1, lsl #8
5 k* p/ F2 Y9 b3 [2 s$ K7 j( D @/ e; P5 g( |: T# O
有没有什么方法能让编译器一次读这16bit的数据啊?- l' a; _" n% w! {" x& {/ \
|
|