857 lines
38 KiB
Diff
857 lines
38 KiB
Diff
|
--- src/ariarm.d.orig Fri May 04 01:04:01 2012 -0400
|
||
|
+++ src/ariarm.d Thu May 24 16:48:47 2012 -0600
|
||
|
@@ -86,7 +86,7 @@
|
||
|
|
||
|
#define C(x) x
|
||
|
#define EXPORT(x) .global x
|
||
|
-#define GLABEL(x) x:
|
||
|
+#define GLABEL(x) .type x STT_FUNC; x:
|
||
|
#define LABEL(x) x:
|
||
|
#define RRX rrx
|
||
|
#define END
|
||
|
@@ -187,7 +187,7 @@
|
||
|
LDR a3,[pc,#ptr_mulu32_high-.-8]
|
||
|
STR a2,[a3,#0]
|
||
|
#endif
|
||
|
- MOVS pc,lr
|
||
|
+ BX lr
|
||
|
|
||
|
/* extern uint16 divu_3216_1616_ (uint32 x, uint16 y);
|
||
|
entry
|
||
|
@@ -243,7 +243,7 @@
|
||
|
LDR a3,[pc,#ptr_divu_16_rest-.-8] /* save rest so can be picked up later */
|
||
|
STR a2,[a3,#0] /* the result is 16 bits */
|
||
|
#endif
|
||
|
- MOVS pc, lr
|
||
|
+ BX lr
|
||
|
|
||
|
/* extern uint32 divu_6432_3232_ (uint32 xhi, uint32 xlo, uint32 y); | -> Quotient q
|
||
|
extern uint32 divu_32_rest; | -> Rest r
|
||
|
@@ -278,7 +278,7 @@
|
||
|
LDR a4,[pc,#ptr_divu_32_rest-.-8]
|
||
|
STR a2,[a4,#0] /* divu_32_rest = remainder */
|
||
|
#endif
|
||
|
- LDMFD sp!, {v1,v2,v3,v4,v5,v6,pc}^
|
||
|
+ LDMFD sp!, {v1,v2,v3,v4,v5,v6,pc}
|
||
|
|
||
|
LABEL(divu_6432_3232_l1)
|
||
|
MOV v3, #0 /* s = 0 */
|
||
|
@@ -346,7 +346,7 @@
|
||
|
LDR a3,[pc,#ptr_divu_32_rest-.-8]
|
||
|
STR a2,[a3,#0] /* divu_32_rest = remainder */
|
||
|
#endif
|
||
|
- LDMFD sp!, {v1,v2,v3,v4,v5,v6,pc}^
|
||
|
+ LDMFD sp!, {v1,v2,v3,v4,v5,v6,pc}
|
||
|
|
||
|
/* extern uintD* copy_loop_up (uintD* sourceptr, uintD* destptr, uintC count);
|
||
|
entry
|
||
|
@@ -370,7 +370,7 @@
|
||
|
LABEL(copy_loop_up_l1)
|
||
|
BICS a4,a3,#3 /* set counter to multiple of 4 */
|
||
|
MOVEQ a1,a2 /* return addr of last word stored */
|
||
|
- MOVEQS pc,lr /* if zero then we're done */
|
||
|
+ BXEQ lr /* if zero then we're done */
|
||
|
STMFD sp!,{v1,lr} /* save work regs */
|
||
|
LABEL(copy_loop_up_l2)
|
||
|
LDMIA a1!,{a3,v1,ip,lr} /* copy 4 words in one go */
|
||
|
@@ -380,7 +380,7 @@
|
||
|
STMGEIA a2!,{a3,v1,ip,lr} /* 4 more words */
|
||
|
BGT copy_loop_up_l2 /* and loop */
|
||
|
MOV a1,a2 /* return addr of last word stored */
|
||
|
- LDMFD sp!,{v1,pc}^ /* restore work regs and return */
|
||
|
+ LDMFD sp!,{v1,pc} /* restore work regs and return */
|
||
|
|
||
|
/* extern uintD* copy_loop_down (uintD* sourceptr, uintD* destptr, uintC count);
|
||
|
entry
|
||
|
@@ -404,7 +404,7 @@
|
||
|
LABEL(copy_loop_down_l1)
|
||
|
BICS a4,a3,#3 /* set counter to multiple of 4 */
|
||
|
MOVEQ a1,a2 /* return addr of last word stored */
|
||
|
- MOVEQS pc,lr /* if zero then we're done */
|
||
|
+ BXEQ lr /* if zero then we're done */
|
||
|
STMFD sp!,{v1,lr} /* save work regs */
|
||
|
LABEL(copy_loop_down_l2)
|
||
|
LDMDB a1!,{a3,v1,ip,lr} /* copy 4 words in one go */
|
||
|
@@ -414,7 +414,7 @@
|
||
|
STMGEDB a2!,{a3,v1,ip,lr} /* 4 more words */
|
||
|
BGT copy_loop_down_l2 /* and loop */
|
||
|
MOV a1,a2 /* return addr of last word stored */
|
||
|
- LDMFD sp!,{v1,pc}^ /* restore work regs and return */
|
||
|
+ LDMFD sp!,{v1,pc} /* restore work regs and return */
|
||
|
|
||
|
/* extern uintD* clear_loop_up (uintD* destptr, uintC count);
|
||
|
entry
|
||
|
@@ -446,7 +446,7 @@
|
||
|
STRGT a3,[a1],#4
|
||
|
LABEL(fill_loop_up_l1)
|
||
|
BICS a4,a2,#3 /* set counter to multiple of 4 */
|
||
|
- MOVEQS pc,lr /* if zero then we're done */
|
||
|
+ BXEQ lr /* if zero then we're done */
|
||
|
STMFD sp!,{v1,lr} /* save work regs */
|
||
|
MOV v1,a3 /* copy filler to three other */
|
||
|
MOV ip,a3 /* registers */
|
||
|
@@ -456,7 +456,7 @@
|
||
|
SUBS a4,a4,#8 /* decrement counter by 8 */
|
||
|
STMGEIA a1!,{a3,v1,ip,lr} /* if count still positive then store 4 */
|
||
|
BGT fill_loop_up_l2 /* more and loop */
|
||
|
- LDMFD sp!,{v1,pc}^ /* restore work regs and return */
|
||
|
+ LDMFD sp!,{v1,pc} /* restore work regs and return */
|
||
|
|
||
|
|
||
|
/* extern uintD* clear_loop_down (uintD* destptr, uintC count);
|
||
|
@@ -489,7 +489,7 @@
|
||
|
STRGT a3,[a1,#-4]!
|
||
|
LABEL(fill_loop_down_l1)
|
||
|
BICS a4,a2,#3 /* set counter to multiple of 4 */
|
||
|
- MOVEQS pc,lr /* if zero then we're done */
|
||
|
+ BXEQ lr /* if zero then we're done */
|
||
|
STMFD sp!,{v1,lr} /* save work regs */
|
||
|
MOV v1,a3 /* copy filler to three other */
|
||
|
MOV ip,a3 /* registers */
|
||
|
@@ -499,7 +499,7 @@
|
||
|
SUBS a4,a4,#8 /* decrement counter by 8 */
|
||
|
STMGEDB a1!,{a3,v1,ip,lr} /* if count still positive then store 4 */
|
||
|
BGT fill_loop_down_l2 /* more and loop */
|
||
|
- LDMFD sp!,{v1,pc}^ /* restore work regs and return */
|
||
|
+ LDMFD sp!,{v1,pc} /* restore work regs and return */
|
||
|
|
||
|
/* extern void or_loop_up (uintD* xptr, uintD* yptr, uintC count);
|
||
|
entry
|
||
|
@@ -529,7 +529,7 @@
|
||
|
STRGT ip,[a1],#4
|
||
|
LABEL(or_loop_up_l1)
|
||
|
BICS a4,a3,#3 /* set counter to multiple of 4 */
|
||
|
- MOVEQS pc,lr /* if zero then we're done */
|
||
|
+ BXEQ lr /* if zero then we're done */
|
||
|
STMFD sp!,{v1-v5,lr} /* save work regs */
|
||
|
LABEL(or_loop_up_l2)
|
||
|
LDMIA a2!,{a3,v1,v2,ip} /* load 4 words in one go */
|
||
|
@@ -541,7 +541,7 @@
|
||
|
STMIA a1!,{v3,v4,v5,lr} /* store 4 results */
|
||
|
SUBS a4,a4,#4 /* decrement counter by 4 */
|
||
|
BGT or_loop_up_l2 /* if count still positive then loop */
|
||
|
- LDMFD sp!,{v1-v5,pc}^ /* restore work regs and return */
|
||
|
+ LDMFD sp!,{v1-v5,pc} /* restore work regs and return */
|
||
|
|
||
|
/* extern void xor_loop_up (uintD* xptr, uintD* yptr, uintC count);
|
||
|
entry
|
||
|
@@ -571,7 +571,7 @@
|
||
|
STRGT ip,[a1],#4
|
||
|
LABEL(xor_loop_up_l1)
|
||
|
BICS a4,a3,#3 /* set counter to multiple of 4 */
|
||
|
- MOVEQS pc,lr /* if zero then we're done */
|
||
|
+ BXEQ lr /* if zero then we're done */
|
||
|
STMFD sp!,{v1-v5,lr} /* save work regs */
|
||
|
LABEL(xor_loop_up_l2)
|
||
|
LDMIA a2!,{a3,v1,v2,ip} /* load 4 words in one go */
|
||
|
@@ -583,7 +583,7 @@
|
||
|
STMIA a1!,{v3,v4,v5,lr} /* store 4 results */
|
||
|
SUBS a4,a4,#4 /* decrement counter by 4 */
|
||
|
BGT xor_loop_up_l2 /* if count still positive then loop */
|
||
|
- LDMFD sp!,{v1-v5,pc}^ /* restore work regs and return */
|
||
|
+ LDMFD sp!,{v1-v5,pc} /* restore work regs and return */
|
||
|
|
||
|
/* extern void and_loop_up (uintD* xptr, uintD* yptr, uintC count);
|
||
|
entry
|
||
|
@@ -613,7 +613,7 @@
|
||
|
STRGT ip,[a1],#4
|
||
|
LABEL(and_loop_up_l1)
|
||
|
BICS a4,a3,#3 /* set counter to multiple of 4 */
|
||
|
- MOVEQS pc,lr /* if zero then we're done */
|
||
|
+ BXEQ lr /* if zero then we're done */
|
||
|
STMFD sp!,{v1-v5,lr} /* save work regs */
|
||
|
LABEL(and_loop_up_l2)
|
||
|
LDMIA a2!,{a3,v1,v2,ip} /* load 4 words in one go */
|
||
|
@@ -625,7 +625,7 @@
|
||
|
STMIA a1!,{v3,v4,v5,lr} /* store 4 results */
|
||
|
SUBS a4,a4,#4 /* decrement counter by 4 */
|
||
|
BGT and_loop_up_l2 /* if count still positive then loop */
|
||
|
- LDMFD sp!,{v1-v5,pc}^ /* restore work regs and return */
|
||
|
+ LDMFD sp!,{v1-v5,pc} /* restore work regs and return */
|
||
|
|
||
|
/* extern void eqv_loop_up (uintD* xptr, uintD* yptr, uintC count);
|
||
|
entry
|
||
|
@@ -659,7 +659,7 @@
|
||
|
STRGT ip,[a1],#4
|
||
|
LABEL(eqv_loop_up_l1)
|
||
|
BICS a4,a3,#3 /* set counter to multiple of 4 */
|
||
|
- MOVEQS pc,lr /* if zero then we're done */
|
||
|
+ BXEQ lr /* if zero then we're done */
|
||
|
STMFD sp!,{v1-v5,lr} /* save work regs */
|
||
|
LABEL(eqv_loop_up_l2)
|
||
|
LDMIA a2!,{a3,v1,v2,ip} /* load 4 words in one go */
|
||
|
@@ -675,7 +675,7 @@
|
||
|
STMIA a1!,{v3,v4,v5,lr} /* store 4 results */
|
||
|
SUBS a4,a4,#4 /* decrement counter by 4 */
|
||
|
BGT eqv_loop_up_l2 /* if count still positive then loop */
|
||
|
- LDMFD sp!,{v1-v5,pc}^ /* restore work regs and return */
|
||
|
+ LDMFD sp!,{v1-v5,pc} /* restore work regs and return */
|
||
|
|
||
|
/* extern void nand_loop_up (uintD* xptr, uintD* yptr, uintC count);
|
||
|
entry
|
||
|
@@ -709,7 +709,7 @@
|
||
|
STRGT ip,[a1],#4
|
||
|
LABEL(nand_loop_up_l1)
|
||
|
BICS a4,a3,#3 /* set counter to multiple of 4 */
|
||
|
- MOVEQS pc,lr /* if zero then we're done */
|
||
|
+ BXEQ lr /* if zero then we're done */
|
||
|
STMFD sp!,{v1-v5,lr} /* save work regs */
|
||
|
LABEL(nand_loop_up_l2)
|
||
|
LDMIA a2!,{a3,v1,v2,ip} /* load 4 words in one go */
|
||
|
@@ -725,7 +725,7 @@
|
||
|
STMIA a1!,{v3,v4,v5,lr} /* store 4 results */
|
||
|
SUBS a4,a4,#4 /* decrement counter by 4 */
|
||
|
BGT nand_loop_up_l2 /* if count still positive then loop */
|
||
|
- LDMFD sp!,{v1-v5,pc}^ /* restore work regs and return */
|
||
|
+ LDMFD sp!,{v1-v5,pc} /* restore work regs and return */
|
||
|
|
||
|
/* extern void nor_loop_up (uintD* xptr, uintD* yptr, uintC count);
|
||
|
entry
|
||
|
@@ -759,7 +759,7 @@
|
||
|
STRGT ip,[a1],#4
|
||
|
LABEL(nor_loop_up_l1)
|
||
|
BICS a4,a3,#3 /* set counter to multiple of 4 */
|
||
|
- MOVEQS pc,lr /* if zero then we're done */
|
||
|
+ BXEQ lr /* if zero then we're done */
|
||
|
STMFD sp!,{v1-v5,lr} /* save work regs */
|
||
|
LABEL(nor_loop_up_l2)
|
||
|
LDMIA a2!,{a3,v1,v2,ip} /* load 4 words in one go */
|
||
|
@@ -775,7 +775,7 @@
|
||
|
STMIA a1!,{v3,v4,v5,lr} /* store 4 results */
|
||
|
SUBS a4,a4,#4 /* decrement counter by 4 */
|
||
|
BGT nor_loop_up_l2 /* if count still positive then loop */
|
||
|
- LDMFD sp!,{v1-v5,pc}^ /* restore work regs and return */
|
||
|
+ LDMFD sp!,{v1-v5,pc} /* restore work regs and return */
|
||
|
|
||
|
/* extern void andc2_loop_up (uintD* xptr, uintD* yptr, uintC count);
|
||
|
entry
|
||
|
@@ -805,7 +805,7 @@
|
||
|
STRGT ip,[a1],#4
|
||
|
LABEL(andc2_loop_up_l1)
|
||
|
BICS a4,a3,#3 /* set counter to multiple of 4 */
|
||
|
- MOVEQS pc,lr /* if zero then we're done */
|
||
|
+ BXEQ lr /* if zero then we're done */
|
||
|
STMFD sp!,{v1-v5,lr} /* save work regs */
|
||
|
LABEL(andc2_loop_up_l2)
|
||
|
LDMIA a2!,{a3,v1,v2,ip} /* load 4 words in one go */
|
||
|
@@ -817,7 +817,7 @@
|
||
|
STMIA a1!,{v3,v4,v5,lr} /* store 4 results */
|
||
|
SUBS a4,a4,#4 /* decrement counter by 4 */
|
||
|
BGT andc2_loop_up_l2 /* if count still positive then loop */
|
||
|
- LDMFD sp!,{v1-v5,pc}^ /* restore work regs and return */
|
||
|
+ LDMFD sp!,{v1-v5,pc} /* restore work regs and return */
|
||
|
|
||
|
/* extern void orc2_loop_up (uintD* xptr, uintD* yptr, uintC count);
|
||
|
entry
|
||
|
@@ -851,7 +851,7 @@
|
||
|
STRGT ip,[a1],#4
|
||
|
LABEL(orc2_loop_up_l1)
|
||
|
BICS a4,a3,#3 /* set counter to multiple of 4 */
|
||
|
- MOVEQS pc,lr /* if zero then we're done */
|
||
|
+ BXEQ lr /* if zero then we're done */
|
||
|
STMFD sp!,{v1-v5,lr} /* save work regs */
|
||
|
LABEL(orc2_loop_up_l2)
|
||
|
LDMIA a2!,{a3,v1,v2,ip} /* load 4 words in one go */
|
||
|
@@ -867,7 +867,7 @@
|
||
|
STMIA a1!,{v3,v4,v5,lr} /* store 4 results */
|
||
|
SUBS a4,a4,#4 /* decrement counter by 4 */
|
||
|
BGT orc2_loop_up_l2 /* if count still positive then loop */
|
||
|
- LDMFD sp!,{v1-v5,pc}^ /* restore work regs and return */
|
||
|
+ LDMFD sp!,{v1-v5,pc} /* restore work regs and return */
|
||
|
|
||
|
/* extern void not_loop_up (uintD* xptr, uintC count);
|
||
|
entry
|
||
|
@@ -893,7 +893,7 @@
|
||
|
STRGT a3,[a1],#4
|
||
|
LABEL(not_loop_up_l1)
|
||
|
BICS a4,a2,#3 /* set counter to multiple of 4 */
|
||
|
- MOVEQS pc,lr /* if zero then we're done */
|
||
|
+ BXEQ lr /* if zero then we're done */
|
||
|
STMFD sp!,{lr} /* save work regs */
|
||
|
LABEL(not_loop_up_l2)
|
||
|
LDMIA a1,{a2,a3,ip,lr} /* load 4 words in one go,NO writeback */
|
||
|
@@ -904,7 +904,7 @@
|
||
|
STMIA a1!,{a2,a3,ip,lr} /* store 4 results */
|
||
|
SUBS a4,a4,#4 /* decrement counter by 4 */
|
||
|
BGT not_loop_up_l2 /* if count still positive then loop */
|
||
|
- LDMFD sp!,{pc}^ /* restore work regs and return */
|
||
|
+ LDMFD sp!,{pc} /* restore work regs and return */
|
||
|
|
||
|
/* extern void and_test_loop_up (uintD* xptr, uintD* yptr, uintC count);
|
||
|
entry
|
||
|
@@ -923,13 +923,13 @@
|
||
|
LDR ip,[a1],#4 /* to align the total to a multiple */
|
||
|
TST ip,a4 /* of 4 words */
|
||
|
MOVNE a1,#1 /* return true if AND_TEST ok */
|
||
|
- MOVNES pc,lr
|
||
|
+ BXNE lr
|
||
|
BCC and_test_loop_up_l1 /* better to branch than skip instrs. */
|
||
|
LDRGE a4,[a2],#4
|
||
|
LDRGE ip,[a1],#4
|
||
|
TSTGE ip,a4
|
||
|
MOVNE a1,#1
|
||
|
- MOVNES pc,lr
|
||
|
+ BXNE lr
|
||
|
ANDS a4,a3,#3
|
||
|
CMP a4,#2
|
||
|
BLE and_test_loop_up_l1 /* better to branch than skip instrs. */
|
||
|
@@ -937,11 +937,11 @@
|
||
|
LDRGT ip,[a1],#4
|
||
|
TSTGT ip,a4
|
||
|
MOVNE a1,#1
|
||
|
- MOVNES pc,lr
|
||
|
+ BXNE lr
|
||
|
LABEL(and_test_loop_up_l1)
|
||
|
BICS a4,a3,#3 /* set counter to multiple of 4 */
|
||
|
MOVEQ a1,#0 /* return false */
|
||
|
- MOVEQS pc,lr /* if zero then we're done */
|
||
|
+ BXEQ lr /* if zero then we're done */
|
||
|
STMFD sp!,{v1-v6,lr} /* save work regs */
|
||
|
MOV v6,a1 /* move xptr to v6 */
|
||
|
MOV a1,#1 /* set result to true */
|
||
|
@@ -952,11 +952,11 @@
|
||
|
TSTEQ v4,v1
|
||
|
TSTEQ v5,v2
|
||
|
TSTEQ lr,ip
|
||
|
- LDMNEFD sp!,{v1-v6,pc}^
|
||
|
+ LDMNEFD sp!,{v1-v6,pc}
|
||
|
SUBS a4,a4,#4 /* decrement counter by 4 */
|
||
|
BGT and_test_loop_up_l2 /* if count still positive then loop */
|
||
|
MOV a1,#0
|
||
|
- LDMFD sp!,{v1-v6,pc}^ /* restore work regs and return */
|
||
|
+ LDMFD sp!,{v1-v6,pc} /* restore work regs and return */
|
||
|
|
||
|
/* extern void test_loop_up (uintD* xptr, uintC count);
|
||
|
entry
|
||
|
@@ -973,21 +973,21 @@
|
||
|
BEQ test_loop_up_l1 /* yup, so branch */
|
||
|
LDR a4,[ip],#4 /* TEST the first 1-3 words */
|
||
|
TEQ a4,#0 /* align the total to a multiple of 4 */
|
||
|
- MOVNES pc,lr /* return true if AND_TEST ok */
|
||
|
+ BXNE lr /* return true if AND_TEST ok */
|
||
|
CMP a3,#2
|
||
|
BLT test_loop_up_l1 /* need to branch 'cos PSR set */
|
||
|
LDRGE a4,[ip],#4 /* when checking against zero */
|
||
|
TEQGE a4,#0
|
||
|
- MOVNES pc,lr
|
||
|
+ BXNE lr
|
||
|
CMP a3,#2
|
||
|
BLE test_loop_up_l1 /* need to branch 'cos PSR set */
|
||
|
LDRGT a4,[ip],#4 /* when checking against zero */
|
||
|
TEQGT a4,#0
|
||
|
- MOVNES pc,lr
|
||
|
+ BXNE lr
|
||
|
LABEL(test_loop_up_l1)
|
||
|
BICS a4,a2,#3 /* set counter to multiple of 4 */
|
||
|
MOVEQ a1,#0 /* return false */
|
||
|
- MOVEQS pc,lr /* if zero then we're done */
|
||
|
+ BXEQ lr /* if zero then we're done */
|
||
|
STMFD sp!,{v1,lr} /* save work regs */
|
||
|
LABEL(test_loop_up_l2)
|
||
|
LDMIA ip!,{a2,a3,v1,lr} /* load 4 words in one go */
|
||
|
@@ -995,11 +995,11 @@
|
||
|
TEQEQ a3,#0
|
||
|
TEQEQ v1,#0
|
||
|
TEQEQ lr,#0
|
||
|
- LDMNEFD sp!,{v1,pc}^
|
||
|
+ LDMNEFD sp!,{v1,pc}
|
||
|
SUBS a4,a4,#4 /* decrement counter by 4 */
|
||
|
BGT test_loop_up_l2 /* if count still positive then loop */
|
||
|
MOV a1,#0
|
||
|
- LDMFD sp!,{v1,pc}^ /* restore work regs and return */
|
||
|
+ LDMFD sp!,{v1,pc} /* restore work regs and return */
|
||
|
|
||
|
/* extern void compare_loop_up (uintD* xptr, uintD* yptr, uintC count);
|
||
|
entry
|
||
|
@@ -1021,7 +1021,7 @@
|
||
|
CMP ip,a4 /* of 4 words */
|
||
|
MVNLO a1,#0 /* x < y -> -1 */
|
||
|
MOVHI a1,#1 /* x > y -> +1 */
|
||
|
- MOVNES pc,lr /* and return result if not equal */
|
||
|
+ BXNE lr /* and return result if not equal */
|
||
|
ANDS a4,a3,#3
|
||
|
CMP a4,#2
|
||
|
BLT compare_loop_up_l1 /* need to branch 'cos PSR used */
|
||
|
@@ -1030,7 +1030,7 @@
|
||
|
CMP ip,a4
|
||
|
MVNLO a1,#0
|
||
|
MOVHI a1,#1
|
||
|
- MOVNES pc,lr
|
||
|
+ BXNE lr
|
||
|
ANDS a4,a3,#3
|
||
|
CMP a4,#2
|
||
|
BLE compare_loop_up_l1 /* need to branch 'cos PSR used */
|
||
|
@@ -1039,11 +1039,11 @@
|
||
|
CMP ip,a4
|
||
|
MVNLO a1,#0
|
||
|
MOVHI a1,#1
|
||
|
- MOVNES pc,lr
|
||
|
+ BXNE lr
|
||
|
LABEL(compare_loop_up_l1)
|
||
|
BICS a4,a3,#3 /* set counter to multiple of 4 */
|
||
|
MOVEQ a1,#0 /* xptr[] == yptr[] -> 0 */
|
||
|
- MOVEQS pc,lr /* if zero then we're done */
|
||
|
+ BXEQ lr /* if zero then we're done */
|
||
|
STMFD sp!,{v1-v6,lr} /* save work regs */
|
||
|
MOV v6,a1 /* move xptr to v6 */
|
||
|
MOV a1,#1 /* set result to +1 */
|
||
|
@@ -1055,11 +1055,11 @@
|
||
|
CMPEQ v5,v2
|
||
|
CMPEQ lr,ip
|
||
|
MVNLO a1,#0 /* x < y -> -1 (a1 already holds +1) */
|
||
|
- LDMNEFD sp!,{v1-v6,pc}^
|
||
|
+ LDMNEFD sp!,{v1-v6,pc}
|
||
|
SUBS a4,a4,#4 /* decrement counter by 4 */
|
||
|
BGT compare_loop_up_l2 /* if count still positive then loop */
|
||
|
MOV a1,#0
|
||
|
- LDMFD sp!,{v1-v6,pc}^ /* restore work regs and return */
|
||
|
+ LDMFD sp!,{v1-v6,pc} /* restore work regs and return */
|
||
|
|
||
|
/* extern uintD addto_loop_down (uintD* sourceptr, uintD* destptr, uintC count);
|
||
|
entry
|
||
|
@@ -1111,11 +1111,11 @@
|
||
|
BICS a4,a4,#3 /* set counter to multiple of 4 */
|
||
|
BNE add_loop_down_l3 /* branch if more adds to do */
|
||
|
ADCEQ a1,a4,a4 /* set result to Carry (a4 is 0) */
|
||
|
- LDMEQFD sp!,{v6,pc}^ /* and return */
|
||
|
+ LDMEQFD sp!,{v6,pc} /* and return */
|
||
|
LABEL(add_loop_down_l1)
|
||
|
BICS a4,a4,#3 /* set counter to multiple of 4 */
|
||
|
MOVEQ a1,#0 /* no adds, so C = 0 */
|
||
|
- MOVEQS pc,lr /* if zero then we're done */
|
||
|
+ BXEQ lr /* if zero then we're done */
|
||
|
CMN a4,#0 /* clear carry bit */
|
||
|
STMFD sp!,{v6,lr}
|
||
|
LABEL(add_loop_down_l3)
|
||
|
@@ -1132,7 +1132,7 @@
|
||
|
TEQ a4,#0 /* are we done ? */
|
||
|
BNE add_loop_down_l2 /* if count non-zero then loop */
|
||
|
ADC a1,a4,a4 /* set result to Carry (a4 is 0) */
|
||
|
- LDMFD sp!,{v1-v6,pc}^ /* restore work regs and return */
|
||
|
+ LDMFD sp!,{v1-v6,pc} /* restore work regs and return */
|
||
|
|
||
|
/* extern uintD inc_loop_down (uintD* ptr, uintC count);
|
||
|
entry
|
||
|
@@ -1150,11 +1150,11 @@
|
||
|
ADDS a4,a4,#1 /* align the total to a multiple of 2 */
|
||
|
STR a4,[a1]
|
||
|
MOVNE a1,#0 /* set result to 0 */
|
||
|
- MOVNES pc,lr /* return 0 if non-zero result */
|
||
|
+ BXNE lr /* return 0 if non-zero result */
|
||
|
LABEL(inc_loop_down_l1)
|
||
|
BICS a4,a2,#1 /* set counter to multiple of 2 */
|
||
|
MOVEQ a1,#1 /* return 1 */
|
||
|
- MOVEQS pc,lr /* if zero then we're done */
|
||
|
+ BXEQ lr /* if zero then we're done */
|
||
|
MOV ip,a1 /* move ptr to ip */
|
||
|
MOV a1,#0 /* set result to 0 */
|
||
|
ANDS a3,a4,#3
|
||
|
@@ -1163,10 +1163,10 @@
|
||
|
ADDS a3,a3,#1 /* INC the two words */
|
||
|
ADDEQS a2,a2,#1 /* stopping when first word non-zero */
|
||
|
STMDB ip!,{a2,a3} /* store 2 results */
|
||
|
- MOVNES pc,lr /* return 0 if any result non-zero */
|
||
|
+ BXNE lr /* return 0 if any result non-zero */
|
||
|
SUBS a4,a4,#2 /* decrement counter by 2 */
|
||
|
MOVEQ a1,#1 /* if finished loop then */
|
||
|
- MOVEQS pc,lr /* return 1 */
|
||
|
+ BXEQ lr /* return 1 */
|
||
|
LABEL(inc_loop_down_l3) /* now a multiple of 4 words */
|
||
|
STMFD sp!,{v1,lr} /* save work regs */
|
||
|
LABEL(inc_loop_down_l2)
|
||
|
@@ -1176,11 +1176,11 @@
|
||
|
ADDEQS a3,a3,#1
|
||
|
ADDEQS a2,a2,#1
|
||
|
STMDB ip!,{a2,a3,v1,lr} /* store 4 results */
|
||
|
- LDMNEFD sp!,{v1,pc}^ /* return 0 if any result non-zero */
|
||
|
+ LDMNEFD sp!,{v1,pc} /* return 0 if any result non-zero */
|
||
|
SUBS a4,a4,#4 /* decrement counter by 4 */
|
||
|
BGT inc_loop_down_l2 /* if count still positive then loop */
|
||
|
MOV a1,#1
|
||
|
- LDMFD sp!,{v1,pc}^ /* restore work regs and return 1 */
|
||
|
+ LDMFD sp!,{v1,pc} /* restore work regs and return 1 */
|
||
|
|
||
|
/* extern uintD sub_loop_down (uintD* sourceptr1, uintD* sourceptr2, uintD* destptr, uintC count);
|
||
|
entry
|
||
|
@@ -1206,7 +1206,7 @@
|
||
|
LABEL(sub_loop_down_l4) /* drop through for better instr. timings */
|
||
|
BICS a4,a4,#3 /* set counter to multiple of 4 */
|
||
|
SBCEQ a1,a4,a4 /* set result to Carry (a4 is 0) */
|
||
|
- LDMEQFD sp!,{v6,pc}^ /* and return */
|
||
|
+ LDMEQFD sp!,{v6,pc} /* and return */
|
||
|
STMFD sp!,{v1-v5} /* save work regs */
|
||
|
B sub_loop_down_l2 /* branch if more subtracts to do */
|
||
|
LABEL(sub_loop_down_l0)
|
||
|
@@ -1224,7 +1224,7 @@
|
||
|
LABEL(sub_loop_down_l1)
|
||
|
BICS a4,a4,#3 /* set counter to multiple of 4 */
|
||
|
MOVEQ a1,#0 /* no subtracts, so C = 0 */
|
||
|
- MOVEQS pc,lr /* if zero then we're done */
|
||
|
+ BXEQ lr /* if zero then we're done */
|
||
|
CMP a4,#0 /* set carry bit, since a4 > 0 */
|
||
|
STMFD sp!,{v1-v6,lr} /* save work regs */
|
||
|
LABEL(sub_loop_down_l2)
|
||
|
@@ -1239,7 +1239,7 @@
|
||
|
TEQ a4,#0 /* are we done ? */
|
||
|
BNE sub_loop_down_l2 /* if count non-zero then loop */
|
||
|
SBC a1,a4,a4 /* set result to Carry (a4 is 0) */
|
||
|
- LDMFD sp!,{v1-v6,pc}^ /* restore work regs and return */
|
||
|
+ LDMFD sp!,{v1-v6,pc} /* restore work regs and return */
|
||
|
|
||
|
/* extern uintD subx_loop_down (uintD* sourceptr1, uintD* sourceptr2, uintD* destptr, uintC count, uintD carry);
|
||
|
entry
|
||
|
@@ -1269,7 +1269,7 @@
|
||
|
LABEL(subx_loop_down_l4) /* drop through for better instr. timings */
|
||
|
BICS a4,a4,#3 /* set counter to multiple of 4 */
|
||
|
SBCEQ a1,a4,a4 /* set result to Carry (a4 is 0) */
|
||
|
- LDMEQFD sp!,{v6,pc}^ /* and return */
|
||
|
+ LDMEQFD sp!,{v6,pc} /* and return */
|
||
|
STMFD sp!,{v1-v5} /* save work regs */
|
||
|
B subx_loop_down_l2 /* branch if more subtracts to do */
|
||
|
LABEL(subx_loop_down_l0)
|
||
|
@@ -1287,7 +1287,7 @@
|
||
|
LABEL(subx_loop_down_l1)
|
||
|
BICS a4,a4,#3 /* set counter to multiple of 4 */
|
||
|
SBCEQ a1,a4,a4 /* set result to Carry (a4 is 0) */
|
||
|
- MOVEQS pc,lr /* if zero then we're done */
|
||
|
+ BXEQ lr /* if zero then we're done */
|
||
|
STMFD sp!,{v1-v6,lr} /* save work regs */
|
||
|
LABEL(subx_loop_down_l2)
|
||
|
LDMDB a2!,{v1,v2,v3,ip} /* load 4 words in one go */
|
||
|
@@ -1301,7 +1301,7 @@
|
||
|
TEQ a4,#0 /* are we done ? */
|
||
|
BNE subx_loop_down_l2 /* if count non-zero then loop */
|
||
|
SBC a1,a4,a4 /* set result to Carry (a4 is 0) */
|
||
|
- LDMFD sp!,{v1-v6,pc}^ /* restore work regs and return */
|
||
|
+ LDMFD sp!,{v1-v6,pc} /* restore work regs and return */
|
||
|
|
||
|
/* extern uintD subfrom_loop_down (uintD* sourceptr, uintD* destptr, uintC count);
|
||
|
entry
|
||
|
@@ -1326,7 +1326,7 @@
|
||
|
LABEL(subfrom_loop_down_l4) /* drop through for better instr. timings */
|
||
|
BICS a4,a3,#3 /* set counter to multiple of 4 */
|
||
|
SBCEQ a1,a4,a4 /* set result to Carry (a4 is 0) */
|
||
|
- LDMEQFD sp!,{pc}^ /* and return */
|
||
|
+ LDMEQFD sp!,{pc} /* and return */
|
||
|
STMFD sp!,{v1-v5} /* save work regs */
|
||
|
B subfrom_loop_down_l2 /* branch if more subtracts to do */
|
||
|
LABEL(subfrom_loop_down_l0)
|
||
|
@@ -1344,7 +1344,7 @@
|
||
|
LABEL(subfrom_loop_down_l1)
|
||
|
BICS a4,a3,#3 /* set counter to multiple of 4 */
|
||
|
MOVEQ a1,#0 /* no subtracts, so C = 0 */
|
||
|
- MOVEQS pc,lr /* if zero then we're done */
|
||
|
+ BXEQ lr /* if zero then we're done */
|
||
|
CMP a4,#0 /* set carry bit, since a4 > 0 */
|
||
|
STMFD sp!,{v1-v5,lr} /* save work regs */
|
||
|
LABEL(subfrom_loop_down_l2)
|
||
|
@@ -1359,7 +1359,7 @@
|
||
|
TEQ a4,#0 /* are we done ? */
|
||
|
BNE subfrom_loop_down_l2 /* if count non-zero then loop */
|
||
|
SBC a1,a4,a4 /* set result to Carry (a4 is 0) */
|
||
|
- LDMFD sp!,{v1-v5,pc}^ /* restore work regs and return */
|
||
|
+ LDMFD sp!,{v1-v5,pc} /* restore work regs and return */
|
||
|
|
||
|
/* extern uintD dec_loop_down (uintD* ptr, uintC count);
|
||
|
entry
|
||
|
@@ -1377,11 +1377,11 @@
|
||
|
SUBS a4,a4,#1 /* align the total to a multiple of 2 */
|
||
|
STR a4,[a1]
|
||
|
MOVCS a1,#0 /* set result to 0 */
|
||
|
- MOVCSS pc,lr /* return 0 if non-zero result */
|
||
|
+ BXCS lr /* return 0 if non-zero result */
|
||
|
LABEL(dec_loop_down_l1)
|
||
|
BICS a4,a2,#1 /* set counter to multiple of 2 */
|
||
|
MVNEQ a1,#0 /* return -1 */
|
||
|
- MOVEQS pc,lr /* if zero then we're done */
|
||
|
+ BXEQ lr /* if zero then we're done */
|
||
|
MOV ip,a1 /* move ptr to ip */
|
||
|
MOV a1,#0 /* set result to 0 */
|
||
|
ANDS a3,a4,#3
|
||
|
@@ -1390,10 +1390,10 @@
|
||
|
SUBS a3,a3,#1 /* DEC the two words */
|
||
|
SUBCCS a2,a2,#1 /* stopping when first word non-zero */
|
||
|
STMDB ip!,{a2,a3} /* store 2 results */
|
||
|
- MOVCSS pc,lr /* return 0 if any result non-zero */
|
||
|
+ BXCS lr /* return 0 if any result non-zero */
|
||
|
SUBS a4,a4,#2 /* decrement counter by 2 */
|
||
|
MVNEQ a1,#0 /* if finished loop then */
|
||
|
- MOVEQS pc,lr /* return -1 */
|
||
|
+ BXEQ lr /* return -1 */
|
||
|
LABEL(dec_loop_down_l3) /* now a multiple of 4 words */
|
||
|
STMFD sp!,{v1,lr} /* save work regs */
|
||
|
LABEL(dec_loop_down_l2)
|
||
|
@@ -1403,11 +1403,11 @@
|
||
|
SUBCCS a3,a3,#1
|
||
|
SUBCCS a2,a2,#1
|
||
|
STMDB ip!,{a2,a3,v1,lr} /* store 4 results */
|
||
|
- LDMCSFD sp!,{v1,pc}^ /* return 0 if any carry */
|
||
|
+ LDMCSFD sp!,{v1,pc} /* return 0 if any carry */
|
||
|
SUBS a4,a4,#4 /* decrement counter by 4 */
|
||
|
BGT dec_loop_down_l2 /* if count still positive then loop */
|
||
|
MVN a1,#0
|
||
|
- LDMFD sp!,{v1,pc}^ /* restore work regs and return -1 */
|
||
|
+ LDMFD sp!,{v1,pc} /* restore work regs and return -1 */
|
||
|
|
||
|
/* extern void neg_loop_down (uintD* ptr, uintC count);
|
||
|
entry
|
||
|
@@ -1421,7 +1421,7 @@
|
||
|
GLABEL(neg_loop_down)
|
||
|
CMPS a2,#0 /* count = 0 ? */
|
||
|
MOVEQ a1,#0 /* yup, so return 0 */
|
||
|
- MOVEQS pc,lr
|
||
|
+ BXEQ lr
|
||
|
LABEL(neg_loop_down_l1) /* skip all the zero words first */
|
||
|
LDR a3,[a1,#-4]! /* compare words against zero */
|
||
|
CMPS a3,#0 /* downwards in memory */
|
||
|
@@ -1429,13 +1429,13 @@
|
||
|
SUBS a2,a2,#1 /* reduce count of words */
|
||
|
BNE neg_loop_down_l1 /* more ?, so loop */
|
||
|
MOV a1,#0 /* return 0 */
|
||
|
- MOVS pc,lr
|
||
|
+ BX lr
|
||
|
LABEL(neg_loop_down_l2)
|
||
|
RSB a3,a3,#0 /* first non-zero word = -word */
|
||
|
STR a3,[a1]
|
||
|
SUBS a2,a2,#1
|
||
|
MVNEQ a1,#0 /* done ? -> return -1 */
|
||
|
- MOVEQS pc,lr
|
||
|
+ BXEQ lr
|
||
|
/* now NOT rest of the words */
|
||
|
ANDS a3,a2,#3 /* multiple of 4 words ? */
|
||
|
BEQ neg_loop_down_l3 /* yup, so branch */
|
||
|
@@ -1453,7 +1453,7 @@
|
||
|
LABEL(neg_loop_down_l3)
|
||
|
BICS a4,a2,#3 /* set counter to multiple of 4 */
|
||
|
MVNEQ a1,#0 /* set result to -1 */
|
||
|
- MOVEQS pc,lr /* if zero then we're done */
|
||
|
+ BXEQ lr /* if zero then we're done */
|
||
|
STMFD sp!,{lr} /* save work regs */
|
||
|
LABEL(neg_loop_down_l4)
|
||
|
LDMDB a1,{a2,a3,ip,lr} /* load 4 words in one go,NO writeback */
|
||
|
@@ -1465,7 +1465,7 @@
|
||
|
SUBS a4,a4,#4 /* decrement counter by 4 */
|
||
|
BGT neg_loop_down_l4 /* if count still positive then loop */
|
||
|
MVN a1,#0 /* set result to -1 */
|
||
|
- LDMFD sp!,{pc}^ /* restore work regs and return -1 */
|
||
|
+ LDMFD sp!,{pc} /* restore work regs and return -1 */
|
||
|
|
||
|
/* extern uintD shift1left_loop_down (uintD* ptr, uintC count);
|
||
|
entry
|
||
|
@@ -1485,7 +1485,7 @@
|
||
|
LABEL(shift1left_loop_down_l1)
|
||
|
BICS a4,a2,#1 /* set counter to multiple of 2 */
|
||
|
ADCEQ a1,a4,a4 /* if zero set result to C (a4 is 0) */
|
||
|
- MOVEQS pc,lr /* and return */
|
||
|
+ BXEQ lr /* and return */
|
||
|
ANDS a3,a4,#3 /* multiple of 4 words ? */
|
||
|
BEQ shift1left_loop_down_l3 /* yup, so branch */
|
||
|
LDMDB a1,{a2,a3} /* load 2 words in one go */
|
||
|
@@ -1494,7 +1494,7 @@
|
||
|
STMDB a1!,{a2,a3} /* store 2 results */
|
||
|
BICS a4,a4,#2 /* decrement counter by 2 */
|
||
|
ADCEQ a1,a4,a4 /* set result to Carry (a4 is 0) */
|
||
|
- MOVEQS pc,lr /* and return */
|
||
|
+ BXEQ lr /* and return */
|
||
|
LABEL(shift1left_loop_down_l3) /* now a multiple of 4 words */
|
||
|
STMFD sp!,{lr} /* save work regs */
|
||
|
LABEL(shift1left_loop_down_l2)
|
||
|
@@ -1508,7 +1508,7 @@
|
||
|
TEQ a4,#0 /* are we done ? */
|
||
|
BNE shift1left_loop_down_l2 /* if count non-zero then loop */
|
||
|
ADC a1,a4,a4 /* set result to Carry (a4 is 0) */
|
||
|
- LDMFD sp!,{pc}^ /* restore work regs and return 1 */
|
||
|
+ LDMFD sp!,{pc} /* restore work regs and return 1 */
|
||
|
|
||
|
/* extern uintD shiftleft_loop_down (uintD* ptr, uintC count, uintC i, uintD carry);
|
||
|
entry
|
||
|
@@ -1542,7 +1542,7 @@
|
||
|
LABEL(shiftleft_loop_down_l1)
|
||
|
BICS ip,a2,#3 /* set counter to multiple of 4 */
|
||
|
MOVEQ a1,a4 /* if zero then we're done */
|
||
|
- LDMEQFD sp!,{v6,pc}^ /* so return last shift out */
|
||
|
+ LDMEQFD sp!,{v6,pc} /* so return last shift out */
|
||
|
STMFD sp!,{v1-v3} /* save work regs */
|
||
|
LABEL(shiftleft_loop_down_l2)
|
||
|
LDMDB a1,{a2,v1,v2,v3} /* load 4 words in one go */
|
||
|
@@ -1558,7 +1558,7 @@
|
||
|
SUBS ip,ip,#4 /* decrement counter by 4 */
|
||
|
BGT shiftleft_loop_down_l2 /* if count still positive then loop */
|
||
|
MOV a1,a4 /* result = last shift out */
|
||
|
- LDMFD sp!,{v1-v3,v6,pc}^ /* restore work regs and return */
|
||
|
+ LDMFD sp!,{v1-v3,v6,pc} /* restore work regs and return */
|
||
|
|
||
|
/* extern uintD shiftleftcopy_loop_down (uintD* sourceptr, uintD* destptr, uintC count, uintC i);
|
||
|
entry
|
||
|
@@ -1593,7 +1593,7 @@
|
||
|
LABEL(shiftleftcopy_loop_down_l1)
|
||
|
BICS ip,a3,#3 /* set counter to multiple of 4 */
|
||
|
MOVEQ a1,v5 /* if zero then we're done */
|
||
|
- LDMEQFD sp!,{v5,v6,pc}^ /* so return last shift out */
|
||
|
+ LDMEQFD sp!,{v5,v6,pc} /* so return last shift out */
|
||
|
STMFD sp!,{v1-v3} /* save work regs */
|
||
|
LABEL(shiftleftcopy_loop_down_l2)
|
||
|
LDMDB a1!,{a3,v1,v2,v3} /* load 4 words in one go */
|
||
|
@@ -1609,7 +1609,7 @@
|
||
|
SUBS ip,ip,#4 /* decrement counter by 4 */
|
||
|
BGT shiftleftcopy_loop_down_l2 /* if count still positive then loop */
|
||
|
MOV a1,v5 /* result = last shift out */
|
||
|
- LDMFD sp!,{v1-v3,v5,v6,pc}^ /* restore work regs and return */
|
||
|
+ LDMFD sp!,{v1-v3,v5,v6,pc} /* restore work regs and return */
|
||
|
|
||
|
/* extern uintD shift1right_loop_up (uintD* ptr, uintC count, uintD carry);
|
||
|
entry
|
||
|
@@ -1630,7 +1630,7 @@
|
||
|
LABEL(shift1right_loop_up_l1)
|
||
|
BICS a4,a2,#1 /* set counter to multiple of 2 */
|
||
|
MOVEQ a1,a4,RRX /* if zero set result to C (a4 is 0) */
|
||
|
- MOVEQS pc,lr /* and return */
|
||
|
+ BXEQ lr /* and return */
|
||
|
ANDS a3,a4,#3 /* multiple of 4 words ? */
|
||
|
BEQ shift1right_loop_up_l3 /* yup, so branch */
|
||
|
LDMIA a1,{a2,a3} /* load 2 words in one go */
|
||
|
@@ -1639,7 +1639,7 @@
|
||
|
STMIA a1!,{a2,a3} /* store 2 results */
|
||
|
BICS a4,a4,#2 /* decrement counter by 2 */
|
||
|
ADCEQ a1,a4,a4 /* set result to Carry (a4 is 0) */
|
||
|
- MOVEQS pc,lr /* and return */
|
||
|
+ BXEQ lr /* and return */
|
||
|
LABEL(shift1right_loop_up_l3) /* now a multiple of 4 words */
|
||
|
STMFD sp!,{lr} /* save work regs */
|
||
|
LABEL(shift1right_loop_up_l2)
|
||
|
@@ -1653,7 +1653,7 @@
|
||
|
TEQ a4,#0 /* are we done ? */
|
||
|
BNE shift1right_loop_up_l2 /* if count non-zero then loop */
|
||
|
MOV a1,a4,RRX /* set result to Carry (a4 is 0) */
|
||
|
- LDMFD sp!,{pc}^ /* restore work regs and return 1 */
|
||
|
+ LDMFD sp!,{pc} /* restore work regs and return 1 */
|
||
|
|
||
|
/* extern uintD shiftright_loop_up (uintD* ptr, uintC count, uintC i);
|
||
|
entry
|
||
|
@@ -1688,7 +1688,7 @@
|
||
|
LABEL(shiftright_loop_up_l1)
|
||
|
BICS ip,a2,#3 /* set counter to multiple of 4 */
|
||
|
MOVEQ a1,a4 /* if zero then we're done */
|
||
|
- LDMEQFD sp!,{v6,pc}^ /* so return last shift out */
|
||
|
+ LDMEQFD sp!,{v6,pc} /* so return last shift out */
|
||
|
STMFD sp!,{v1-v3} /* save work regs */
|
||
|
LABEL(shiftright_loop_up_l2)
|
||
|
LDMIA a1,{v1,v2,v3,lr} /* load 4 words in one go */
|
||
|
@@ -1704,7 +1704,7 @@
|
||
|
SUBS ip,ip,#4 /* decrement counter by 4 */
|
||
|
BGT shiftright_loop_up_l2 /* if count still positive then loop */
|
||
|
MOV a1,a4 /* result = last shift out */
|
||
|
- LDMFD sp!,{v1-v3,v6,pc}^ /* restore work regs and return */
|
||
|
+ LDMFD sp!,{v1-v3,v6,pc} /* restore work regs and return */
|
||
|
|
||
|
/* extern uintD shiftrightsigned_loop_up (uintD* ptr, uintC count, uintC i);
|
||
|
entry
|
||
|
@@ -1759,7 +1759,7 @@
|
||
|
LABEL(shiftrightcopy_loop_up_l1)
|
||
|
BICS ip,a3,#3 /* set counter to multiple of 4 */
|
||
|
MOVEQ a1,v5 /* if zero then we're done */
|
||
|
- LDMEQFD sp!,{v5,v6,pc}^ /* so return last shift out */
|
||
|
+ LDMEQFD sp!,{v5,v6,pc} /* so return last shift out */
|
||
|
STMFD sp!,{v1-v3} /* save work regs */
|
||
|
LABEL(shiftrightcopy_loop_up_l2)
|
||
|
LDMIA a1!,{v1,v2,v3,lr} /* load 4 words in one go */
|
||
|
@@ -1775,7 +1775,7 @@
|
||
|
SUBS ip,ip,#4 /* decrement counter by 4 */
|
||
|
BGT shiftrightcopy_loop_up_l2 /* if count still positive then loop */
|
||
|
MOV a1,v5 /* result = last shift out */
|
||
|
- LDMFD sp!,{v1-v3,v5,v6,pc}^ /* restore work regs and return */
|
||
|
+ LDMFD sp!,{v1-v3,v5,v6,pc} /* restore work regs and return */
|
||
|
|
||
|
#ifndef HAVE_umull
|
||
|
/* mulu32_64_vregs
|
||
|
@@ -1800,7 +1800,7 @@
|
||
|
ADDCS v2,v2,#0x10000 /* carry from above add */
|
||
|
ADDS v1,v4,ip,LSL #16 /* x is now bottom 32 bits of result */
|
||
|
ADC ip,v2,ip,LSR #16 /* hi is top 32 bits */
|
||
|
- MOVS pc,lr
|
||
|
+ BX lr
|
||
|
#endif /* HAVE_umull */
|
||
|
|
||
|
/* extern uintD mulusmall_loop_down (uintD digit, uintD* ptr, uintC len, uintD newdigit);
|
||
|
@@ -1816,7 +1816,7 @@
|
||
|
GLABEL(mulusmall_loop_down)
|
||
|
CMP a3,#0
|
||
|
MOVEQ a1,a4
|
||
|
- MOVEQS pc,lr
|
||
|
+ BXEQ lr
|
||
|
#ifdef HAVE_umull
|
||
|
STMFD sp!,{v1,lr}
|
||
|
LABEL(mulusmall_loop_down_l1)
|
||
|
@@ -1828,7 +1828,7 @@
|
||
|
SUBS a3,a3,#1 /* len-- */
|
||
|
BNE mulusmall_loop_down_l1 /* until len==0 */
|
||
|
MOV a1,a4 /* return carry */
|
||
|
- LDMFD sp!,{v1,pc}^
|
||
|
+ LDMFD sp!,{v1,pc}
|
||
|
#else
|
||
|
STMFD sp!,{v1-v2,lr}
|
||
|
LABEL(mulusmall_loop_down_l1)
|
||
|
@@ -1850,7 +1850,7 @@
|
||
|
SUBS a3,a3,#1 /* len-- */
|
||
|
BNE mulusmall_loop_down_l1 /* until len==0 */
|
||
|
MOV a1,a4 /* return carry */
|
||
|
- LDMFD sp!,{v1-v2,pc}^
|
||
|
+ LDMFD sp!,{v1-v2,pc}
|
||
|
#endif
|
||
|
|
||
|
/* extern void mulu_loop_down (uintD digit, uintD* sourceptr, uintD* destptr, uintC len);
|
||
|
@@ -1875,7 +1875,7 @@
|
||
|
SUBS a4,a4,#1 /* len-- */
|
||
|
BNE mulu_loop_down_l1 /* until len==0 */
|
||
|
STR v5,[a3,#-4]! /* *--destptr = carry */
|
||
|
- LDMFD sp!,{v1,v5,pc}^
|
||
|
+ LDMFD sp!,{v1,v5,pc}
|
||
|
#else
|
||
|
STMFD sp!,{v1-v5,lr}
|
||
|
MOV v5,#0
|
||
|
@@ -1888,7 +1888,7 @@
|
||
|
SUBS a4,a4,#1 /* len-- */
|
||
|
BNE mulu_loop_down_l1 /* until len==0 */
|
||
|
STR v5,[a3,#-4]! /* *--destptr = carry */
|
||
|
- LDMFD sp!,{v1-v5,pc}^
|
||
|
+ LDMFD sp!,{v1-v5,pc}
|
||
|
#endif
|
||
|
|
||
|
/* extern void muluadd_loop_down (uintD digit, uintD* sourceptr, uintD* destptr, uintC len);
|
||
|
@@ -1916,7 +1916,7 @@
|
||
|
SUBS a4,a4,#1 /* len-- */
|
||
|
BNE muluadd_loop_down_l1 /* until len==0 */
|
||
|
MOV a1,v5 /* return carry */
|
||
|
- LDMFD sp!,{v1,v5,pc}^
|
||
|
+ LDMFD sp!,{v1,v5,pc}
|
||
|
#else
|
||
|
STMFD sp!,{v1-v5,lr}
|
||
|
MOV v5,#0
|
||
|
@@ -1932,7 +1932,7 @@
|
||
|
SUBS a4,a4,#1 /* len-- */
|
||
|
BNE muluadd_loop_down_l1 /* until len==0 */
|
||
|
MOV a1,v5 /* return carry */
|
||
|
- LDMFD sp!,{v1-v5,pc}^
|
||
|
+ LDMFD sp!,{v1-v5,pc}
|
||
|
#endif
|
||
|
|
||
|
/* extern void mulusub_loop_down (uintD digit, uintD* sourceptr, uintD* destptr, uintC len);
|
||
|
@@ -1960,7 +1960,7 @@
|
||
|
SUBS a4,a4,#1 /* len-- */
|
||
|
BNE mulusub_loop_down_l1 /* until len==0 */
|
||
|
MOV a1,v5 /* return carry */
|
||
|
- LDMFD sp!,{v1,v5,pc}^
|
||
|
+ LDMFD sp!,{v1,v5,pc}
|
||
|
#else
|
||
|
STMFD sp!,{v1-v5,lr}
|
||
|
MOV v5,#0
|
||
|
@@ -1976,7 +1976,7 @@
|
||
|
SUBS a4,a4,#1 /* len-- */
|
||
|
BNE mulusub_loop_down_l1 /* until len==0 */
|
||
|
MOV a1,v5 /* return carry */
|
||
|
- LDMFD sp!,{v1-v5,pc}^
|
||
|
+ LDMFD sp!,{v1-v5,pc}
|
||
|
#endif
|
||
|
|
||
|
END
|