| 
									
										
										
										
											2009-10-02 21:18:34 -04:00
										 |  |  | ! Copyright (C) 2007, 2009 Slava Pestov. | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | ! See http://factorcode.org/license.txt for BSD license. | 
					
						
							| 
									
										
										
										
											2009-10-02 21:18:34 -04:00
										 |  |  | USING: accessors arrays combinators kernel make math math.bitwise | 
					
						
							|  |  |  | namespaces sequences words words.symbol parser ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | IN: cpu.arm.assembler | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-02 21:18:34 -04:00
										 |  |  | ! Registers | 
					
						
							|  |  |  | << | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | SYMBOL: registers | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | V{ } registers set-global
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | SYNTAX: REGISTER: | 
					
						
							| 
									
										
										
										
											2011-09-27 16:20:07 -04:00
										 |  |  |     scan-new-word | 
					
						
							| 
									
										
										
										
											2009-10-02 21:18:34 -04:00
										 |  |  |     [ define-symbol ] | 
					
						
							|  |  |  |     [ registers get length "register" set-word-prop ] | 
					
						
							|  |  |  |     [ registers get push ] | 
					
						
							|  |  |  |     tri ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | >> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | REGISTER: R0 | 
					
						
							|  |  |  | REGISTER: R1 | 
					
						
							|  |  |  | REGISTER: R2 | 
					
						
							|  |  |  | REGISTER: R3 | 
					
						
							|  |  |  | REGISTER: R4 | 
					
						
							|  |  |  | REGISTER: R5 | 
					
						
							|  |  |  | REGISTER: R6 | 
					
						
							|  |  |  | REGISTER: R7 | 
					
						
							|  |  |  | REGISTER: R8 | 
					
						
							|  |  |  | REGISTER: R9 | 
					
						
							|  |  |  | REGISTER: R10 | 
					
						
							|  |  |  | REGISTER: R11 | 
					
						
							|  |  |  | REGISTER: R12 | 
					
						
							|  |  |  | REGISTER: R13 | 
					
						
							|  |  |  | REGISTER: R14 | 
					
						
							|  |  |  | REGISTER: R15 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ALIAS: SL R10 ALIAS: FP R11 ALIAS: IP R12 | 
					
						
							|  |  |  | ALIAS: SP R13 ALIAS: LR R14 ALIAS: PC R15 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | <PRIVATE
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | GENERIC: register ( register -- n )
 | 
					
						
							|  |  |  | M: word register "register" word-prop ;
 | 
					
						
							|  |  |  | M: f register drop 0 ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-03-24 12:56:59 -04:00
										 |  |  | PREDICATE: register-class < word register >boolean ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-02 21:18:34 -04:00
										 |  |  | PRIVATE>
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | ! Condition codes | 
					
						
							|  |  |  | SYMBOL: cond-code | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : >CC ( n -- )
 | 
					
						
							|  |  |  |     cond-code set ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : CC> ( -- n )
 | 
					
						
							| 
									
										
										
										
											2015-09-08 19:15:10 -04:00
										 |  |  |     ! Default value is 0b1110 AL (= always) | 
					
						
							| 
									
										
										
										
											2011-11-23 21:49:33 -05:00
										 |  |  |     cond-code [ f ] change 0b1110 or ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : EQ ( -- ) 0b0000 >CC ;
 | 
					
						
							|  |  |  | : NE ( -- ) 0b0001 >CC ;
 | 
					
						
							|  |  |  | : CS ( -- ) 0b0010 >CC ;
 | 
					
						
							|  |  |  | : CC ( -- ) 0b0011 >CC ;
 | 
					
						
							|  |  |  | : LO ( -- ) 0b0100 >CC ;
 | 
					
						
							|  |  |  | : PL ( -- ) 0b0101 >CC ;
 | 
					
						
							|  |  |  | : VS ( -- ) 0b0110 >CC ;
 | 
					
						
							|  |  |  | : VC ( -- ) 0b0111 >CC ;
 | 
					
						
							|  |  |  | : HI ( -- ) 0b1000 >CC ;
 | 
					
						
							|  |  |  | : LS ( -- ) 0b1001 >CC ;
 | 
					
						
							|  |  |  | : GE ( -- ) 0b1010 >CC ;
 | 
					
						
							|  |  |  | : LT ( -- ) 0b1011 >CC ;
 | 
					
						
							|  |  |  | : GT ( -- ) 0b1100 >CC ;
 | 
					
						
							|  |  |  | : LE ( -- ) 0b1101 >CC ;
 | 
					
						
							|  |  |  | : AL ( -- ) 0b1110 >CC ;
 | 
					
						
							|  |  |  | : NV ( -- ) 0b1111 >CC ;
 | 
					
						
							| 
									
										
										
										
											2009-10-02 21:18:34 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | <PRIVATE
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : (insn) ( n -- ) CC> 28 shift bitor , ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : insn ( bitspec -- ) bitfield (insn) ; inline
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! Branching instructions | 
					
						
							| 
									
										
										
										
											2009-10-02 21:18:34 -04:00
										 |  |  | GENERIC# (B) 1 ( target l -- )
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | M: integer (B) { 24 { 1 25 } { 0 26 } { 1 27 } 0 } insn ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-02 21:18:34 -04:00
										 |  |  | PRIVATE>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : B ( target -- ) 0 (B) ;
 | 
					
						
							|  |  |  | : BL ( target -- ) 1 (B) ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | ! Data processing instructions | 
					
						
							| 
									
										
										
										
											2009-10-02 21:18:34 -04:00
										 |  |  | <PRIVATE
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | SYMBOL: updates-cond-code | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-02 21:18:34 -04:00
										 |  |  | PRIVATE>
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | : S ( -- ) updates-cond-code on ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : S> ( -- ? ) updates-cond-code [ f ] change ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-02 21:18:34 -04:00
										 |  |  | <PRIVATE
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | : sinsn ( bitspec -- )
 | 
					
						
							|  |  |  |     bitfield S> [ 20 2^ bitor ] when (insn) ; inline
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | GENERIC# shift-imm/reg 2 ( shift-imm/Rs Rm shift -- n )
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: integer shift-imm/reg ( shift-imm Rm shift -- n )
 | 
					
						
							|  |  |  |     { { 0 4 } 5 { register 0 } 7 } bitfield ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-03-24 12:56:59 -04:00
										 |  |  | M: register-class shift-imm/reg ( Rs Rm shift -- n )
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |     { | 
					
						
							|  |  |  |         { 1 4 } | 
					
						
							|  |  |  |         { 0 7 } | 
					
						
							|  |  |  |         5
 | 
					
						
							|  |  |  |         { register 8 } | 
					
						
							|  |  |  |         { register 0 } | 
					
						
							|  |  |  |     } bitfield ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-02 21:18:34 -04:00
										 |  |  | PRIVATE>
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | TUPLE: IMM immed rotate ;
 | 
					
						
							|  |  |  | C: <IMM> IMM | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TUPLE: shifter Rm by shift ;
 | 
					
						
							|  |  |  | C: <shifter> shifter | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-02 21:18:34 -04:00
										 |  |  | <PRIVATE
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | GENERIC: shifter-op ( shifter-op -- n )
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: IMM shifter-op | 
					
						
							|  |  |  |     [ immed>> ] [ rotate>> ] bi { { 1 25 } 8 0 } bitfield ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | M: shifter shifter-op | 
					
						
							| 
									
										
										
										
											2009-10-02 21:18:34 -04:00
										 |  |  |     [ by>> ] [ Rm>> ] [ shift>> ] tri shift-imm/reg ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | PRIVATE>
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-23 21:49:33 -05:00
										 |  |  | : <LSL> ( Rm shift-imm/Rs -- shifter-op ) 0b00 <shifter> ;
 | 
					
						
							|  |  |  | : <LSR> ( Rm shift-imm/Rs -- shifter-op ) 0b01 <shifter> ;
 | 
					
						
							|  |  |  | : <ASR> ( Rm shift-imm/Rs -- shifter-op ) 0b10 <shifter> ;
 | 
					
						
							|  |  |  | : <ROR> ( Rm shift-imm/Rs -- shifter-op ) 0b11 <shifter> ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | : <RRX> ( Rm -- shifter-op ) 0 <ROR> ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-03-24 12:56:59 -04:00
										 |  |  | M: register-class shifter-op 0 <LSL> shifter-op ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | M: integer shifter-op 0 <IMM> shifter-op ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-02 21:18:34 -04:00
										 |  |  | <PRIVATE
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | : addr1 ( Rd Rn shifter-op opcode -- )
 | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         21 ! opcode | 
					
						
							|  |  |  |         { shifter-op 0 } | 
					
						
							|  |  |  |         { register 16 } ! Rn | 
					
						
							|  |  |  |         { register 12 } ! Rd | 
					
						
							|  |  |  |     } sinsn ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-02 21:18:34 -04:00
										 |  |  | PRIVATE>
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-23 21:49:33 -05:00
										 |  |  | : AND ( Rd Rn shifter-op -- ) 0b0000 addr1 ;
 | 
					
						
							|  |  |  | : EOR ( Rd Rn shifter-op -- ) 0b0001 addr1 ;
 | 
					
						
							|  |  |  | : SUB ( Rd Rn shifter-op -- ) 0b0010 addr1 ;
 | 
					
						
							|  |  |  | : RSB ( Rd Rn shifter-op -- ) 0b0011 addr1 ;
 | 
					
						
							|  |  |  | : ADD ( Rd Rn shifter-op -- ) 0b0100 addr1 ;
 | 
					
						
							|  |  |  | : ADC ( Rd Rn shifter-op -- ) 0b0101 addr1 ;
 | 
					
						
							|  |  |  | : SBC ( Rd Rn shifter-op -- ) 0b0110 addr1 ;
 | 
					
						
							|  |  |  | : RSC ( Rd Rn shifter-op -- ) 0b0111 addr1 ;
 | 
					
						
							|  |  |  | : ORR ( Rd Rn shifter-op -- ) 0b1100 addr1 ;
 | 
					
						
							|  |  |  | : BIC ( Rd Rn shifter-op -- ) 0b1110 addr1 ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-23 21:49:33 -05:00
										 |  |  | : MOV ( Rd shifter-op -- ) [ f ] dip 0b1101 addr1 ;
 | 
					
						
							|  |  |  | : MVN ( Rd shifter-op -- ) [ f ] dip 0b1111 addr1 ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | ! These always update the condition code flags | 
					
						
							| 
									
										
										
										
											2009-10-02 21:18:34 -04:00
										 |  |  | <PRIVATE
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : (CMP) ( Rn shifter-op opcode -- ) [ f ] 3dip S addr1 ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-02 21:18:34 -04:00
										 |  |  | PRIVATE>
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-23 21:49:33 -05:00
										 |  |  | : TST ( Rn shifter-op -- ) 0b1000 (CMP) ;
 | 
					
						
							|  |  |  | : TEQ ( Rn shifter-op -- ) 0b1001 (CMP) ;
 | 
					
						
							|  |  |  | : CMP ( Rn shifter-op -- ) 0b1010 (CMP) ;
 | 
					
						
							|  |  |  | : CMN ( Rn shifter-op -- ) 0b1011 (CMP) ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | ! Multiply instructions | 
					
						
							| 
									
										
										
										
											2009-10-02 21:18:34 -04:00
										 |  |  | <PRIVATE
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : (MLA) ( Rd Rm Rs Rn a -- )
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |     { | 
					
						
							|  |  |  |         21
 | 
					
						
							|  |  |  |         { register 12 } | 
					
						
							|  |  |  |         { register 8 } | 
					
						
							|  |  |  |         { register 0 } | 
					
						
							|  |  |  |         { register 16 } | 
					
						
							|  |  |  |         { 1 7 } | 
					
						
							|  |  |  |         { 1 4 } | 
					
						
							|  |  |  |     } sinsn ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : (S/UMLAL)  ( RdLo RdHi Rm Rs s a -- )
 | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         { 1 23 } | 
					
						
							|  |  |  |         22
 | 
					
						
							|  |  |  |         21
 | 
					
						
							|  |  |  |         { register 8 } | 
					
						
							|  |  |  |         { register 0 } | 
					
						
							|  |  |  |         { register 16 } | 
					
						
							|  |  |  |         { register 12 } | 
					
						
							|  |  |  |         { 1 7 } | 
					
						
							|  |  |  |         { 1 4 } | 
					
						
							|  |  |  |     } sinsn ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-02 21:18:34 -04:00
										 |  |  | PRIVATE>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : MUL ( Rd Rm Rs -- ) f 0 (MLA) ;
 | 
					
						
							|  |  |  | : MLA ( Rd Rm Rs Rn -- ) 1 (MLA) ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : SMLAL ( RdLo RdHi Rm Rs -- ) 1 1 (S/UMLAL) ;
 | 
					
						
							|  |  |  | : SMULL ( RdLo RdHi Rm Rs -- ) 1 0 (S/UMLAL) ;
 | 
					
						
							|  |  |  | : UMLAL ( RdLo RdHi Rm Rs -- ) 0 1 (S/UMLAL) ;
 | 
					
						
							|  |  |  | : UMULL ( RdLo RdHi Rm Rs -- ) 0 0 (S/UMLAL) ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | ! Miscellaneous arithmetic instructions | 
					
						
							|  |  |  | : CLZ ( Rd Rm -- )
 | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         { 1 24 } | 
					
						
							|  |  |  |         { 1 22 } | 
					
						
							|  |  |  |         { 1 21 } | 
					
						
							| 
									
										
										
										
											2011-11-23 21:49:33 -05:00
										 |  |  |         { 0b111 16 } | 
					
						
							|  |  |  |         { 0b1111 8 } | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |         { 1 4 } | 
					
						
							|  |  |  |         { register 0 } | 
					
						
							|  |  |  |         { register 12 } | 
					
						
							|  |  |  |     } sinsn ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! Status register acess instructions | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! Load and store instructions | 
					
						
							| 
									
										
										
										
											2009-10-02 21:18:34 -04:00
										 |  |  | <PRIVATE
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | GENERIC: addressing-mode-2 ( addressing-mode -- n )
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-02 21:18:34 -04:00
										 |  |  | TUPLE: addressing base p u w ;
 | 
					
						
							|  |  |  | C: <addressing> addressing | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | M: addressing addressing-mode-2 | 
					
						
							| 
									
										
										
										
											2009-10-02 21:18:34 -04:00
										 |  |  |     { [ p>> ] [ u>> ] [ w>> ] [ base>> addressing-mode-2 ] } cleave
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |     { 0 21 23 24 } bitfield ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: integer addressing-mode-2 ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: object addressing-mode-2 shifter-op { { 1 25 } 0 } bitfield ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : addr2 ( Rd Rn addressing-mode b l -- )
 | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         { 1 26 } | 
					
						
							|  |  |  |         20
 | 
					
						
							|  |  |  |         22
 | 
					
						
							|  |  |  |         { addressing-mode-2 0 } | 
					
						
							|  |  |  |         { register 16 } | 
					
						
							|  |  |  |         { register 12 } | 
					
						
							|  |  |  |     } insn ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-02 21:18:34 -04:00
										 |  |  | PRIVATE>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! Offset | 
					
						
							|  |  |  | : <+> ( base -- addressing ) 1 1 0 <addressing> ;
 | 
					
						
							|  |  |  | : <-> ( base -- addressing ) 1 0 0 <addressing> ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! Pre-indexed | 
					
						
							|  |  |  | : <!+> ( base -- addressing ) 1 1 1 <addressing> ;
 | 
					
						
							|  |  |  | : <!-> ( base -- addressing ) 1 0 1 <addressing> ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! Post-indexed | 
					
						
							|  |  |  | : <+!> ( base -- addressing ) 0 1 0 <addressing> ;
 | 
					
						
							|  |  |  | : <-!> ( base -- addressing ) 0 0 0 <addressing> ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : LDR  ( Rd Rn addressing-mode -- ) 0 1 addr2 ;
 | 
					
						
							|  |  |  | : LDRB ( Rd Rn addressing-mode -- ) 1 1 addr2 ;
 | 
					
						
							|  |  |  | : STR  ( Rd Rn addressing-mode -- ) 0 0 addr2 ;
 | 
					
						
							|  |  |  | : STRB ( Rd Rn addressing-mode -- ) 1 0 addr2 ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | ! We might have to simulate these instructions since older ARM | 
					
						
							|  |  |  | ! chips don't have them. | 
					
						
							| 
									
										
										
										
											2007-10-15 19:59:03 -04:00
										 |  |  | SYMBOL: have-BX? | 
					
						
							|  |  |  | SYMBOL: have-BLX? | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-02 21:18:34 -04:00
										 |  |  | <PRIVATE
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-10-15 19:59:03 -04:00
										 |  |  | GENERIC# (BX) 1 ( Rm l -- )
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-03-24 12:56:59 -04:00
										 |  |  | M: register-class (BX) ( Rm l -- )
 | 
					
						
							| 
									
										
										
										
											2007-10-15 19:59:03 -04:00
										 |  |  |     { | 
					
						
							|  |  |  |         { 1 24 } | 
					
						
							|  |  |  |         { 1 21 } | 
					
						
							| 
									
										
										
										
											2011-11-23 21:49:33 -05:00
										 |  |  |         { 0b1111 16 } | 
					
						
							|  |  |  |         { 0b1111 12 } | 
					
						
							|  |  |  |         { 0b1111 8 } | 
					
						
							| 
									
										
										
										
											2007-10-15 19:59:03 -04:00
										 |  |  |         5
 | 
					
						
							|  |  |  |         { 1 4 } | 
					
						
							|  |  |  |         { register 0 } | 
					
						
							|  |  |  |     } insn ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-02 21:18:34 -04:00
										 |  |  | PRIVATE>
 | 
					
						
							| 
									
										
										
										
											2007-10-15 19:59:03 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-02 21:18:34 -04:00
										 |  |  | : BX ( Rm -- ) have-BX? get [ 0 (BX) ] [ [ PC ] dip MOV ] if ;
 | 
					
						
							| 
									
										
										
										
											2007-10-15 19:59:03 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-02 21:18:34 -04:00
										 |  |  | : BLX ( Rm -- ) have-BLX? get [ 1 (BX) ] [ LR PC MOV BX ] if ;
 | 
					
						
							| 
									
										
										
										
											2007-10-15 19:59:03 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | ! More load and store instructions | 
					
						
							| 
									
										
										
										
											2009-10-02 21:18:34 -04:00
										 |  |  | <PRIVATE
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-10-15 19:59:03 -04:00
										 |  |  | GENERIC: addressing-mode-3 ( addressing-mode -- n )
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-23 21:49:33 -05:00
										 |  |  | : b>n/n ( b -- n n ) [ -4 shift ] [ 0xf bitand ] bi ;
 | 
					
						
							| 
									
										
										
										
											2007-10-15 19:59:03 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | M: addressing addressing-mode-3 | 
					
						
							| 
									
										
										
										
											2009-10-02 21:18:34 -04:00
										 |  |  |     { [ p>> ] [ u>> ] [ w>> ] [ base>> addressing-mode-3 ] } cleave
 | 
					
						
							| 
									
										
										
										
											2007-10-15 19:59:03 -04:00
										 |  |  |     { 0 21 23 24 } bitfield ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: integer addressing-mode-3 | 
					
						
							|  |  |  |     b>n/n { | 
					
						
							|  |  |  |         ! { 1 24 } | 
					
						
							|  |  |  |         { 1 22 } | 
					
						
							|  |  |  |         { 1 7 } | 
					
						
							|  |  |  |         { 1 4 } | 
					
						
							|  |  |  |         0
 | 
					
						
							|  |  |  |         8
 | 
					
						
							|  |  |  |     } bitfield ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: object addressing-mode-3 | 
					
						
							|  |  |  |     shifter-op { | 
					
						
							|  |  |  |         ! { 1 24 } | 
					
						
							|  |  |  |         { 1 7 } | 
					
						
							|  |  |  |         { 1 4 } | 
					
						
							|  |  |  |         0
 | 
					
						
							|  |  |  |     } bitfield ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : addr3 ( Rn Rd addressing-mode h l s -- )
 | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         6
 | 
					
						
							|  |  |  |         20
 | 
					
						
							|  |  |  |         5
 | 
					
						
							|  |  |  |         { addressing-mode-3 0 } | 
					
						
							|  |  |  |         { register 16 } | 
					
						
							|  |  |  |         { register 12 } | 
					
						
							|  |  |  |     } insn ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-02 21:18:34 -04:00
										 |  |  | PRIVATE>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : LDRH  ( Rn Rd addressing-mode -- ) 1 1 0 addr3 ;
 | 
					
						
							|  |  |  | : LDRSB ( Rn Rd addressing-mode -- ) 0 1 1 addr3 ;
 | 
					
						
							|  |  |  | : LDRSH ( Rn Rd addressing-mode -- ) 1 1 1 addr3 ;
 | 
					
						
							|  |  |  | : STRH  ( Rn Rd addressing-mode -- ) 1 0 0 addr3 ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | ! Load and store multiple instructions | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! Semaphore instructions | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! Exception-generating instructions |