;
; Ullrich von Bassewitz, 07.08.1998
;
; CC65 runtime: modulo operation for signed ints
;

; When negating values, we will ignore the possibility here, that one of the
; values if $8000, in which case the negate will fail.

        .export         tosmoda0, tosmodax
        .import         popsargs, udiv16, negax
        .importzp       ptr1, tmp1

tosmoda0:
        ldx     #0
tosmodax:
        jsr     popsargs        ; Get arguments from stack, adjust sign
        jsr     udiv16          ; Do the division
        lda     ptr1            ; Load low byte of result
        ldx     ptr1+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