|
EDA365欢迎您登录!
您需要 登录 才可以下载或查看,没有帐号?注册
x
, U: Z" O, A4 @2 H! f一.存储器的字与半字2 w5 l# I9 ~: ?
6 f$ g* Z6 M1 k$ l9 ^
1.从偶数地址开始的连续的两个字节构成一个半字。
) d3 a+ r: l9 r4 J4 S, P
i. p: @8 R/ x2 Q" g; n2.能被4整除的地址的连续4个字阶构成一个字
: v6 U0 H, a" I; K) D# z
: d$ J, Z! h( M$ M2 OARM指令的长度刚好是一个字,Thumb指令的长度刚好是一个半字8 ~7 W. o2 B3 B' \( r6 i
; o* g: X) N8 n6 a; s% {. X; [二.存储器的存储方式(半字对齐,字对齐)- {. d7 P6 x! Y- U
" }8 @* p4 ~6 j$ E) A* _1 z$ H- F1.半字对齐:存放一个数据的地址如果能被二整除,则它是半字对齐。反之,则是非半字对齐。
' J& n+ ?* S6 ^0 r- W3 Q1 ^
8 n5 f" d8 W5 W: Q2.字对齐:存放一个数据的地址如果能被四整除,则它是字对齐。否则,它是非字对齐。- X0 @, M3 P! O* ~' M% X
9 o2 D! x% |; W2 X0 M6 F
' W% S+ k( m3 g. N- q+ B: w
, w2 D5 W" d, u$ H" I( p w
三.ARM处理器状态:
; G$ K& Q/ h" y
, e+ X6 f4 X8 w3 K' G [& rARM有两种处理器状态:ARM状态,Thumb状态。, ^, [* K1 s: T$ S+ c9 ^7 {
+ j; y& ~3 R$ |1. ARM状态:32位。处理器执行字方式的ARM指令。: o* v; W, i4 |9 s
" r$ C2 C- H' v9 K; |
2. Thumb状态:16位。处理器执行半字方式的Thumb指令。
2 @& A4 D) p1 C9 |9 j
5 k: z6 n' f6 V* m$ C注:两个状态之间的切换是不会影响处理器的模式或寄存器的内容。, x7 k z% y+ {, O" L4 w
( R. R/ U! T0 Q; S# O0 O- E# w; g它们之间是如何进行切换的。. g. S6 U# U; K% x S1 J, k
6 y$ J3 \ r; f. N
使用BX指令在ARM和Thumb状态之间进行切换。# f A; N2 h* }9 p9 `3 d+ n; f
5 W1 \( O. I" f2 |! n
(但是,所有的异常处理都是在ARM状态中执行。如果异常发生在Thumb状态中,处理器会切换到ARM状态。在异常处理返回时,自动切换回Thumb状态。)+ m- K! U; M5 Q0 r% s4 m
! m* F0 D- t/ ~8 A从ARM状态切换到Thumb状态的程序代码:
! k6 R. H& @+ H6 P# k
4 s7 G- j! K. p
( x- L, g- e7 z8 q2 k
; r* M, ~4 e2 G, A! x$ V
$ }; j% l2 x6 ]; @) l
- d2 O6 d/ |: }9 f& v( M
具体程序来说明处理器状态:! L- a, I8 ~+ L. t2 \; D2 ~4 o+ S
# y1 v0 J5 D) z' R程序1:
" z5 y4 j. [) J9 _9 j
+ m1 ^' |. @/ q* u& h. f
* a; `% g8 e6 Q' j
. G" h- x, n) T! L. C7 `" h- J
7 b+ i; Y, @* `ADR R0,TST+1
, A- o" x& B+ d. l8 I! d3 U
+ X& z3 W4 R, ~; z注:伪指令ADR将寄存器内容的地址存入寄存器中。这里将地址TST+1存入R0中,这样就加载了转移地址并且设置了最近有效位。! a$ O* Y; W. H1 j/ a: T' v
6 X! ~, P! \5 v( z" n# }* JBX R0
) q& S* X- G( w) V Q- [
( Y/ x+ X2 o" y2 W7 f3 O- c注:此时,R0中数值的第0位是1,所以该语句执行完处理器切换进入Thumb状态,开始执行Thumb指令; B* j) G, D% C c+ x, P' n1 Y
5 }, J& b; \% u7 y
(我们可以在AXD下看到此时状态寄存器的T位被置1.)
1 a3 T( t: W2 n0 q2 t! A" ~5 ~" O
( r3 }" f+ } y& E% |# w% Y) MCODE16$ a- ]9 q8 g# j& Z; H) \
- a, g: V9 e! c7 H' O8 ^! n注:
- R5 G3 `# r' }% {9 t
! g! W' A& I! k' k$ m$ U6 j9 kA汇编器需要知道什么时候产生ARM代码,什么时候产生Thumb 代码。8 R( M* w( C$ `: Q" ^/ t8 z) H
+ X# o5 M' _$ a0 U
B伪指令CODE16定义一下的程序被编译成Thumb模式,即后面的就是16位的Thumb指令了。* Z5 L' N3 j5 S' d! z& t( q5 H
5 ]0 w: M' o; [9 O/ u& _C.伪指令CODE32定义一下的程序将被编译成ARM模式,即后面的就是32位的ARM指令。# w1 t; u9 P* x9 W# |: u& V& m5 r
! s5 ~3 `% [: w9 K: K. A
D伪指令CODE16和CODE32只是指示汇编器后面指令的类型,并不产生任何代码,也不进行程序状态的切换。% V7 {4 j9 H2 g v
, C1 ]. i0 D( Y' @程序2:
: C8 u7 n" j! W( `3 }; z
2 f$ I' L! D+ \4 I( v1 ?
) [3 ~2 X$ U9 d) [, T
' M5 R% b5 ^4 D3 F! A7 R7 H% ]注:
4 @/ B& a+ `& x, N
4 p; X0 Y& a `- Y3 Q在Thumb状态下,调用软中断:SWI 0XAB5 `, k- y* m& {* [- M1 Q, U8 j0 n
$ _/ h4 }( ?3 ]8 ^ u在 ARM 状态下,调用软中断:SWI 0X123456/ Y8 ~8 F* V, _
7 q! B& H/ N- f4 b5 n四.ARM处理器模式:5 j4 H7 M' w5 i, |* K/ g, {
: Q N: c2 A2 `5 n. R0 O5 L: p. f- j
ARM体系结构支持7中处理器模式:用户模式,快中断模式,中断模式,管理模式,中止模式,未定义模式和系统模式。- i. x9 w3 d* ], o- R9 E
- k* I8 [* r% s; g, D
5 a- U( f# k, v7 v& E. m3 y4 G$ V2 ^4 M& p5 g2 j/ }% j
, l0 q9 h6 j% I6 x1.快中断模式,中断模式,管理模式,中止模式和未定义模式。它们称为异常模式。8 Z2 x3 s0 K) F9 b6 f( d8 H; ]
6 {$ i- D6 E; P4 L% W% C) i
A.异常模式既可以通过程序切换进入外,也可以有特定的异常进入。
- _9 |0 G4 ~8 z2 P) z- l* `, P
" T2 Z" I8 v8 n: RB.当特定的异常出现时,处理器进入相应饿模式。每种模式都有某些附加的寄存器。
% L% l `* g1 g6 [, @
1 B+ C$ z" V% |% t2.系统模式和用户模式,它们不能由异常进入。并且使用与用户模式相同的寄存器。
! p/ ]8 H/ m, K9 d% a( W8 U" e4 W0 V' O2 |+ V
A.系统模式是特权模式,不受用户模式的限制。操作系统在该模式下访问用户模式的寄存器比较方便。) Q( p+ n* T7 N+ P+ p4 s, b
, Q3 B1 N" s" X( R8 p6 Y* d五.ARM体系的存储系统
" C/ ~: R* K$ r6 W5 }4 m7 I6 w P+ p" _4 V1 W: E! T
1.ARM7存储系统概要:0 D/ [0 K ]8 |' U' }, b: p: K
6 _6 @" O7 i' s2 A4 ?1>.ARM7处理器采用冯.诺依曼结构,指令和数据共用一条32位数据总线(采用指令,数据和I/O统一编址)。, {& r" q9 g) q3 y( `; w0 a
5 x3 e+ y( c0 ^4 r
只有装载,保存和交换指令可访问存储器中的数据。" t- v" _3 s6 x
3 f( F* W0 ^6 n7 |) m
Tiger 补充:
1 G3 f4 ~* q3 l, k0 d1 y& a$ P3 s; q& i) |! C
计算机结构说明:
7 w: k& W F6 P- M. m" A4 n, J1 `" P
1> 冯诺依曼结构:把代码作为一中特殊的数据来操作。指令总线和数据总线及其存储区域是统一的。5 h3 @% Z8 D7 Y' s' L4 r
0 ~3 v' D, Q: _ 哈佛结构:指令总线和数据总线及其存储区域是分开独立的。& Y% A5 \( `0 N, o& M) J" Q) l
5 s4 `& B: ~+ j" B
* {) |/ V/ N8 C' D& F% s2>.ARM芯片一般在处理器核和外部存储器之间有
& }, Z6 D" t/ n+ d. T( w
( L$ S% k! Q. W1 e- `/ C; J一个存储器管理部件。0 H3 i6 C( c5 @
# Q; @/ ?& ]7 L: }* e, U存储器管理部件的作用是将局部总线的信号和时序转换为现实的外部总线信号和时序。
) l# \2 ^7 W/ x1 \5 N3 `
$ @* S+ u+ \" c; C( U5 c8 y
- H/ V3 E8 T% D1 I% H0 _9 k O: }, m0 l* k5 u
0 ]& U$ H ^4 W- g( y注:各芯片生产商制定了自己的外部总线的信号和时序。
" }6 D$ G ^: D! h+ Q q3 V/ z; X1 Y
3. 地址空间
) s/ {$ X$ b$ M ^
- K9 E& C# i( i1> ARM地址空间有232个8位字节的地址空间。也可以看作是230个32位字或231个16位半字。
+ @& G% U! S" ^2 ~
4 T" M( z- I" C$ n2> 如果在取指操作时地址发生溢出,只要没有执行预取的无效指令,就不会导致异常。* b& F, G( |2 Y9 D7 d5 g
: [- M! p# H. f# C
4. 存储器格式:# d2 \: T& s0 x) c4 O4 w
+ G# w( o" F: h+ B8 t2 X2 R1> 地址空间的规则要求一个字或半字要求连续存储。
# K) u# Q; w4 F3 |
7 o& E8 Q( a% S8 e$ EEg:位于地址0x02处的字,它所包含的字节位于地址0x02,0x03,0x04,0x5
4 |- J) x/ y# Z0 o+ o/ [# y6 N! X7 E
同理位于地址0x02处的半字,它所包含的字节位于地址0x02,0x03.0 u, N. \- P* e0 g4 _; E E
: Q0 L( E" t+ a! ^2> 存储器系统有两种映射机制:
O) ^9 W2 s! T' W, `- d" L
K& c, o1 m9 }! zA. 小端存储器系统:5 n' D' C% l8 c% C; r; `7 y1 h
& `; ^- y1 Y/ P: b- ^' Z
数据的高字节存放在高地址中。
7 V2 m' S7 X0 X1 S% D2 i* [0 B L# n
B. 大端存储器系统:! ?; H8 N* E) v! Y# }
' a! K! a. f9 C; J8 z3 ~: F5 _8 g; V数据的高字节存放在低地址中。
( x6 k' N8 z t; n3 m; D N' t$ ~! U+ ^8 d$ E
- { H9 N4 }, x. v2 N
_, a6 J( M- d8 i
4 d6 j- x; n9 a, C$ J3 o$ @! p4 g3>非对齐的存储器访问
9 E- u* ^2 V/ Q( ~2 _/ a# |9 e# j. }* ~2 A0 n
A. ARM结构希望所有存储器访问时都对齐。即字访问的地址是字对齐的,或半字访问使用的地址是半字对齐的。若不满足上述条件的即为非对齐的存储器访问。
2 b# {5 W$ x( T" o, G0 s1 E/ h7 v4 U( s* r8 d* G( ]/ @
B. 把一个非字对齐(或非半字对齐)的地址写入ARM状态(或Thumb状态的)R15寄存器中,将会引起非对齐的指令取指。
- }( E/ G# e" [- E# k3 X+ }7 `0 d7 a6 C) z
C. 在一个非字对齐(或非半字对齐)的地址处读写一个字或半字会引起非对齐的数据访问。( M$ X$ C6 d; ^
6 f: @. g+ W7 Z' k' }3 }9 d注:编程时应该注意的问题:% U6 t F6 y. t. {8 m6 n( ^
7 Y: _- x6 K- T! h k! [
ARM处理器直接支持对齐存放的半字或字数据的存取,也就是可以使用一条相应的指令来实现对应操作。如果访问非对齐的半字或字数据,将需要多条指令组合才能实现对应操作,这对程序的执行效率影响较大。因此,在C语言编程中,定义的多字节变量或结构体,最好使其为对齐存放。8 X" _, g s5 J& c7 B1 w3 {
. G0 I% u \0 H. K+ V. i
9 [- C, m4 q! D: l' ^8 O* C- h7 E) K' H, t5 l% A
|
|