1
0
mirror of https://gitlab.com/camelot/kickc.git synced 2024-05-29 03:41:40 +00:00
kickc/src/test/ref/euclid-3.asm

248 lines
4.9 KiB
NASM
Raw Normal View History

2019-07-25 12:55:10 +00:00
/*
* Find greatest common denominator using subtraction-based Euclidian algorithm
2019-07-25 12:55:10 +00:00
* See https://en.wikipedia.org/wiki/Euclidean_algorithm
* Based on facebook post from
*/
// Commodore 64 PRG executable file
.file [name="euclid-3.prg", type="prg", segments="Program"]
.segmentdef Program [segments="Basic, Code, Data"]
.segmentdef Basic [start=$0801]
.segmentdef Code [start=$80d]
.segmentdef Data [startAfter="Code"]
.segment Basic
2019-07-25 12:55:10 +00:00
:BasicUpstart(main)
.label print_screen = $400
.label print_line_cursor = 5
.label print_char_cursor = 2
.segment Code
2019-07-25 12:55:10 +00:00
main: {
2020-02-23 08:44:36 +00:00
// print_cls()
2019-07-25 12:55:10 +00:00
jsr print_cls
2020-02-23 08:44:36 +00:00
// print_euclid(128,2)
lda #<print_screen
sta.z print_line_cursor
lda #>print_screen
sta.z print_line_cursor+1
2019-07-25 12:55:10 +00:00
lda #2
sta.z print_euclid.b
lda #<print_screen
sta.z print_char_cursor
lda #>print_screen
sta.z print_char_cursor+1
2019-07-25 12:55:10 +00:00
lda #$80
sta.z print_euclid.a
2019-07-25 12:55:10 +00:00
jsr print_euclid
lda.z print_line_cursor
sta.z print_char_cursor
lda.z print_line_cursor+1
sta.z print_char_cursor+1
2020-02-23 08:44:36 +00:00
// print_euclid(169,69)
2019-07-25 12:55:10 +00:00
lda #$45
sta.z print_euclid.b
2019-07-25 12:55:10 +00:00
lda #$a9
sta.z print_euclid.a
2019-07-25 12:55:10 +00:00
jsr print_euclid
lda.z print_line_cursor
sta.z print_char_cursor
lda.z print_line_cursor+1
sta.z print_char_cursor+1
2020-02-23 08:44:36 +00:00
// print_euclid(155,55)
2019-07-25 12:55:10 +00:00
lda #$37
sta.z print_euclid.b
2019-07-25 12:55:10 +00:00
lda #$9b
sta.z print_euclid.a
2019-07-25 12:55:10 +00:00
jsr print_euclid
lda.z print_line_cursor
sta.z print_char_cursor
lda.z print_line_cursor+1
sta.z print_char_cursor+1
2020-02-23 08:44:36 +00:00
// print_euclid(199,3)
2019-07-25 12:55:10 +00:00
lda #3
sta.z print_euclid.b
2019-07-25 12:55:10 +00:00
lda #$c7
sta.z print_euclid.a
2019-07-25 12:55:10 +00:00
jsr print_euclid
lda.z print_line_cursor
sta.z print_char_cursor
lda.z print_line_cursor+1
sta.z print_char_cursor+1
2020-02-23 08:44:36 +00:00
// print_euclid(91,26)
2019-07-25 12:55:10 +00:00
lda #$1a
sta.z print_euclid.b
2019-07-25 12:55:10 +00:00
lda #$5b
sta.z print_euclid.a
2019-07-25 12:55:10 +00:00
jsr print_euclid
lda.z print_line_cursor
sta.z print_char_cursor
lda.z print_line_cursor+1
sta.z print_char_cursor+1
2020-02-23 08:44:36 +00:00
// print_euclid(119,187)
2019-07-25 12:55:10 +00:00
lda #$bb
sta.z print_euclid.b
2019-07-25 12:55:10 +00:00
lda #$77
sta.z print_euclid.a
2019-07-25 12:55:10 +00:00
jsr print_euclid
2020-02-23 08:44:36 +00:00
// }
2019-07-25 12:55:10 +00:00
rts
}
// Clear the screen. Also resets current line/char cursor.
print_cls: {
// memset(print_screen, ' ', 1000)
jsr memset
// }
rts
}
// void print_euclid(__zp(4) char a, __zp(7) char b)
2019-07-25 12:55:10 +00:00
print_euclid: {
.label b = 7
.label a = 4
2020-04-13 18:06:30 +00:00
// print_uchar(a)
ldx.z a
2020-04-13 18:06:30 +00:00
jsr print_uchar
2020-02-23 08:44:36 +00:00
// print_char(' ')
2019-07-25 12:55:10 +00:00
lda #' '
jsr print_char
2020-04-13 18:06:30 +00:00
// print_uchar(b)
ldx.z b
2020-04-13 18:06:30 +00:00
jsr print_uchar
2020-02-23 08:44:36 +00:00
// print_char(' ')
2019-07-25 12:55:10 +00:00
lda #' '
jsr print_char
2020-02-23 08:44:36 +00:00
// euclid(a,b)
ldx.z b
2019-07-25 12:55:10 +00:00
jsr euclid
2020-02-23 08:44:36 +00:00
// euclid(a,b)
lda.z euclid.a
2020-04-13 18:06:30 +00:00
// print_uchar(euclid(a,b))
2019-07-25 12:55:10 +00:00
tax
2020-04-13 18:06:30 +00:00
jsr print_uchar
2020-02-23 08:44:36 +00:00
// print_ln()
2019-07-25 12:55:10 +00:00
jsr print_ln
2020-02-23 08:44:36 +00:00
// }
2019-07-25 12:55:10 +00:00
rts
}
// Copies the character c (an unsigned char) to the first num characters of the object pointed to by the argument str.
// void * memset(void *str, char c, unsigned int num)
memset: {
.const c = ' '
.const num = $3e8
.label str = print_screen
.label end = str+num
.label dst = 2
lda #<str
sta.z dst
lda #>str
sta.z dst+1
__b1:
// for(char* dst = str; dst!=end; dst++)
lda.z dst+1
cmp #>end
bne __b2
lda.z dst
cmp #<end
bne __b2
2020-02-23 08:44:36 +00:00
// }
2019-07-25 12:55:10 +00:00
rts
__b2:
// *dst = c
lda #c
ldy #0
sta (dst),y
// for(char* dst = str; dst!=end; dst++)
inc.z dst
bne !+
inc.z dst+1
!:
jmp __b1
2019-07-25 12:55:10 +00:00
}
// Print a char as HEX
// void print_uchar(__register(X) char b)
2020-04-13 18:06:30 +00:00
print_uchar: {
2020-02-23 08:44:36 +00:00
// b>>4
2019-07-25 12:55:10 +00:00
txa
lsr
lsr
lsr
lsr
2020-02-23 08:44:36 +00:00
// print_char(print_hextab[b>>4])
2019-07-25 12:55:10 +00:00
tay
lda print_hextab,y
// Table of hexadecimal digits
2019-07-25 12:55:10 +00:00
jsr print_char
2024-01-02 18:45:16 +00:00
// b&0xf
2019-07-25 12:55:10 +00:00
lda #$f
axs #0
2024-01-02 18:45:16 +00:00
// print_char(print_hextab[b&0xf])
2019-07-25 12:55:10 +00:00
lda print_hextab,x
jsr print_char
2020-02-23 08:44:36 +00:00
// }
2019-07-25 12:55:10 +00:00
rts
}
// Print a single char
// void print_char(__register(A) char ch)
2019-07-25 12:55:10 +00:00
print_char: {
2020-02-23 08:44:36 +00:00
// *(print_char_cursor++) = ch
2019-07-25 12:55:10 +00:00
ldy #0
sta (print_char_cursor),y
2020-02-23 08:44:36 +00:00
// *(print_char_cursor++) = ch;
inc.z print_char_cursor
2019-07-25 12:55:10 +00:00
bne !+
inc.z print_char_cursor+1
2019-07-25 12:55:10 +00:00
!:
2020-02-23 08:44:36 +00:00
// }
2019-07-25 12:55:10 +00:00
rts
}
// __register(A) char euclid(__zp(4) char a, __register(X) char b)
2019-07-25 12:55:10 +00:00
euclid: {
.label a = 4
__b1:
2020-02-23 08:44:36 +00:00
// while (a!=b)
cpx.z a
bne __b2
2020-02-23 08:44:36 +00:00
// }
2019-07-25 12:55:10 +00:00
rts
__b2:
2020-02-23 08:44:36 +00:00
// if(a>b)
cpx.z a
bcc __b3
2020-02-23 08:44:36 +00:00
// b=b-a
2019-07-25 12:55:10 +00:00
txa
sec
sbc.z a
2019-07-25 12:55:10 +00:00
tax
jmp __b1
__b3:
2020-02-23 08:44:36 +00:00
// a=a-b
2019-07-25 12:55:10 +00:00
txa
eor #$ff
sec
adc.z a
sta.z a
jmp __b1
2019-07-25 12:55:10 +00:00
}
// Print a newline
print_ln: {
__b1:
2024-01-02 18:45:16 +00:00
// print_line_cursor + 0x28
lda #$28
clc
adc.z print_line_cursor
sta.z print_line_cursor
bcc !+
inc.z print_line_cursor+1
!:
// while (print_line_cursor<print_char_cursor)
lda.z print_line_cursor+1
cmp.z print_char_cursor+1
bcc __b1
2019-07-25 12:55:10 +00:00
bne !+
lda.z print_line_cursor
cmp.z print_char_cursor
bcc __b1
2019-07-25 12:55:10 +00:00
!:
// }
rts
2019-07-25 12:55:10 +00:00
}
.segment Data
2019-07-25 12:55:10 +00:00
print_hextab: .text "0123456789abcdef"