Divison
This commit is contained in:
parent
29b2f431cd
commit
279816add6
1 changed files with 173 additions and 0 deletions
173
division.s
Normal file
173
division.s
Normal file
|
@ -0,0 +1,173 @@
|
||||||
|
PORTB = $6000
|
||||||
|
PORTA = $6001
|
||||||
|
DDRB = $6002
|
||||||
|
DDRA = $6003
|
||||||
|
|
||||||
|
value = $0200 ; 2 bytes
|
||||||
|
mod10 = $0202 ; 2 bytes
|
||||||
|
message = $0204 ; 6 bytes
|
||||||
|
|
||||||
|
E = %10000000
|
||||||
|
RW = %01000000
|
||||||
|
RS = %00100000
|
||||||
|
|
||||||
|
.org $8000
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
reset:
|
||||||
|
lda #%11111111 ; Set all pins on port B to output
|
||||||
|
sta DDRB
|
||||||
|
|
||||||
|
lda #%11100000 ; Set top 3 pins on port A to output
|
||||||
|
sta DDRA
|
||||||
|
|
||||||
|
lda #%00111000 ; Set 8-bit mode; 2-line display; 5x8 font
|
||||||
|
jsr send_inst
|
||||||
|
|
||||||
|
lda #%00001110 ; Display on; cursor on; blink off
|
||||||
|
jsr send_inst
|
||||||
|
|
||||||
|
lda #%00000001 ; Reset display
|
||||||
|
jsr send_inst
|
||||||
|
|
||||||
|
lda #%00000110 ; Increment and shift cursor; don't shift display
|
||||||
|
jsr send_inst
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
;; division rotate minus
|
||||||
|
|
||||||
|
lda #0
|
||||||
|
sta message
|
||||||
|
|
||||||
|
;; initialize value to the conversion number
|
||||||
|
lda number
|
||||||
|
sta value
|
||||||
|
lda number + 1
|
||||||
|
sta value + 1
|
||||||
|
divide:
|
||||||
|
;; initialse remainder to zero
|
||||||
|
lda #0
|
||||||
|
sta mod10
|
||||||
|
sta mod10 + 1
|
||||||
|
clc
|
||||||
|
|
||||||
|
ldx #16
|
||||||
|
divloop:
|
||||||
|
|
||||||
|
;; rotate the quotient
|
||||||
|
rol value
|
||||||
|
rol value + 1
|
||||||
|
rol mod10
|
||||||
|
rol mod10 + 1
|
||||||
|
|
||||||
|
;; a,y = dividend = divisor
|
||||||
|
sec
|
||||||
|
lda mod10
|
||||||
|
sbc #10
|
||||||
|
tay ; save low byte in Y
|
||||||
|
lda mod10 + 1
|
||||||
|
sbc #0
|
||||||
|
bcc ignore_result ; branch if dividend < divosr
|
||||||
|
|
||||||
|
sty mod10
|
||||||
|
sta mod10 + 1
|
||||||
|
|
||||||
|
ignore_result:
|
||||||
|
dex
|
||||||
|
bne divloop
|
||||||
|
rol value ; shift in last bit of quotient
|
||||||
|
rol value + 1
|
||||||
|
|
||||||
|
lda mod10
|
||||||
|
clc
|
||||||
|
adc #"0"
|
||||||
|
jsr push_char
|
||||||
|
|
||||||
|
;; if value != 0 continue dividing
|
||||||
|
lda value
|
||||||
|
ora value + 1
|
||||||
|
bne divide
|
||||||
|
|
||||||
|
|
||||||
|
ldx #0
|
||||||
|
print:
|
||||||
|
lda message,x
|
||||||
|
beq loop
|
||||||
|
jsr send_data
|
||||||
|
inx
|
||||||
|
jmp print
|
||||||
|
|
||||||
|
|
||||||
|
loop:
|
||||||
|
jmp loop
|
||||||
|
|
||||||
|
number: .word 1729
|
||||||
|
|
||||||
|
;; add character in A to start of message
|
||||||
|
push_char:
|
||||||
|
pha ; Push first char on stack
|
||||||
|
ldy #0
|
||||||
|
char_loop:
|
||||||
|
lda message,y ; get char on string and put in X
|
||||||
|
tax
|
||||||
|
pla
|
||||||
|
sta message,y ; pull char off stack and add it to the string
|
||||||
|
iny
|
||||||
|
txa
|
||||||
|
pha ; put char from string and put it back
|
||||||
|
bne char_loop
|
||||||
|
|
||||||
|
pla
|
||||||
|
sta message,y ; Pull null off stack stuff on end of string
|
||||||
|
|
||||||
|
rts
|
||||||
|
|
||||||
|
|
||||||
|
lcd_wait:
|
||||||
|
pha
|
||||||
|
lda #%00000000 ; PORT B to INPUT
|
||||||
|
sta DDRB
|
||||||
|
lcd_busy:
|
||||||
|
lda #RW
|
||||||
|
sta PORTA
|
||||||
|
lda #(RW | E)
|
||||||
|
sta PORTA
|
||||||
|
lda PORTB
|
||||||
|
and #%10000000
|
||||||
|
bne lcd_busy
|
||||||
|
|
||||||
|
lda #RW
|
||||||
|
sta PORTA
|
||||||
|
lda #%11111111 ; PORT B to output
|
||||||
|
sta DDRB
|
||||||
|
pla
|
||||||
|
rts
|
||||||
|
|
||||||
|
send_inst:
|
||||||
|
jsr lcd_wait
|
||||||
|
sta PORTB
|
||||||
|
lda #0 ; Clear RS/RW/E bits
|
||||||
|
sta PORTA
|
||||||
|
lda #E ; Set E bit to send instruction
|
||||||
|
sta PORTA
|
||||||
|
lda #0 ; Clear RS/RW/E bits
|
||||||
|
sta PORTA
|
||||||
|
rts
|
||||||
|
|
||||||
|
send_data:
|
||||||
|
jsr lcd_wait
|
||||||
|
sta PORTB
|
||||||
|
lda #RS ; Set RS; Clear RW/E bits
|
||||||
|
sta PORTA
|
||||||
|
lda #(RS | E) ; Set E bit to send instruction
|
||||||
|
sta PORTA
|
||||||
|
lda #RS ; Clear E bits
|
||||||
|
sta PORTA
|
||||||
|
rts
|
||||||
|
|
||||||
|
|
||||||
|
.org $fffc
|
||||||
|
.word reset
|
||||||
|
.word $0000
|
Loading…
Reference in a new issue