mirror of
https://github.com/cc65/cc65.git
synced 2025-01-19 02:33:19 +00:00
03d5e5fba0
-415 bytes, -39% cycles, Unit test expanded to cover more cases (there was a bug in 2100 before!)
39 lines
1.1 KiB
ArmAsm
39 lines
1.1 KiB
ArmAsm
; divt.s
|
|
;
|
|
; 2002-10-22, Greg King
|
|
;
|
|
; This signed-division function returns both the quotient and the remainder,
|
|
; in this structure: (quotient in sreg, remainder in AX)
|
|
;
|
|
; typedef struct {
|
|
; int rem, quot;
|
|
; } div_t;
|
|
;
|
|
; div_t __fastcall__ div (int numer, int denom);
|
|
;
|
|
|
|
.export _div
|
|
|
|
.import tosdivax, negax
|
|
.importzp sreg, ptr1, tmp1
|
|
|
|
_div: jsr tosdivax ; Division-operator does most of the work
|
|
|
|
ldy sreg ; low byte remainder from sreg
|
|
sta sreg ; store low byte quotient to sreg
|
|
|
|
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
|
|
|
|
; Adjust the sign of the remainder.
|
|
; It must be the same as the sign of the dividend.
|
|
;
|
|
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
|
|
|
|
Pos: rts
|