__aeabi_ldivmod: fix sign logic
. signed 64-bit divide incorrectly tested for sign compensation bits in the NEG (R5) register, causing the signedness of the quotient and modulus to be wrong for negative numerators. Fixes test45 on ARM. Change-Id: Id0df8fd97ea67cd0722db8cdd70a07e01b3d7870
This commit is contained in:
parent
3bc6d7df06
commit
de57a53027
1 changed files with 2 additions and 2 deletions
|
@ -80,9 +80,9 @@ ENTRY(__aeabi_ldivmod)
|
||||||
|
|
||||||
pop {r2, r3}
|
pop {r2, r3}
|
||||||
tst NEG, #2 /* does remainder need to be negative? */
|
tst NEG, #2 /* does remainder need to be negative? */
|
||||||
bleq .Lnegate_b
|
blne .Lnegate_b
|
||||||
tst NEG, #1 /* does quotient need to be negative? */
|
tst NEG, #1 /* does quotient need to be negative? */
|
||||||
bleq .Lnegate_a
|
blne .Lnegate_a
|
||||||
pop {r4-r5, sl, lr}
|
pop {r4-r5, sl, lr}
|
||||||
RET
|
RET
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue