1
0
mirror of https://github.com/catseye/SixtyPical.git synced 2025-01-22 03:30:08 +00:00
SixtyPical/doc/Emitting.markdown

250 lines
4.3 KiB
Markdown
Raw Normal View History

2014-04-03 13:32:06 +01:00
Emitting Ophis from SixtyPical Programs
=======================================
-> Tests for functionality "Emit ASM for SixtyPical program"
-> Functionality "Emit ASM for SixtyPical program" is implemented by
-> shell command "bin/sixtypical emit %(test-file)"
Emitting an `if`.
2014-04-03 13:32:06 +01:00
| assign byte screen $0400
| routine main {
| lda screen
| cmp screen
| if beq {
| tax
| } else {
| tay
| }
| sta screen
| }
= main:
= lda screen
= cmp screen
= BEQ _label_1
= tay
= jmp _past_1
= _label_1:
= tax
= _past_1:
= sta screen
= rts
=
= .data
2014-04-03 13:32:06 +01:00
= .alias screen 1024
Emitting a `repeat`.
2014-04-03 13:32:06 +01:00
| assign byte screen 1024
| reserve byte four : $04
2014-04-03 13:32:06 +01:00
| routine main {
| ldy four
2014-04-03 13:32:06 +01:00
| repeat bne {
| inc screen
| dey
| cpy four
2014-04-03 13:32:06 +01:00
| }
| sty screen
| }
= main:
= ldy four
2014-04-03 13:32:06 +01:00
=
= _repeat_1:
= inc screen
= dey
= cpy four
2014-04-03 13:32:06 +01:00
= BNE _repeat_1
= sty screen
= rts
=
= four: .byte 4
= .data
= .alias screen 1024
2014-04-03 13:32:06 +01:00
Nested ifs.
| routine main {
| if beq {
| if bcc {
| lda #0
| } else {
| if bvs {
| lda #1
| } else {
| lda #2
| }
| }
| } else {
| lda #3
| }
| }
= main:
= BEQ _label_3
= lda #3
= jmp _past_3
= _label_3:
= BCC _label_2
= BVS _label_1
= lda #2
= jmp _past_1
= _label_1:
= lda #1
= _past_1:
= jmp _past_2
= _label_2:
= lda #0
= _past_2:
= _past_3:
= rts
Installing an interrupt handler (at the Kernal level, i.e. with CINV)
| assign byte screen 1024
| assign vector cinv 788
| reserve vector save_cinv
|
| routine main {
2014-04-11 21:26:27 +01:00
| with sei {
| copy cinv save_cinv
2014-04-03 13:32:06 +01:00
| copy routine our_cinv to cinv
| }
| }
|
| routine our_cinv {
| inc screen
| jmp (save_cinv)
2014-04-03 13:32:06 +01:00
| }
= main:
= sei
= lda cinv
= sta save_cinv
= lda cinv+1
= sta save_cinv+1
= lda #<our_cinv
= sta cinv
= lda #>our_cinv
= sta cinv+1
= cli
= rts
=
= our_cinv:
= inc screen
= jmp (save_cinv)
= rts
=
= .data
2014-04-03 13:32:06 +01:00
= .alias screen 1024
= .alias cinv 788
= .space save_cinv 2
Copy command: immediate -> byte
| reserve byte position
| routine main {
| copy #23 position
| }
= main:
= lda #23
= sta position
= rts
=
= .data
= .space position 1
Copy command: immediate -> word
| reserve word position
| routine main {
| copy #$0400 position
| }
= main:
= lda #0
= sta position
= lda #4
= sta position+1
= rts
=
= .data
= .space position 2
2014-04-04 16:54:25 +01:00
`main` is always emitted first.
| reserve word position
| routine foo {
| inx
| }
| routine main {
| jsr foo
| jsr foo
| }
= main:
= jsr foo
= jsr foo
= rts
=
= foo:
= inx
= rts
=
= .data
= .space position 2
Reserving and assigning byte tables.
| reserve byte[16] frequencies
| assign byte[256] screen $0400
| routine main {
| lda #0
| ldy #0
| sta frequencies, y
| sta screen, y
| }
= main:
= lda #0
= ldy #0
= sta frequencies, y
= sta screen, y
= rts
=
= .data
= .space frequencies 16
= .alias screen 1024
Temporary storage, in the form of block-local declarations. Note that these
temporaries are not unioned yet, but they could be.
| routine a {
| reserve byte foo
| reserve word bar
| lda foo
| sta >bar
| }
| routine b {
| reserve byte baz
| reserve word quuz
| lda baz
| sta <quuz
| }
| routine main {
| jsr a
| jsr b
| }
= main:
= jsr a
= jsr b
= rts
= a:
= lda _temp_1
= sta _temp_2+1
= rts
= b:
= lda _temp_3
= sta _temp_4
= rts
=
= .data
= .space _temp_1 1
= .space _temp_2 2
= .space _temp_3 1
= .space _temp_4 2