mirror of
https://github.com/cc65/cc65.git
synced 2024-12-23 19:29:37 +00:00
53dd513176
which included commits to RCS files with non-trunk default branches. git-svn-id: svn://svn.cc65.org/cc65/trunk@3 b7a2c559-68d2-44c3-8de9-860c34a00d81
77 lines
1.3 KiB
ArmAsm
77 lines
1.3 KiB
ArmAsm
;
|
|
; Ullrich von Bassewitz, 13.08.1998
|
|
;
|
|
; CC65 runtime: helper stuff for mod/div/mul with long signed ints
|
|
;
|
|
|
|
; When negating values, we will ignore the possibility here, that one of the
|
|
; values if $80000000, in which case the negate will fail.
|
|
|
|
.export poplsargs, adjlsres
|
|
.import getlop, negeax
|
|
.importzp sreg, tmp1, ptr1, ptr3, ptr4
|
|
|
|
poplsargs:
|
|
jsr getlop ; Get the operands
|
|
|
|
; Calculate the sign of the result, that is sign(op1) * sign(op2) and
|
|
; remember it.
|
|
|
|
lda sreg+1
|
|
eor ptr4+1
|
|
sta tmp1 ; Save it across call
|
|
|
|
; Make both operands positive
|
|
|
|
lda sreg+1 ; Is the operand negative?
|
|
bpl L1 ; Jump if not
|
|
|
|
clc ; Make it positive
|
|
lda ptr1
|
|
eor #$FF
|
|
adc #$01
|
|
sta ptr1
|
|
lda ptr1+1
|
|
eor #$FF
|
|
adc #$00
|
|
sta ptr1+1
|
|
lda sreg
|
|
eor #$FF
|
|
adc #$00
|
|
sta sreg
|
|
lda sreg+1
|
|
eor #$FF
|
|
adc #$00
|
|
sta sreg+1
|
|
|
|
L1: lda ptr4+1 ; Is the operand nagative?
|
|
bpl L2 ; Jump if not
|
|
|
|
clc ; Make it positive
|
|
lda ptr3
|
|
eor #$FF
|
|
adc #$01
|
|
sta ptr3
|
|
lda ptr3+1
|
|
eor #$FF
|
|
adc #$00
|
|
sta ptr3+1
|
|
lda ptr4
|
|
eor #$FF
|
|
adc #$00
|
|
sta ptr4
|
|
lda ptr4+1
|
|
eor #$FF
|
|
adc #$00
|
|
sta ptr4+1
|
|
|
|
L2: rts
|
|
|
|
; Adjust the result of a mod/div/mul operation
|
|
|
|
adjlsres:
|
|
ldy tmp1 ; Check if we must adjust the sign
|
|
bpl L2
|
|
jmp negeax ; Netage value
|
|
|