2000-05-28 13:40:48 +00:00
|
|
|
;
|
2018-05-25 21:18:26 +00:00
|
|
|
; Ullrich von Bassewitz, 07.08.1998
|
2000-05-28 13:40:48 +00:00
|
|
|
;
|
|
|
|
; CC65 runtime: modulo operation for signed ints
|
|
|
|
;
|
|
|
|
|
|
|
|
; When negating values, we will ignore the possibility here, that one of the
|
2018-05-24 01:55:40 +00:00
|
|
|
; values is $8000, in which case the negate will fail.
|
2000-05-28 13:40:48 +00:00
|
|
|
|
2013-05-09 11:56:54 +00:00
|
|
|
.export tosmoda0, tosmodax
|
2018-05-25 21:18:26 +00:00
|
|
|
.import popsargsudiv16, negax
|
|
|
|
.importzp sreg, tmp1
|
2000-05-28 13:40:48 +00:00
|
|
|
|
|
|
|
tosmoda0:
|
2013-05-09 11:56:54 +00:00
|
|
|
ldx #0
|
2000-05-28 13:40:48 +00:00
|
|
|
tosmodax:
|
2018-05-25 21:18:26 +00:00
|
|
|
jsr popsargsudiv16 ; Get arguments from stack, adjust sign
|
|
|
|
; and do the division
|
|
|
|
lda sreg ; Load low byte of result
|
|
|
|
ldx sreg+1 ; Load high byte of result
|
|
|
|
|
|
|
|
; Adjust the sign of the result. tmp1 contains the high byte of the left
|
|
|
|
; operand, tmp2 contains the high byte of the right operand. The sign of
|
|
|
|
; the result of the modulo operation is the same as that of the left
|
|
|
|
; operand
|
|
|
|
|
|
|
|
bit tmp1
|
|
|
|
bpl Pos ; Jump if sign of result positive
|
|
|
|
|
|
|
|
; Result is negative
|
|
|
|
|
|
|
|
jmp negax ; Adjust the sign
|
|
|
|
|
|
|
|
; Result is positive
|
|
|
|
|
|
|
|
Pos: rts
|
2000-05-28 13:40:48 +00:00
|
|
|
|