2000-05-28 13:40:48 +00:00
|
|
|
;
|
|
|
|
; Ullrich von Bassewitz, 17.08.1998
|
|
|
|
;
|
|
|
|
; CC65 runtime: division for signed long ints
|
|
|
|
;
|
|
|
|
|
|
|
|
; When negating values, we will ignore the possibility here, that one of the
|
|
|
|
; values if $80000000, in which case the negate will fail.
|
|
|
|
|
2013-05-09 13:56:54 +02:00
|
|
|
.export tosdiv0ax, tosdiveax
|
|
|
|
.import poplsargs, udiv32, negeax
|
|
|
|
.importzp sreg, ptr1, tmp1, tmp2
|
2009-08-15 20:58:35 +00:00
|
|
|
|
|
|
|
tosdiv0ax:
|
|
|
|
ldy #$00
|
|
|
|
sty sreg
|
|
|
|
sty sreg+1
|
2000-05-28 13:40:48 +00:00
|
|
|
|
|
|
|
tosdiveax:
|
2013-05-09 13:56:54 +02:00
|
|
|
jsr poplsargs ; Get arguments from stack, adjust sign
|
|
|
|
jsr udiv32 ; Do the division, result is in (ptr1:sreg)
|
2002-09-28 19:55:19 +00:00
|
|
|
ldx ptr1+1 ; Load byte 1 of result
|
|
|
|
|
|
|
|
; Adjust the sign of the result
|
|
|
|
|
|
|
|
lda tmp1 ; Get sign of left operand
|
|
|
|
eor tmp2 ; Calculate sign of result
|
|
|
|
bpl Pos ; Jump if result positive
|
|
|
|
|
|
|
|
; Result is negative
|
|
|
|
|
2013-05-09 13:56:54 +02:00
|
|
|
lda ptr1 ; Load byte 0
|
|
|
|
jmp negeax ; Negate value
|
2002-09-28 19:55:19 +00:00
|
|
|
|
|
|
|
; Result is positive
|
|
|
|
|
|
|
|
Pos: lda ptr1
|
|
|
|
rts
|
|
|
|
|
2000-05-28 13:40:48 +00:00
|
|
|
|