54949f713f
Reorder the code in .fef8 and .fif8 so that in the usual case, we fall through to the blr without taking any branches. The usual case, by my guess, is .fef8 with normalized numbers or .fif8 with small integers. I change .fef8 and .fif8 to pass values on the real stack, not in specific registers. This simplifies the ncg table, and might help me experiment with changes to the ncg table. This change might or might not help mcg. Seems that mcg always uses the stack to pass values to libem, but I have not tested .fef8 or .fif8 with mcg.
66 lines
1.7 KiB
ArmAsm
66 lines
1.7 KiB
ArmAsm
.sect .text
|
|
|
|
! Multiplies two double-precision floats, then splits the product into
|
|
! fraction and integer, like modf(3) in C. On entry:
|
|
!
|
|
! Stack: ( a b -- fraction integer )
|
|
|
|
.define .fif8
|
|
.fif8:
|
|
lfd f1, 8(sp)
|
|
lfd f2, 0(sp)
|
|
fmul f1, f1, f2 ! f1 = a * b
|
|
stfd f1, 0(sp)
|
|
lwz r3, 0(sp) ! r3 = high word
|
|
lwz r4, 4(sp) ! r4 = low word
|
|
|
|
! IEEE double-precision format:
|
|
! sign exponent fraction
|
|
! 0 1..11 12..63
|
|
!
|
|
! Subtract 1023 from the IEEE exponent. If the result is from
|
|
! 0 to 51, then the IEEE fraction has that many integer bits.
|
|
! (IEEE has an implicit 1 before its fraction. If the IEEE
|
|
! fraction has 0 integer bits, we still have an integer.)
|
|
|
|
extrwi r5, r3, 11, 1 ! r5 = IEEE exponent
|
|
addic. r5, r5, -1023 ! r5 = nr of integer bits
|
|
blt 4f ! branch if no integer
|
|
cmpwi r5, 52
|
|
bge 5f ! branch if no fraction
|
|
cmpwi r5, 21
|
|
bge 6f ! branch if large integer
|
|
! fall through if small integer
|
|
|
|
! f1 has r5 = 0 to 20 integer bits in the IEEE fraction.
|
|
! High word has 20 - r5 fraction bits.
|
|
li r6, 20
|
|
subf r6, r5, r6
|
|
srw r3, r3, r6
|
|
li r4, 0 ! clear low word
|
|
slw r3, r3, r6 ! clear fraction in high word
|
|
! fall through
|
|
|
|
1: stw r3, 0(sp)
|
|
stw r4, 4(sp)
|
|
lfd f2, 0(sp) ! integer = high word, low word
|
|
2: fsub f1, f1, f2 ! fraction = value - integer
|
|
3: stfd f1, 8(sp) ! push fraction
|
|
stfd f2, 0(sp) ! push integer
|
|
blr
|
|
|
|
4: ! f1 is a fraction without integer.
|
|
fsub f2, f1, f1 ! integer = zero
|
|
b 3b
|
|
|
|
5: ! f1 is an integer without fraction (or infinity or NaN).
|
|
fmr f2, f1 ! integer = f1
|
|
b 2b
|
|
|
|
6: ! f1 has r5 = 21 to 51 to integer bits.
|
|
! Low word has 52 - r5 fraction bits.
|
|
li r6, 52
|
|
subf r6, r5, r6
|
|
srw r4, r4, r6
|
|
slw r4, r4, r6 ! clear fraction in low word
|
|
b 1b
|