2002-10-25 20:42:18 +00:00
|
|
|
; divt.s
|
|
|
|
;
|
|
|
|
; 2002-10-22, Greg King
|
|
|
|
;
|
|
|
|
; This signed-division function returns both the quotient and the remainder,
|
2024-01-10 22:20:43 +01:00
|
|
|
; in this structure: (quotient in sreg, remainder in AX)
|
2002-10-25 20:42:18 +00:00
|
|
|
;
|
|
|
|
; typedef struct {
|
|
|
|
; int rem, quot;
|
|
|
|
; } div_t;
|
|
|
|
;
|
|
|
|
; div_t __fastcall__ div (int numer, int denom);
|
|
|
|
;
|
|
|
|
|
2013-05-09 13:56:54 +02:00
|
|
|
.export _div
|
2002-10-25 20:42:18 +00:00
|
|
|
|
2013-05-09 13:56:54 +02:00
|
|
|
.import tosdivax, negax
|
|
|
|
.importzp sreg, ptr1, tmp1
|
2002-10-25 20:42:18 +00:00
|
|
|
|
2013-05-09 13:56:54 +02:00
|
|
|
_div: jsr tosdivax ; Division-operator does most of the work
|
2022-04-17 16:06:22 +02:00
|
|
|
|
2018-11-09 15:56:16 +01:00
|
|
|
ldy sreg ; low byte remainder from sreg
|
|
|
|
sta sreg ; store low byte quotient to sreg
|
2022-04-17 16:06:22 +02:00
|
|
|
|
2018-11-09 15:56:16 +01:00
|
|
|
lda sreg+1 ; high byte remainder from sreg
|
|
|
|
stx sreg+1 ; store high byte quotient to sreg
|
|
|
|
|
|
|
|
tax ; high byte remainder to x
|
|
|
|
tya ; low byte remainder to a
|
2002-10-25 20:42:18 +00:00
|
|
|
|
|
|
|
; Adjust the sign of the remainder.
|
|
|
|
; It must be the same as the sign of the dividend.
|
|
|
|
;
|
2013-05-09 13:56:54 +02:00
|
|
|
bit tmp1 ; Load high-byte of left argument
|
|
|
|
bpl Pos ; Jump if sign-of-result is positive
|
|
|
|
jmp negax ; Result is negative, adjust the sign
|
2002-10-25 20:42:18 +00:00
|
|
|
|
2013-05-09 13:56:54 +02:00
|
|
|
Pos: rts
|