mirror of
https://gitlab.com/camelot/kickc.git
synced 2025-04-05 07:40:39 +00:00
Added support for advanced indirect calls. Calls are now fragments. Added support for @outside_flow ASM tag placing ASM at the end of the current scope. Added support for expanding label names in ASM fragments. Closes #708
This commit is contained in:
parent
92755c6287
commit
d3ed5f774f
@ -1,4 +1,4 @@
|
||||
//KICKC FRAGMENT CACHE 84ae04234 84ae062c1
|
||||
//KICKC FRAGMENT CACHE 8d94f4f71 8d94f7000
|
||||
//FRAGMENT vbuzz=vbuc1
|
||||
ldz #{c1}
|
||||
//FRAGMENT vbuzz_lt_vbuc1_then_la1
|
||||
|
1679
src/main/fragment/cache/fragment-cache-mega45gs02.asm
vendored
1679
src/main/fragment/cache/fragment-cache-mega45gs02.asm
vendored
File diff suppressed because it is too large
Load Diff
@ -1,4 +1,4 @@
|
||||
//KICKC FRAGMENT CACHE 84ae04234 84ae062c1
|
||||
//KICKC FRAGMENT CACHE 8d94f4f71 8d94f7000
|
||||
//FRAGMENT vbuz1=vbuc1
|
||||
lda #{c1}
|
||||
sta {z1}
|
||||
|
579
src/main/fragment/cache/fragment-cache-mos6502x.asm
vendored
579
src/main/fragment/cache/fragment-cache-mos6502x.asm
vendored
@ -1,4 +1,4 @@
|
||||
//KICKC FRAGMENT CACHE 84ae04234 84ae062c1
|
||||
//KICKC FRAGMENT CACHE 8d94f4f71 8d94f7000
|
||||
//FRAGMENT vbuz1=vbuc1
|
||||
lda #{c1}
|
||||
sta {z1}
|
||||
@ -1866,33 +1866,8 @@ lda #<{c1}
|
||||
sta {z1}
|
||||
lda #>{c1}
|
||||
sta {z1}+1
|
||||
//FRAGMENT pprz1=pprz2
|
||||
lda {z2}
|
||||
sta {z1}
|
||||
lda {z2}+1
|
||||
sta {z1}+1
|
||||
//FRAGMENT pprz1=qprc1_derefidx_vbuz2
|
||||
ldy {z2}
|
||||
lda {c1},y
|
||||
sta {z1}
|
||||
lda {c1}+1,y
|
||||
sta {z1}+1
|
||||
//FRAGMENT pprz1=qprc1_derefidx_vbuaa
|
||||
tay
|
||||
lda {c1},y
|
||||
sta {z1}
|
||||
lda {c1}+1,y
|
||||
sta {z1}+1
|
||||
//FRAGMENT pprz1=qprc1_derefidx_vbuxx
|
||||
lda {c1},x
|
||||
sta {z1}
|
||||
lda {c1}+1,x
|
||||
sta {z1}+1
|
||||
//FRAGMENT pprz1=qprc1_derefidx_vbuyy
|
||||
lda {c1},y
|
||||
sta {z1}
|
||||
lda {c1}+1,y
|
||||
sta {z1}+1
|
||||
//FRAGMENT call_vprc1
|
||||
jsr {c1}
|
||||
//FRAGMENT pbuz1_lt_vwuc1_then_la1
|
||||
lda {z1}+1
|
||||
cmp #>{c1}
|
||||
@ -2428,42 +2403,6 @@ tay
|
||||
sta {c1},x
|
||||
//FRAGMENT vbsyy=vbsc1
|
||||
ldy #{c1}
|
||||
//FRAGMENT vbuz1=_stackidxbyte_vbuc1
|
||||
tsx
|
||||
lda STACK_BASE+{c1},x
|
||||
sta {z1}
|
||||
//FRAGMENT _stackpushbyte_=vbuz1
|
||||
lda {z1}
|
||||
pha
|
||||
//FRAGMENT _stackpullbyte_1
|
||||
pla
|
||||
//FRAGMENT vbuz1_eq_vbuc1_then_la1
|
||||
lda #{c1}
|
||||
cmp {z1}
|
||||
beq {la1}
|
||||
//FRAGMENT vbuaa=_stackidxbyte_vbuc1
|
||||
tsx
|
||||
lda STACK_BASE+{c1},x
|
||||
//FRAGMENT vbuxx=_stackidxbyte_vbuc1
|
||||
tsx
|
||||
lda STACK_BASE+{c1},x
|
||||
tax
|
||||
//FRAGMENT vbuyy=_stackidxbyte_vbuc1
|
||||
tsx
|
||||
lda STACK_BASE+{c1},x
|
||||
tay
|
||||
//FRAGMENT _stackpushbyte_=vbuyy
|
||||
tya
|
||||
pha
|
||||
//FRAGMENT vbuaa_eq_vbuc1_then_la1
|
||||
cmp #{c1}
|
||||
beq {la1}
|
||||
//FRAGMENT vbuxx_eq_vbuc1_then_la1
|
||||
cpx #{c1}
|
||||
beq {la1}
|
||||
//FRAGMENT vbuyy_eq_vbuc1_then_la1
|
||||
cpy #{c1}
|
||||
beq {la1}
|
||||
//FRAGMENT vbuxx=vbuxx_plus_vbuc1
|
||||
txa
|
||||
axs #-[{c1}]
|
||||
@ -3594,26 +3533,6 @@ sta {z1}+1
|
||||
//FRAGMENT vwuz1=vwuz1_rol_1
|
||||
asl {z1}
|
||||
rol {z1}+1
|
||||
//FRAGMENT pssz1=pssc1
|
||||
lda #<{c1}
|
||||
sta {z1}
|
||||
lda #>{c1}
|
||||
sta {z1}+1
|
||||
//FRAGMENT pbuz1=qbuz2_derefidx_vbuc1
|
||||
ldy #{c1}
|
||||
lda ({z2}),y
|
||||
sta {z1}
|
||||
iny
|
||||
lda ({z2}),y
|
||||
sta {z1}+1
|
||||
//FRAGMENT pssz1=pssz1_plus_vbuc1
|
||||
lda #{c1}
|
||||
clc
|
||||
adc {z1}
|
||||
sta {z1}
|
||||
bcc !+
|
||||
inc {z1}+1
|
||||
!:
|
||||
//FRAGMENT vwuz1=_deref_pwuc1_minus_vwuc2
|
||||
sec
|
||||
lda {c1}
|
||||
@ -3769,6 +3688,10 @@ sta {z1}
|
||||
lda {z1}+1
|
||||
sbc {c1}+1,y
|
||||
sta {z1}+1
|
||||
//FRAGMENT vbuz1_eq_vbuc1_then_la1
|
||||
lda #{c1}
|
||||
cmp {z1}
|
||||
beq {la1}
|
||||
//FRAGMENT vwuz1=vwuz1_plus_pwuc1_derefidx_vbuz2
|
||||
ldy {z2}
|
||||
clc
|
||||
@ -4031,6 +3954,9 @@ sta {z1}
|
||||
lda {z1}+1
|
||||
sbc {c1}+1,y
|
||||
sta {z1}+1
|
||||
//FRAGMENT vbuxx_eq_vbuc1_then_la1
|
||||
cpx #{c1}
|
||||
beq {la1}
|
||||
//FRAGMENT vwuz1=vwuz1_plus_pwuc1_derefidx_vbuaa
|
||||
tay
|
||||
clc
|
||||
@ -4062,6 +3988,9 @@ dex
|
||||
//FRAGMENT vbuyy=vbuyy_minus_2
|
||||
dey
|
||||
dey
|
||||
//FRAGMENT vbuyy_eq_vbuc1_then_la1
|
||||
cpy #{c1}
|
||||
beq {la1}
|
||||
//FRAGMENT vbuz1=vbuz2_bor_vbuyy
|
||||
tya
|
||||
ora {z2}
|
||||
@ -4121,6 +4050,9 @@ sta {z1}
|
||||
bcc !+
|
||||
inc {z1}+1
|
||||
!:
|
||||
//FRAGMENT vbuaa_eq_vbuc1_then_la1
|
||||
cmp #{c1}
|
||||
beq {la1}
|
||||
//FRAGMENT vbuaa_eq_vbuz1_then_la1
|
||||
cmp {z1}
|
||||
beq {la1}
|
||||
@ -4976,20 +4908,18 @@ sta {c1}
|
||||
tya
|
||||
ora {c1}
|
||||
sta {c1}
|
||||
//FRAGMENT vbuz1_le_vbuc1_then_la1
|
||||
lda #{c1}
|
||||
cmp {z1}
|
||||
bcs {la1}
|
||||
//FRAGMENT vbuaa_le_vbuc1_then_la1
|
||||
cmp #{c1}
|
||||
bcc {la1}
|
||||
beq {la1}
|
||||
//FRAGMENT _stackpushbyte_=vbuc1
|
||||
lda #{c1}
|
||||
pha
|
||||
//FRAGMENT _stackpullbyte_1
|
||||
pla
|
||||
//FRAGMENT vbuz1=_stackpullbyte_
|
||||
pla
|
||||
sta {z1}
|
||||
//FRAGMENT vbuz1=_stackidxbyte_vbuc1
|
||||
tsx
|
||||
lda STACK_BASE+{c1},x
|
||||
sta {z1}
|
||||
//FRAGMENT _stackidxbyte_vbuc1=vbuz1
|
||||
lda {z1}
|
||||
tsx
|
||||
@ -5002,6 +4932,17 @@ tax
|
||||
//FRAGMENT vbuyy=_stackpullbyte_
|
||||
pla
|
||||
tay
|
||||
//FRAGMENT vbuaa=_stackidxbyte_vbuc1
|
||||
tsx
|
||||
lda STACK_BASE+{c1},x
|
||||
//FRAGMENT vbuxx=_stackidxbyte_vbuc1
|
||||
tsx
|
||||
lda STACK_BASE+{c1},x
|
||||
tax
|
||||
//FRAGMENT vbuyy=_stackidxbyte_vbuc1
|
||||
tsx
|
||||
lda STACK_BASE+{c1},x
|
||||
tay
|
||||
//FRAGMENT _stackidxbyte_vbuc1=vbuaa
|
||||
tsx
|
||||
sta STACK_BASE+{c1},x
|
||||
@ -5159,6 +5100,9 @@ lda {z1}
|
||||
sta STACK_BASE+{c1},x
|
||||
lda {z1}+1
|
||||
sta STACK_BASE+{c1}+1,x
|
||||
//FRAGMENT _stackpushbyte_=vbuz1
|
||||
lda {z1}
|
||||
pha
|
||||
//FRAGMENT _stackpushbyte_1
|
||||
pha
|
||||
//FRAGMENT vssz1=_stackpullstruct_2_
|
||||
@ -5342,6 +5286,9 @@ pha
|
||||
lda {z1}
|
||||
tay
|
||||
dey
|
||||
//FRAGMENT _stackpushbyte_=vbuyy
|
||||
tya
|
||||
pha
|
||||
//FRAGMENT vbuz1=vbuaa_minus_1
|
||||
sec
|
||||
sbc #1
|
||||
@ -5919,6 +5866,10 @@ tax
|
||||
//FRAGMENT vbuyy=_byte_vduz1
|
||||
lda {z1}
|
||||
tay
|
||||
//FRAGMENT call__deref_pprc1
|
||||
jsr {c1}
|
||||
//FRAGMENT _deref_pbuc1=_dec__deref_pbuc1
|
||||
dec {c1}
|
||||
//FRAGMENT pbuz1_derefidx_vbuaa=vbuaa
|
||||
tay
|
||||
sta ({z1}),y
|
||||
@ -6404,8 +6355,6 @@ sta {c1}+1
|
||||
//FRAGMENT _deref_pbsc1=vbsc2
|
||||
lda #{c2}
|
||||
sta {c1}
|
||||
//FRAGMENT _deref_pbuc1=_dec__deref_pbuc1
|
||||
dec {c1}
|
||||
//FRAGMENT vbuz1=_dec_vbuz2
|
||||
ldy {z2}
|
||||
dey
|
||||
@ -6622,6 +6571,10 @@ lda {z2}
|
||||
clc
|
||||
adc #2
|
||||
sta {z1}
|
||||
//FRAGMENT vbuz1_le_vbuc1_then_la1
|
||||
lda #{c1}
|
||||
cmp {z1}
|
||||
bcs {la1}
|
||||
//FRAGMENT vbuz1=vbuaa_plus_2
|
||||
clc
|
||||
adc #2
|
||||
@ -6630,6 +6583,10 @@ sta {z1}
|
||||
inx
|
||||
inx
|
||||
stx {z1}
|
||||
//FRAGMENT vbuaa_le_vbuc1_then_la1
|
||||
cmp #{c1}
|
||||
bcc {la1}
|
||||
beq {la1}
|
||||
//FRAGMENT vbuxx_le_vbuc1_then_la1
|
||||
cpx #{c1}
|
||||
bcc {la1}
|
||||
@ -8708,6 +8665,18 @@ tax
|
||||
lda {c1}
|
||||
eor #$ff
|
||||
tay
|
||||
//FRAGMENT pssz1=pssc1
|
||||
lda #<{c1}
|
||||
sta {z1}
|
||||
lda #>{c1}
|
||||
sta {z1}+1
|
||||
//FRAGMENT pbuz1=qbuz2_derefidx_vbuc1
|
||||
ldy #{c1}
|
||||
lda ({z2}),y
|
||||
sta {z1}
|
||||
iny
|
||||
lda ({z2}),y
|
||||
sta {z1}+1
|
||||
//FRAGMENT vwuz1=pwuz2_derefidx_vbuc1
|
||||
ldy #{c1}
|
||||
lda ({z2}),y
|
||||
@ -8715,6 +8684,14 @@ sta {z1}
|
||||
iny
|
||||
lda ({z2}),y
|
||||
sta {z1}+1
|
||||
//FRAGMENT pssz1=pssz1_plus_vbuc1
|
||||
lda #{c1}
|
||||
clc
|
||||
adc {z1}
|
||||
sta {z1}
|
||||
bcc !+
|
||||
inc {z1}+1
|
||||
!:
|
||||
//FRAGMENT _deref_pwsc1=vwsc2
|
||||
lda #<{c2}
|
||||
sta {c1}
|
||||
@ -11639,153 +11616,6 @@ ldy {c1}+1
|
||||
sty $ff
|
||||
ldy #0
|
||||
sta ($fe),y
|
||||
//FRAGMENT vbuz1=vbuz2_bxor_vbuz3
|
||||
lda {z2}
|
||||
eor {z3}
|
||||
sta {z1}
|
||||
//FRAGMENT _stackpushbyte_=pbuc1_derefidx_vbuz1
|
||||
ldy {z1}
|
||||
lda {c1},y
|
||||
pha
|
||||
//FRAGMENT vbuz1=vbuz2_bxor_vbuaa
|
||||
eor {z2}
|
||||
sta {z1}
|
||||
//FRAGMENT vbuz1=vbuz2_bxor_vbuxx
|
||||
txa
|
||||
eor {z2}
|
||||
sta {z1}
|
||||
//FRAGMENT vbuz1=vbuz2_bxor_vbuyy
|
||||
tya
|
||||
eor {z2}
|
||||
sta {z1}
|
||||
//FRAGMENT vbuz1=vbuyy_bxor_vbuz2
|
||||
tya
|
||||
eor {z2}
|
||||
sta {z1}
|
||||
//FRAGMENT vbuz1=vbuyy_bxor_vbuaa
|
||||
sty $ff
|
||||
eor $ff
|
||||
sta {z1}
|
||||
//FRAGMENT vbuz1=vbuyy_bxor_vbuxx
|
||||
txa
|
||||
sty $ff
|
||||
eor $ff
|
||||
sta {z1}
|
||||
//FRAGMENT vbuz1=vbuyy_bxor_vbuyy
|
||||
tya
|
||||
sty $ff
|
||||
eor $ff
|
||||
sta {z1}
|
||||
//FRAGMENT vbuaa=vbuz1_bxor_vbuz2
|
||||
lda {z1}
|
||||
eor {z2}
|
||||
//FRAGMENT vbuaa=vbuz1_bxor_vbuaa
|
||||
eor {z1}
|
||||
//FRAGMENT vbuaa=vbuz1_bxor_vbuxx
|
||||
txa
|
||||
eor {z1}
|
||||
//FRAGMENT vbuaa=vbuz1_bxor_vbuyy
|
||||
tya
|
||||
eor {z1}
|
||||
//FRAGMENT vbuaa=vbuyy_bxor_vbuz1
|
||||
tya
|
||||
eor {z1}
|
||||
//FRAGMENT vbuaa=vbuyy_bxor_vbuaa
|
||||
sty $ff
|
||||
eor $ff
|
||||
//FRAGMENT vbuaa=vbuyy_bxor_vbuxx
|
||||
txa
|
||||
sty $ff
|
||||
eor $ff
|
||||
//FRAGMENT vbuaa=vbuyy_bxor_vbuyy
|
||||
tya
|
||||
sty $ff
|
||||
eor $ff
|
||||
//FRAGMENT vbuxx=vbuz1_bxor_vbuz2
|
||||
lda {z1}
|
||||
eor {z2}
|
||||
tax
|
||||
//FRAGMENT vbuxx=vbuz1_bxor_vbuaa
|
||||
eor {z1}
|
||||
tax
|
||||
//FRAGMENT vbuxx=vbuz1_bxor_vbuxx
|
||||
txa
|
||||
eor {z1}
|
||||
tax
|
||||
//FRAGMENT vbuxx=vbuz1_bxor_vbuyy
|
||||
tya
|
||||
eor {z1}
|
||||
tax
|
||||
//FRAGMENT vbuxx=vbuyy_bxor_vbuz1
|
||||
tya
|
||||
eor {z1}
|
||||
tax
|
||||
//FRAGMENT vbuxx=vbuyy_bxor_vbuaa
|
||||
sty $ff
|
||||
eor $ff
|
||||
tax
|
||||
//FRAGMENT vbuxx=vbuyy_bxor_vbuxx
|
||||
sty $ff
|
||||
txa
|
||||
eor $ff
|
||||
tax
|
||||
//FRAGMENT vbuxx=vbuyy_bxor_vbuyy
|
||||
tya
|
||||
sty $ff
|
||||
eor $ff
|
||||
tax
|
||||
//FRAGMENT vbuyy=vbuz1_bxor_vbuz2
|
||||
lda {z1}
|
||||
eor {z2}
|
||||
tay
|
||||
//FRAGMENT vbuyy=vbuz1_bxor_vbuaa
|
||||
eor {z1}
|
||||
tay
|
||||
//FRAGMENT vbuyy=vbuz1_bxor_vbuxx
|
||||
txa
|
||||
eor {z1}
|
||||
tay
|
||||
//FRAGMENT vbuyy=vbuz1_bxor_vbuyy
|
||||
tya
|
||||
eor {z1}
|
||||
tay
|
||||
//FRAGMENT vbuyy=vbuyy_bxor_vbuz1
|
||||
tya
|
||||
eor {z1}
|
||||
tay
|
||||
//FRAGMENT vbuyy=vbuyy_bxor_vbuaa
|
||||
sty $ff
|
||||
eor $ff
|
||||
tay
|
||||
//FRAGMENT vbuyy=vbuyy_bxor_vbuxx
|
||||
txa
|
||||
sty $ff
|
||||
eor $ff
|
||||
tay
|
||||
//FRAGMENT vbuyy=vbuyy_bxor_vbuyy
|
||||
tya
|
||||
sty $ff
|
||||
eor $ff
|
||||
tay
|
||||
//FRAGMENT _stackpushbyte_=pbuc1_derefidx_vbuaa
|
||||
tay
|
||||
lda {c1},y
|
||||
pha
|
||||
//FRAGMENT _stackpushbyte_=pbuc1_derefidx_vbuxx
|
||||
lda {c1},x
|
||||
pha
|
||||
//FRAGMENT _stackpushbyte_=pbuc1_derefidx_vbuyy
|
||||
lda {c1},y
|
||||
pha
|
||||
//FRAGMENT vbuyy_gt_vbuaa_then_la1
|
||||
tax
|
||||
sty $ff
|
||||
cpx $ff
|
||||
bcc {la1}
|
||||
//FRAGMENT vbuyy_lt_vbuaa_then_la1
|
||||
sta $ff
|
||||
cpy $ff
|
||||
bcc {la1}
|
||||
//FRAGMENT _deref_pbuc1_eq__deref_pbuc2_then_la1
|
||||
lda {c1}
|
||||
cmp {c2}
|
||||
@ -12274,28 +12104,6 @@ sta ({z1}),y
|
||||
lda #{c2}
|
||||
ldy {m1}
|
||||
sta {c1},y
|
||||
//FRAGMENT qbuc1_derefidx_vbuz1=pbuc2
|
||||
ldy {z1}
|
||||
lda #<{c2}
|
||||
sta {c1},y
|
||||
lda #>{c2}
|
||||
sta {c1}+1,y
|
||||
//FRAGMENT qbuc1_derefidx_vbuaa=pbuc2
|
||||
tay
|
||||
lda #<{c2}
|
||||
sta {c1},y
|
||||
lda #>{c2}
|
||||
sta {c1}+1,y
|
||||
//FRAGMENT qbuc1_derefidx_vbuxx=pbuc2
|
||||
lda #<{c2}
|
||||
sta {c1},x
|
||||
lda #>{c2}
|
||||
sta {c1}+1,x
|
||||
//FRAGMENT qbuc1_derefidx_vbuyy=pbuc2
|
||||
lda #<{c2}
|
||||
sta {c1},y
|
||||
lda #>{c2}
|
||||
sta {c1}+1,y
|
||||
//FRAGMENT pbuz1_ge_pbuc1_then_la1
|
||||
lda {z1}+1
|
||||
cmp #>{c1}
|
||||
@ -12940,15 +12748,6 @@ sta {z1}
|
||||
lda #0
|
||||
adc {z2}+1
|
||||
sta {z1}+1
|
||||
//FRAGMENT pssz1_lt_pssc1_then_la1
|
||||
lda {z1}+1
|
||||
cmp #>{c1}
|
||||
bcc {la1}
|
||||
bne !+
|
||||
lda {z1}
|
||||
cmp #<{c1}
|
||||
bcc {la1}
|
||||
!:
|
||||
//FRAGMENT vbuz1_lt__deref_pbuc1_then_la1
|
||||
lda {z1}
|
||||
cmp {c1}
|
||||
@ -13312,10 +13111,6 @@ sta ({z1}),y
|
||||
//FRAGMENT _deref_pbuc1=_byte_pprz1
|
||||
lda {z1}
|
||||
sta {c1}
|
||||
//FRAGMENT _stackidxbyte_vbuc1=vbuc2
|
||||
lda #{c2}
|
||||
tsx
|
||||
sta STACK_BASE+{c1},x
|
||||
//FRAGMENT vbuz1=vbuz2_band_pbuz3_derefidx_vbuc1
|
||||
lda {z2}
|
||||
ldy #{c1}
|
||||
@ -15715,11 +15510,6 @@ adc ({z1}),y
|
||||
sta {z1}+1
|
||||
pla
|
||||
sta {z1}
|
||||
//FRAGMENT pprz1=_deref_qprc1
|
||||
lda {c1}
|
||||
sta {z1}
|
||||
lda {c1}+1
|
||||
sta {z1}+1
|
||||
//FRAGMENT vbuz1_ge_vbuaa_then_la1
|
||||
ldy {z1}
|
||||
sta $ff
|
||||
@ -16352,3 +16142,230 @@ sta {c1},x
|
||||
lda #{c2}
|
||||
ora {c1},y
|
||||
sta {c1},y
|
||||
//FRAGMENT call__deref_pprz1
|
||||
jsr {la1}
|
||||
{la1}: @outside_flow
|
||||
jmp ({z1}) @outside_flow
|
||||
//FRAGMENT pprz1=pprz2
|
||||
lda {z2}
|
||||
sta {z1}
|
||||
lda {z2}+1
|
||||
sta {z1}+1
|
||||
//FRAGMENT pprz1=qprc1_derefidx_vbuz2
|
||||
ldy {z2}
|
||||
lda {c1},y
|
||||
sta {z1}
|
||||
lda {c1}+1,y
|
||||
sta {z1}+1
|
||||
//FRAGMENT pprz1=qprc1_derefidx_vbuaa
|
||||
tay
|
||||
lda {c1},y
|
||||
sta {z1}
|
||||
lda {c1}+1,y
|
||||
sta {z1}+1
|
||||
//FRAGMENT pprz1=qprc1_derefidx_vbuxx
|
||||
lda {c1},x
|
||||
sta {z1}
|
||||
lda {c1}+1,x
|
||||
sta {z1}+1
|
||||
//FRAGMENT pprz1=qprc1_derefidx_vbuyy
|
||||
lda {c1},y
|
||||
sta {z1}
|
||||
lda {c1}+1,y
|
||||
sta {z1}+1
|
||||
//FRAGMENT vbuz1=vbuz2_bxor_vbuz3
|
||||
lda {z2}
|
||||
eor {z3}
|
||||
sta {z1}
|
||||
//FRAGMENT _stackpushbyte_=pbuc1_derefidx_vbuz1
|
||||
ldy {z1}
|
||||
lda {c1},y
|
||||
pha
|
||||
//FRAGMENT vbuz1=vbuz2_bxor_vbuaa
|
||||
eor {z2}
|
||||
sta {z1}
|
||||
//FRAGMENT vbuz1=vbuz2_bxor_vbuxx
|
||||
txa
|
||||
eor {z2}
|
||||
sta {z1}
|
||||
//FRAGMENT vbuz1=vbuz2_bxor_vbuyy
|
||||
tya
|
||||
eor {z2}
|
||||
sta {z1}
|
||||
//FRAGMENT vbuz1=vbuyy_bxor_vbuz2
|
||||
tya
|
||||
eor {z2}
|
||||
sta {z1}
|
||||
//FRAGMENT vbuz1=vbuyy_bxor_vbuaa
|
||||
sty $ff
|
||||
eor $ff
|
||||
sta {z1}
|
||||
//FRAGMENT vbuz1=vbuyy_bxor_vbuxx
|
||||
txa
|
||||
sty $ff
|
||||
eor $ff
|
||||
sta {z1}
|
||||
//FRAGMENT vbuz1=vbuyy_bxor_vbuyy
|
||||
tya
|
||||
sty $ff
|
||||
eor $ff
|
||||
sta {z1}
|
||||
//FRAGMENT vbuaa=vbuz1_bxor_vbuz2
|
||||
lda {z1}
|
||||
eor {z2}
|
||||
//FRAGMENT vbuaa=vbuz1_bxor_vbuaa
|
||||
eor {z1}
|
||||
//FRAGMENT vbuaa=vbuz1_bxor_vbuxx
|
||||
txa
|
||||
eor {z1}
|
||||
//FRAGMENT vbuaa=vbuz1_bxor_vbuyy
|
||||
tya
|
||||
eor {z1}
|
||||
//FRAGMENT vbuaa=vbuyy_bxor_vbuz1
|
||||
tya
|
||||
eor {z1}
|
||||
//FRAGMENT vbuaa=vbuyy_bxor_vbuaa
|
||||
sty $ff
|
||||
eor $ff
|
||||
//FRAGMENT vbuaa=vbuyy_bxor_vbuxx
|
||||
txa
|
||||
sty $ff
|
||||
eor $ff
|
||||
//FRAGMENT vbuaa=vbuyy_bxor_vbuyy
|
||||
tya
|
||||
sty $ff
|
||||
eor $ff
|
||||
//FRAGMENT vbuxx=vbuz1_bxor_vbuz2
|
||||
lda {z1}
|
||||
eor {z2}
|
||||
tax
|
||||
//FRAGMENT vbuxx=vbuz1_bxor_vbuaa
|
||||
eor {z1}
|
||||
tax
|
||||
//FRAGMENT vbuxx=vbuz1_bxor_vbuxx
|
||||
txa
|
||||
eor {z1}
|
||||
tax
|
||||
//FRAGMENT vbuxx=vbuz1_bxor_vbuyy
|
||||
tya
|
||||
eor {z1}
|
||||
tax
|
||||
//FRAGMENT vbuxx=vbuyy_bxor_vbuz1
|
||||
tya
|
||||
eor {z1}
|
||||
tax
|
||||
//FRAGMENT vbuxx=vbuyy_bxor_vbuaa
|
||||
sty $ff
|
||||
eor $ff
|
||||
tax
|
||||
//FRAGMENT vbuxx=vbuyy_bxor_vbuxx
|
||||
sty $ff
|
||||
txa
|
||||
eor $ff
|
||||
tax
|
||||
//FRAGMENT vbuxx=vbuyy_bxor_vbuyy
|
||||
tya
|
||||
sty $ff
|
||||
eor $ff
|
||||
tax
|
||||
//FRAGMENT vbuyy=vbuz1_bxor_vbuz2
|
||||
lda {z1}
|
||||
eor {z2}
|
||||
tay
|
||||
//FRAGMENT vbuyy=vbuz1_bxor_vbuaa
|
||||
eor {z1}
|
||||
tay
|
||||
//FRAGMENT vbuyy=vbuz1_bxor_vbuxx
|
||||
txa
|
||||
eor {z1}
|
||||
tay
|
||||
//FRAGMENT vbuyy=vbuz1_bxor_vbuyy
|
||||
tya
|
||||
eor {z1}
|
||||
tay
|
||||
//FRAGMENT vbuyy=vbuyy_bxor_vbuz1
|
||||
tya
|
||||
eor {z1}
|
||||
tay
|
||||
//FRAGMENT vbuyy=vbuyy_bxor_vbuaa
|
||||
sty $ff
|
||||
eor $ff
|
||||
tay
|
||||
//FRAGMENT vbuyy=vbuyy_bxor_vbuxx
|
||||
txa
|
||||
sty $ff
|
||||
eor $ff
|
||||
tay
|
||||
//FRAGMENT vbuyy=vbuyy_bxor_vbuyy
|
||||
tya
|
||||
sty $ff
|
||||
eor $ff
|
||||
tay
|
||||
//FRAGMENT _stackpushbyte_=pbuc1_derefidx_vbuaa
|
||||
tay
|
||||
lda {c1},y
|
||||
pha
|
||||
//FRAGMENT _stackpushbyte_=pbuc1_derefidx_vbuxx
|
||||
lda {c1},x
|
||||
pha
|
||||
//FRAGMENT _stackpushbyte_=pbuc1_derefidx_vbuyy
|
||||
lda {c1},y
|
||||
pha
|
||||
//FRAGMENT vbuyy_gt_vbuaa_then_la1
|
||||
tax
|
||||
sty $ff
|
||||
cpx $ff
|
||||
bcc {la1}
|
||||
//FRAGMENT vbuyy_lt_vbuaa_then_la1
|
||||
sta $ff
|
||||
cpy $ff
|
||||
bcc {la1}
|
||||
//FRAGMENT _stackidxbyte_vbuc1=vbuc2
|
||||
lda #{c2}
|
||||
tsx
|
||||
sta STACK_BASE+{c1},x
|
||||
//FRAGMENT pprz1=_deref_qprc1
|
||||
lda {c1}
|
||||
sta {z1}
|
||||
lda {c1}+1
|
||||
sta {z1}+1
|
||||
//FRAGMENT qbuc1_derefidx_vbuz1=pbuc2
|
||||
ldy {z1}
|
||||
lda #<{c2}
|
||||
sta {c1},y
|
||||
lda #>{c2}
|
||||
sta {c1}+1,y
|
||||
//FRAGMENT qbuc1_derefidx_vbuaa=pbuc2
|
||||
tay
|
||||
lda #<{c2}
|
||||
sta {c1},y
|
||||
lda #>{c2}
|
||||
sta {c1}+1,y
|
||||
//FRAGMENT qbuc1_derefidx_vbuxx=pbuc2
|
||||
lda #<{c2}
|
||||
sta {c1},x
|
||||
lda #>{c2}
|
||||
sta {c1}+1,x
|
||||
//FRAGMENT qbuc1_derefidx_vbuyy=pbuc2
|
||||
lda #<{c2}
|
||||
sta {c1},y
|
||||
lda #>{c2}
|
||||
sta {c1}+1,y
|
||||
//FRAGMENT pssz1_lt_pssc1_then_la1
|
||||
lda {z1}+1
|
||||
cmp #>{c1}
|
||||
bcc {la1}
|
||||
bne !+
|
||||
lda {z1}
|
||||
cmp #<{c1}
|
||||
bcc {la1}
|
||||
!:
|
||||
//FRAGMENT call__deref_(qprz1_derefidx_vbuc1)
|
||||
ldy #{c1}
|
||||
lda ({z1}),y
|
||||
sta !+ +1
|
||||
iny
|
||||
lda ({z1}),y
|
||||
sta !+ +2
|
||||
!:
|
||||
jsr $0000
|
||||
|
@ -1,4 +1,4 @@
|
||||
//KICKC FRAGMENT CACHE 84ae04234 84ae062c1
|
||||
//KICKC FRAGMENT CACHE 8d94f4f71 8d94f7000
|
||||
//FRAGMENT _deref_pbuc1=_inc__deref_pbuc1
|
||||
inc {c1}
|
||||
//FRAGMENT isr_hardware_all_entry
|
||||
|
@ -1,4 +1,4 @@
|
||||
//KICKC FRAGMENT CACHE 84ae04234 84ae062c1
|
||||
//KICKC FRAGMENT CACHE 8d94f4f71 8d94f7000
|
||||
//FRAGMENT vbuz1=_deref_pbuc1
|
||||
lda {c1}
|
||||
sta {z1}
|
||||
|
@ -1,3 +1,3 @@
|
||||
jsr {la1}
|
||||
icall: @outside_flow
|
||||
{la1}: @outside_flow
|
||||
jmp ({z1}) @outside_flow
|
@ -29,6 +29,9 @@ public class AsmProgram {
|
||||
*/
|
||||
private List<AsmChunk> chunks;
|
||||
|
||||
/**Stashed lines to be inserted outside the flow. */
|
||||
private List<AsmLine> stash;
|
||||
|
||||
/**
|
||||
* The index of the next chunk.
|
||||
*/
|
||||
@ -47,6 +50,7 @@ public class AsmProgram {
|
||||
this.chunks = new ArrayList<>();
|
||||
this.nextLineIndex = 0;
|
||||
this.nextChunkIndex = 0;
|
||||
this.stash = new ArrayList<>();
|
||||
}
|
||||
|
||||
public TargetCpu getTargetCpu() {
|
||||
@ -72,6 +76,32 @@ public class AsmProgram {
|
||||
getCurrentChunk().addLine(line);
|
||||
}
|
||||
|
||||
/**
|
||||
* Put an ASM-line into the stash for being added to the program later.
|
||||
* @param line The line
|
||||
*/
|
||||
public void stashLine(AsmLine line) {
|
||||
stash.add(line);
|
||||
}
|
||||
|
||||
/**
|
||||
* Are there any lines in the stash
|
||||
* @return true if there are
|
||||
*/
|
||||
public boolean hasStash() {
|
||||
return stash.size()>0;
|
||||
}
|
||||
|
||||
/**
|
||||
* Add the stash lines to the program - and clear the stash
|
||||
*/
|
||||
public void addStash() {
|
||||
for(AsmLine asmLine : stash) {
|
||||
addLine(asmLine);
|
||||
}
|
||||
stash = new ArrayList<>();
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the current encoding used for strings/chars
|
||||
* @return The encoding
|
||||
|
@ -103,6 +103,12 @@ public class AsmFragmentInstance {
|
||||
} else if(boundValue instanceof Label) {
|
||||
String param = AsmFormat.asmFix(((Label) boundValue).getLocalName());
|
||||
return new AsmParameter(param, false);
|
||||
} else if(boundValue instanceof LabelRef) {
|
||||
String param = AsmFormat.asmFix(((LabelRef) boundValue).getLocalName());
|
||||
return new AsmParameter(param, false);
|
||||
} else if(boundValue instanceof ProcedureRef) {
|
||||
String param = AsmFormat.asmFix(((ProcedureRef) boundValue).getFullName());
|
||||
return new AsmParameter(param, false);
|
||||
} else {
|
||||
throw new InternalError("Bound Value Type not implemented " + boundValue);
|
||||
}
|
||||
@ -198,6 +204,16 @@ public class AsmFragmentInstance {
|
||||
this.visit(context);
|
||||
}
|
||||
|
||||
public void handleTags(AsmLine asmLine, List<TerminalNode> tags) {
|
||||
AsmLine line = addTags(asmLine, tags);
|
||||
if(line.getTags().has("outside_flow")) {
|
||||
// Outside the normal ASM flow - stash them in the program for later
|
||||
asmProgram.stashLine(line);
|
||||
} else {
|
||||
asmProgram.addLine(line);
|
||||
}
|
||||
}
|
||||
|
||||
private static AsmLine addTags(AsmLine asmLine, List<TerminalNode> asmTags) {
|
||||
if(asmTags != null)
|
||||
for(TerminalNode asmTag : asmTags) {
|
||||
@ -209,13 +225,23 @@ public class AsmFragmentInstance {
|
||||
|
||||
@Override
|
||||
public Object visitAsmLabelName(KickCParser.AsmLabelNameContext ctx) {
|
||||
asmProgram.addLine(addTags(new AsmLabel(ctx.ASM_NAME().getText()), ctx.ASM_TAG()));
|
||||
AsmLabel label = new AsmLabel(ctx.ASM_NAME().getText());
|
||||
handleTags(label, ctx.ASM_TAG());
|
||||
return null;
|
||||
}
|
||||
|
||||
@Override
|
||||
public Object visitAsmLabelMulti(KickCParser.AsmLabelMultiContext ctx) {
|
||||
asmProgram.addLine(addTags(new AsmLabel(ctx.ASM_MULTI_NAME().getText()), ctx.ASM_TAG()));
|
||||
AsmLabel label = new AsmLabel(ctx.ASM_MULTI_NAME().getText());
|
||||
handleTags(label, ctx.ASM_TAG());
|
||||
return null;
|
||||
}
|
||||
|
||||
@Override
|
||||
public Object visitAsmLabelReplace(KickCParser.AsmLabelReplaceContext ctx) {
|
||||
String replaceName = ctx.ASM_NAME().getText();
|
||||
AsmParameter boundValue = fragmentInstance.getBoundValue(replaceName);
|
||||
handleTags(new AsmLabel(boundValue.getParam()), ctx.ASM_TAG());
|
||||
return null;
|
||||
}
|
||||
|
||||
@ -225,7 +251,8 @@ public class AsmFragmentInstance {
|
||||
for(int i = 1; i < ctx.getChildCount(); i = i + 2) {
|
||||
values.add(ctx.getChild(i).getText());
|
||||
}
|
||||
asmProgram.addLine(addTags(new AsmDataNumeric(null, AsmDataNumeric.Type.BYTE, values), ctx.ASM_TAG()));
|
||||
AsmDataNumeric data = new AsmDataNumeric(null, AsmDataNumeric.Type.BYTE, values);
|
||||
handleTags(data, ctx.ASM_TAG());
|
||||
return null;
|
||||
}
|
||||
|
||||
@ -239,7 +266,7 @@ public class AsmFragmentInstance {
|
||||
instruction = (AsmInstruction) this.visit(paramModeCtx);
|
||||
}
|
||||
if(instruction != null) {
|
||||
asmProgram.addLine(addTags(instruction, ctx.ASM_TAG()));
|
||||
handleTags(instruction, ctx.ASM_TAG());
|
||||
} else {
|
||||
throw new RuntimeException("Error parsing ASM fragment line " + name + ".asm\n - Line: " + ctx.getText());
|
||||
}
|
||||
|
@ -62,17 +62,19 @@ public class AsmFragmentInstanceSpecBuilder {
|
||||
* Create a fragment instance spec factory for an indirect call
|
||||
* @return the fragment instance spec factory
|
||||
*/
|
||||
public static AsmFragmentInstanceSpecBuilder call(StatementCallExecute call, Program program) {
|
||||
return new AsmFragmentInstanceSpecBuilder(call, program);
|
||||
public static AsmFragmentInstanceSpecBuilder call(StatementCallExecute call, int indirectCallId, Program program) {
|
||||
return new AsmFragmentInstanceSpecBuilder(call, indirectCallId, program);
|
||||
}
|
||||
|
||||
private AsmFragmentInstanceSpecBuilder(StatementCallExecute call, Program program) {
|
||||
private AsmFragmentInstanceSpecBuilder(StatementCallExecute call, int indirectCallId, Program program) {
|
||||
this.program = program;
|
||||
this.bindings = new LinkedHashMap<>();
|
||||
ScopeRef codeScope = program.getStatementInfos().getBlock(call).getScope();
|
||||
StringBuilder signature = new StringBuilder();
|
||||
signature.append("call_");
|
||||
signature.append(bind(call.getProcedureRVal()));
|
||||
RValue procRVal = call.getProcedureRVal();
|
||||
signature.append(bind(procRVal));
|
||||
bind("la1", new LabelRef(codeScope.getFullName()+"::"+"icall"+indirectCallId));
|
||||
this.asmFragmentInstanceSpec = new AsmFragmentInstanceSpec(program, signature.toString(), bindings, codeScope);
|
||||
}
|
||||
|
||||
@ -487,6 +489,13 @@ public class AsmFragmentInstanceSpecBuilder {
|
||||
String name = getTypePrefix(castType) + getConstName(value);
|
||||
bind(name, value);
|
||||
return name;
|
||||
} else if(value instanceof ProcedureRef) {
|
||||
if(castType == null) {
|
||||
castType = SymbolTypeInference.inferType(program.getScope(), (ProcedureRef) value);
|
||||
}
|
||||
String name = getTypePrefix(castType) + getConstName(value);
|
||||
bind(name, value);
|
||||
return name;
|
||||
} else if(value instanceof Label) {
|
||||
String name = "la" + nextLabelIdx++;
|
||||
bind(name, value);
|
||||
|
@ -160,6 +160,7 @@ public class AsmFragmentTemplate {
|
||||
if(signature.contains("c5")) bindings.put("c5", new ConstantInteger(350L));
|
||||
if(signature.contains("c6")) bindings.put("c6", new ConstantInteger(360L));
|
||||
if(signature.contains("la1")) bindings.put("la1", new Label("@1", scope, true));
|
||||
if(signature.startsWith("call_")) bindings.put("la1", new Label("@1", scope, true));
|
||||
AsmFragmentInstance fragmentInstance =
|
||||
new AsmFragmentInstance(new Program(), signature, ScopeRef.ROOT, this, bindings);
|
||||
AsmProgram asm = new AsmProgram(targetCpu);
|
||||
@ -167,6 +168,7 @@ public class AsmFragmentTemplate {
|
||||
fragmentInstance.generate(asm);
|
||||
CpuClobber cpuClobber = asm.getClobber();
|
||||
this.clobber = new AsmFragmentClobber(cpuClobber);
|
||||
asm.addStash();
|
||||
this.cycles = asm.getCycles();
|
||||
}
|
||||
|
||||
|
@ -222,8 +222,10 @@ expr
|
||||
| expr DOT NAME #exprDot
|
||||
| expr '->' NAME #exprArrow
|
||||
| expr PAR_BEGIN parameterList? PAR_END #exprCall
|
||||
| SIZEOF ( expr | PAR_BEGIN typeName PAR_END ) #exprSizeOf
|
||||
| TYPEID ( expr | PAR_BEGIN typeName PAR_END ) #exprTypeId
|
||||
| SIZEOF PAR_BEGIN typeName PAR_END #exprSizeOfType
|
||||
| SIZEOF expr #exprSizeOf
|
||||
| TYPEID PAR_BEGIN typeName PAR_END #exprTypeIdType
|
||||
| TYPEID expr #exprTypeId
|
||||
| DEFINED PAR_BEGIN? NAME PAR_END? #exprDefined
|
||||
| expr BRACKET_BEGIN commaExpr BRACKET_END #exprArray
|
||||
| PAR_BEGIN typeName PAR_END expr #exprCast
|
||||
@ -283,6 +285,7 @@ asmLine
|
||||
|
||||
asmLabel
|
||||
: ASM_NAME ASM_COLON ASM_TAG* #asmLabelName
|
||||
| ASM_CURLY_BEGIN ASM_NAME ASM_CURLY_END ASM_COLON ASM_TAG* #asmLabelReplace
|
||||
| ASM_MULTI_NAME ASM_COLON ASM_TAG* #asmLabelMulti
|
||||
;
|
||||
|
||||
|
File diff suppressed because one or more lines are too long
File diff suppressed because it is too large
Load Diff
@ -1081,30 +1081,6 @@ public class KickCParserBaseListener implements KickCParserListener {
|
||||
* <p>The default implementation does nothing.</p>
|
||||
*/
|
||||
@Override public void exitExprPtr(KickCParser.ExprPtrContext ctx) { }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
* <p>The default implementation does nothing.</p>
|
||||
*/
|
||||
@Override public void enterExprPreMod(KickCParser.ExprPreModContext ctx) { }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
* <p>The default implementation does nothing.</p>
|
||||
*/
|
||||
@Override public void exitExprPreMod(KickCParser.ExprPreModContext ctx) { }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
* <p>The default implementation does nothing.</p>
|
||||
*/
|
||||
@Override public void enterExprBinary(KickCParser.ExprBinaryContext ctx) { }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
* <p>The default implementation does nothing.</p>
|
||||
*/
|
||||
@Override public void exitExprBinary(KickCParser.ExprBinaryContext ctx) { }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
@ -1153,18 +1129,6 @@ public class KickCParserBaseListener implements KickCParserListener {
|
||||
* <p>The default implementation does nothing.</p>
|
||||
*/
|
||||
@Override public void exitExprNumber(KickCParser.ExprNumberContext ctx) { }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
* <p>The default implementation does nothing.</p>
|
||||
*/
|
||||
@Override public void enterExprChar(KickCParser.ExprCharContext ctx) { }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
* <p>The default implementation does nothing.</p>
|
||||
*/
|
||||
@Override public void exitExprChar(KickCParser.ExprCharContext ctx) { }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
@ -1177,30 +1141,6 @@ public class KickCParserBaseListener implements KickCParserListener {
|
||||
* <p>The default implementation does nothing.</p>
|
||||
*/
|
||||
@Override public void exitExprArrow(KickCParser.ExprArrowContext ctx) { }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
* <p>The default implementation does nothing.</p>
|
||||
*/
|
||||
@Override public void enterExprDot(KickCParser.ExprDotContext ctx) { }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
* <p>The default implementation does nothing.</p>
|
||||
*/
|
||||
@Override public void exitExprDot(KickCParser.ExprDotContext ctx) { }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
* <p>The default implementation does nothing.</p>
|
||||
*/
|
||||
@Override public void enterInitList(KickCParser.InitListContext ctx) { }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
* <p>The default implementation does nothing.</p>
|
||||
*/
|
||||
@Override public void exitInitList(KickCParser.InitListContext ctx) { }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
@ -1213,18 +1153,6 @@ public class KickCParserBaseListener implements KickCParserListener {
|
||||
* <p>The default implementation does nothing.</p>
|
||||
*/
|
||||
@Override public void exitExprCast(KickCParser.ExprCastContext ctx) { }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
* <p>The default implementation does nothing.</p>
|
||||
*/
|
||||
@Override public void enterExprCall(KickCParser.ExprCallContext ctx) { }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
* <p>The default implementation does nothing.</p>
|
||||
*/
|
||||
@Override public void exitExprCall(KickCParser.ExprCallContext ctx) { }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
@ -1237,6 +1165,138 @@ public class KickCParserBaseListener implements KickCParserListener {
|
||||
* <p>The default implementation does nothing.</p>
|
||||
*/
|
||||
@Override public void exitExprPar(KickCParser.ExprParContext ctx) { }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
* <p>The default implementation does nothing.</p>
|
||||
*/
|
||||
@Override public void enterExprId(KickCParser.ExprIdContext ctx) { }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
* <p>The default implementation does nothing.</p>
|
||||
*/
|
||||
@Override public void exitExprId(KickCParser.ExprIdContext ctx) { }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
* <p>The default implementation does nothing.</p>
|
||||
*/
|
||||
@Override public void enterExprTernary(KickCParser.ExprTernaryContext ctx) { }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
* <p>The default implementation does nothing.</p>
|
||||
*/
|
||||
@Override public void exitExprTernary(KickCParser.ExprTernaryContext ctx) { }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
* <p>The default implementation does nothing.</p>
|
||||
*/
|
||||
@Override public void enterExprAssignment(KickCParser.ExprAssignmentContext ctx) { }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
* <p>The default implementation does nothing.</p>
|
||||
*/
|
||||
@Override public void exitExprAssignment(KickCParser.ExprAssignmentContext ctx) { }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
* <p>The default implementation does nothing.</p>
|
||||
*/
|
||||
@Override public void enterExprPreMod(KickCParser.ExprPreModContext ctx) { }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
* <p>The default implementation does nothing.</p>
|
||||
*/
|
||||
@Override public void exitExprPreMod(KickCParser.ExprPreModContext ctx) { }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
* <p>The default implementation does nothing.</p>
|
||||
*/
|
||||
@Override public void enterExprBinary(KickCParser.ExprBinaryContext ctx) { }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
* <p>The default implementation does nothing.</p>
|
||||
*/
|
||||
@Override public void exitExprBinary(KickCParser.ExprBinaryContext ctx) { }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
* <p>The default implementation does nothing.</p>
|
||||
*/
|
||||
@Override public void enterExprTypeIdType(KickCParser.ExprTypeIdTypeContext ctx) { }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
* <p>The default implementation does nothing.</p>
|
||||
*/
|
||||
@Override public void exitExprTypeIdType(KickCParser.ExprTypeIdTypeContext ctx) { }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
* <p>The default implementation does nothing.</p>
|
||||
*/
|
||||
@Override public void enterExprChar(KickCParser.ExprCharContext ctx) { }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
* <p>The default implementation does nothing.</p>
|
||||
*/
|
||||
@Override public void exitExprChar(KickCParser.ExprCharContext ctx) { }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
* <p>The default implementation does nothing.</p>
|
||||
*/
|
||||
@Override public void enterExprDot(KickCParser.ExprDotContext ctx) { }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
* <p>The default implementation does nothing.</p>
|
||||
*/
|
||||
@Override public void exitExprDot(KickCParser.ExprDotContext ctx) { }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
* <p>The default implementation does nothing.</p>
|
||||
*/
|
||||
@Override public void enterExprSizeOfType(KickCParser.ExprSizeOfTypeContext ctx) { }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
* <p>The default implementation does nothing.</p>
|
||||
*/
|
||||
@Override public void exitExprSizeOfType(KickCParser.ExprSizeOfTypeContext ctx) { }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
* <p>The default implementation does nothing.</p>
|
||||
*/
|
||||
@Override public void enterInitList(KickCParser.InitListContext ctx) { }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
* <p>The default implementation does nothing.</p>
|
||||
*/
|
||||
@Override public void exitInitList(KickCParser.InitListContext ctx) { }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
* <p>The default implementation does nothing.</p>
|
||||
*/
|
||||
@Override public void enterExprCall(KickCParser.ExprCallContext ctx) { }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
* <p>The default implementation does nothing.</p>
|
||||
*/
|
||||
@Override public void exitExprCall(KickCParser.ExprCallContext ctx) { }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
@ -1285,18 +1345,6 @@ public class KickCParserBaseListener implements KickCParserListener {
|
||||
* <p>The default implementation does nothing.</p>
|
||||
*/
|
||||
@Override public void exitExprBool(KickCParser.ExprBoolContext ctx) { }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
* <p>The default implementation does nothing.</p>
|
||||
*/
|
||||
@Override public void enterExprId(KickCParser.ExprIdContext ctx) { }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
* <p>The default implementation does nothing.</p>
|
||||
*/
|
||||
@Override public void exitExprId(KickCParser.ExprIdContext ctx) { }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
@ -1309,30 +1357,6 @@ public class KickCParserBaseListener implements KickCParserListener {
|
||||
* <p>The default implementation does nothing.</p>
|
||||
*/
|
||||
@Override public void exitExprDefined(KickCParser.ExprDefinedContext ctx) { }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
* <p>The default implementation does nothing.</p>
|
||||
*/
|
||||
@Override public void enterExprTernary(KickCParser.ExprTernaryContext ctx) { }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
* <p>The default implementation does nothing.</p>
|
||||
*/
|
||||
@Override public void exitExprTernary(KickCParser.ExprTernaryContext ctx) { }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
* <p>The default implementation does nothing.</p>
|
||||
*/
|
||||
@Override public void enterExprAssignment(KickCParser.ExprAssignmentContext ctx) { }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
* <p>The default implementation does nothing.</p>
|
||||
*/
|
||||
@Override public void exitExprAssignment(KickCParser.ExprAssignmentContext ctx) { }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
@ -1477,6 +1501,18 @@ public class KickCParserBaseListener implements KickCParserListener {
|
||||
* <p>The default implementation does nothing.</p>
|
||||
*/
|
||||
@Override public void exitAsmLabelName(KickCParser.AsmLabelNameContext ctx) { }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
* <p>The default implementation does nothing.</p>
|
||||
*/
|
||||
@Override public void enterAsmLabelReplace(KickCParser.AsmLabelReplaceContext ctx) { }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
* <p>The default implementation does nothing.</p>
|
||||
*/
|
||||
@Override public void exitAsmLabelReplace(KickCParser.AsmLabelReplaceContext ctx) { }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
|
@ -636,20 +636,6 @@ public class KickCParserBaseVisitor<T> extends AbstractParseTreeVisitor<T> imple
|
||||
* {@link #visitChildren} on {@code ctx}.</p>
|
||||
*/
|
||||
@Override public T visitExprPtr(KickCParser.ExprPtrContext ctx) { return visitChildren(ctx); }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
* <p>The default implementation returns the result of calling
|
||||
* {@link #visitChildren} on {@code ctx}.</p>
|
||||
*/
|
||||
@Override public T visitExprPreMod(KickCParser.ExprPreModContext ctx) { return visitChildren(ctx); }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
* <p>The default implementation returns the result of calling
|
||||
* {@link #visitChildren} on {@code ctx}.</p>
|
||||
*/
|
||||
@Override public T visitExprBinary(KickCParser.ExprBinaryContext ctx) { return visitChildren(ctx); }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
@ -678,13 +664,6 @@ public class KickCParserBaseVisitor<T> extends AbstractParseTreeVisitor<T> imple
|
||||
* {@link #visitChildren} on {@code ctx}.</p>
|
||||
*/
|
||||
@Override public T visitExprNumber(KickCParser.ExprNumberContext ctx) { return visitChildren(ctx); }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
* <p>The default implementation returns the result of calling
|
||||
* {@link #visitChildren} on {@code ctx}.</p>
|
||||
*/
|
||||
@Override public T visitExprChar(KickCParser.ExprCharContext ctx) { return visitChildren(ctx); }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
@ -692,20 +671,6 @@ public class KickCParserBaseVisitor<T> extends AbstractParseTreeVisitor<T> imple
|
||||
* {@link #visitChildren} on {@code ctx}.</p>
|
||||
*/
|
||||
@Override public T visitExprArrow(KickCParser.ExprArrowContext ctx) { return visitChildren(ctx); }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
* <p>The default implementation returns the result of calling
|
||||
* {@link #visitChildren} on {@code ctx}.</p>
|
||||
*/
|
||||
@Override public T visitExprDot(KickCParser.ExprDotContext ctx) { return visitChildren(ctx); }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
* <p>The default implementation returns the result of calling
|
||||
* {@link #visitChildren} on {@code ctx}.</p>
|
||||
*/
|
||||
@Override public T visitInitList(KickCParser.InitListContext ctx) { return visitChildren(ctx); }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
@ -719,14 +684,84 @@ public class KickCParserBaseVisitor<T> extends AbstractParseTreeVisitor<T> imple
|
||||
* <p>The default implementation returns the result of calling
|
||||
* {@link #visitChildren} on {@code ctx}.</p>
|
||||
*/
|
||||
@Override public T visitExprCall(KickCParser.ExprCallContext ctx) { return visitChildren(ctx); }
|
||||
@Override public T visitExprPar(KickCParser.ExprParContext ctx) { return visitChildren(ctx); }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
* <p>The default implementation returns the result of calling
|
||||
* {@link #visitChildren} on {@code ctx}.</p>
|
||||
*/
|
||||
@Override public T visitExprPar(KickCParser.ExprParContext ctx) { return visitChildren(ctx); }
|
||||
@Override public T visitExprId(KickCParser.ExprIdContext ctx) { return visitChildren(ctx); }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
* <p>The default implementation returns the result of calling
|
||||
* {@link #visitChildren} on {@code ctx}.</p>
|
||||
*/
|
||||
@Override public T visitExprTernary(KickCParser.ExprTernaryContext ctx) { return visitChildren(ctx); }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
* <p>The default implementation returns the result of calling
|
||||
* {@link #visitChildren} on {@code ctx}.</p>
|
||||
*/
|
||||
@Override public T visitExprAssignment(KickCParser.ExprAssignmentContext ctx) { return visitChildren(ctx); }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
* <p>The default implementation returns the result of calling
|
||||
* {@link #visitChildren} on {@code ctx}.</p>
|
||||
*/
|
||||
@Override public T visitExprPreMod(KickCParser.ExprPreModContext ctx) { return visitChildren(ctx); }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
* <p>The default implementation returns the result of calling
|
||||
* {@link #visitChildren} on {@code ctx}.</p>
|
||||
*/
|
||||
@Override public T visitExprBinary(KickCParser.ExprBinaryContext ctx) { return visitChildren(ctx); }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
* <p>The default implementation returns the result of calling
|
||||
* {@link #visitChildren} on {@code ctx}.</p>
|
||||
*/
|
||||
@Override public T visitExprTypeIdType(KickCParser.ExprTypeIdTypeContext ctx) { return visitChildren(ctx); }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
* <p>The default implementation returns the result of calling
|
||||
* {@link #visitChildren} on {@code ctx}.</p>
|
||||
*/
|
||||
@Override public T visitExprChar(KickCParser.ExprCharContext ctx) { return visitChildren(ctx); }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
* <p>The default implementation returns the result of calling
|
||||
* {@link #visitChildren} on {@code ctx}.</p>
|
||||
*/
|
||||
@Override public T visitExprDot(KickCParser.ExprDotContext ctx) { return visitChildren(ctx); }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
* <p>The default implementation returns the result of calling
|
||||
* {@link #visitChildren} on {@code ctx}.</p>
|
||||
*/
|
||||
@Override public T visitExprSizeOfType(KickCParser.ExprSizeOfTypeContext ctx) { return visitChildren(ctx); }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
* <p>The default implementation returns the result of calling
|
||||
* {@link #visitChildren} on {@code ctx}.</p>
|
||||
*/
|
||||
@Override public T visitInitList(KickCParser.InitListContext ctx) { return visitChildren(ctx); }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
* <p>The default implementation returns the result of calling
|
||||
* {@link #visitChildren} on {@code ctx}.</p>
|
||||
*/
|
||||
@Override public T visitExprCall(KickCParser.ExprCallContext ctx) { return visitChildren(ctx); }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
@ -755,13 +790,6 @@ public class KickCParserBaseVisitor<T> extends AbstractParseTreeVisitor<T> imple
|
||||
* {@link #visitChildren} on {@code ctx}.</p>
|
||||
*/
|
||||
@Override public T visitExprBool(KickCParser.ExprBoolContext ctx) { return visitChildren(ctx); }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
* <p>The default implementation returns the result of calling
|
||||
* {@link #visitChildren} on {@code ctx}.</p>
|
||||
*/
|
||||
@Override public T visitExprId(KickCParser.ExprIdContext ctx) { return visitChildren(ctx); }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
@ -769,20 +797,6 @@ public class KickCParserBaseVisitor<T> extends AbstractParseTreeVisitor<T> imple
|
||||
* {@link #visitChildren} on {@code ctx}.</p>
|
||||
*/
|
||||
@Override public T visitExprDefined(KickCParser.ExprDefinedContext ctx) { return visitChildren(ctx); }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
* <p>The default implementation returns the result of calling
|
||||
* {@link #visitChildren} on {@code ctx}.</p>
|
||||
*/
|
||||
@Override public T visitExprTernary(KickCParser.ExprTernaryContext ctx) { return visitChildren(ctx); }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
* <p>The default implementation returns the result of calling
|
||||
* {@link #visitChildren} on {@code ctx}.</p>
|
||||
*/
|
||||
@Override public T visitExprAssignment(KickCParser.ExprAssignmentContext ctx) { return visitChildren(ctx); }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
@ -867,6 +881,13 @@ public class KickCParserBaseVisitor<T> extends AbstractParseTreeVisitor<T> imple
|
||||
* {@link #visitChildren} on {@code ctx}.</p>
|
||||
*/
|
||||
@Override public T visitAsmLabelName(KickCParser.AsmLabelNameContext ctx) { return visitChildren(ctx); }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
* <p>The default implementation returns the result of calling
|
||||
* {@link #visitChildren} on {@code ctx}.</p>
|
||||
*/
|
||||
@Override public T visitAsmLabelReplace(KickCParser.AsmLabelReplaceContext ctx) { return visitChildren(ctx); }
|
||||
/**
|
||||
* {@inheritDoc}
|
||||
*
|
||||
|
@ -1031,30 +1031,6 @@ public interface KickCParserListener extends ParseTreeListener {
|
||||
* @param ctx the parse tree
|
||||
*/
|
||||
void exitExprPtr(KickCParser.ExprPtrContext ctx);
|
||||
/**
|
||||
* Enter a parse tree produced by the {@code exprPreMod}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
* @param ctx the parse tree
|
||||
*/
|
||||
void enterExprPreMod(KickCParser.ExprPreModContext ctx);
|
||||
/**
|
||||
* Exit a parse tree produced by the {@code exprPreMod}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
* @param ctx the parse tree
|
||||
*/
|
||||
void exitExprPreMod(KickCParser.ExprPreModContext ctx);
|
||||
/**
|
||||
* Enter a parse tree produced by the {@code exprBinary}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
* @param ctx the parse tree
|
||||
*/
|
||||
void enterExprBinary(KickCParser.ExprBinaryContext ctx);
|
||||
/**
|
||||
* Exit a parse tree produced by the {@code exprBinary}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
* @param ctx the parse tree
|
||||
*/
|
||||
void exitExprBinary(KickCParser.ExprBinaryContext ctx);
|
||||
/**
|
||||
* Enter a parse tree produced by the {@code exprTypeId}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
@ -1103,18 +1079,6 @@ public interface KickCParserListener extends ParseTreeListener {
|
||||
* @param ctx the parse tree
|
||||
*/
|
||||
void exitExprNumber(KickCParser.ExprNumberContext ctx);
|
||||
/**
|
||||
* Enter a parse tree produced by the {@code exprChar}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
* @param ctx the parse tree
|
||||
*/
|
||||
void enterExprChar(KickCParser.ExprCharContext ctx);
|
||||
/**
|
||||
* Exit a parse tree produced by the {@code exprChar}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
* @param ctx the parse tree
|
||||
*/
|
||||
void exitExprChar(KickCParser.ExprCharContext ctx);
|
||||
/**
|
||||
* Enter a parse tree produced by the {@code exprArrow}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
@ -1127,30 +1091,6 @@ public interface KickCParserListener extends ParseTreeListener {
|
||||
* @param ctx the parse tree
|
||||
*/
|
||||
void exitExprArrow(KickCParser.ExprArrowContext ctx);
|
||||
/**
|
||||
* Enter a parse tree produced by the {@code exprDot}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
* @param ctx the parse tree
|
||||
*/
|
||||
void enterExprDot(KickCParser.ExprDotContext ctx);
|
||||
/**
|
||||
* Exit a parse tree produced by the {@code exprDot}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
* @param ctx the parse tree
|
||||
*/
|
||||
void exitExprDot(KickCParser.ExprDotContext ctx);
|
||||
/**
|
||||
* Enter a parse tree produced by the {@code initList}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
* @param ctx the parse tree
|
||||
*/
|
||||
void enterInitList(KickCParser.InitListContext ctx);
|
||||
/**
|
||||
* Exit a parse tree produced by the {@code initList}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
* @param ctx the parse tree
|
||||
*/
|
||||
void exitInitList(KickCParser.InitListContext ctx);
|
||||
/**
|
||||
* Enter a parse tree produced by the {@code exprCast}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
@ -1163,18 +1103,6 @@ public interface KickCParserListener extends ParseTreeListener {
|
||||
* @param ctx the parse tree
|
||||
*/
|
||||
void exitExprCast(KickCParser.ExprCastContext ctx);
|
||||
/**
|
||||
* Enter a parse tree produced by the {@code exprCall}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
* @param ctx the parse tree
|
||||
*/
|
||||
void enterExprCall(KickCParser.ExprCallContext ctx);
|
||||
/**
|
||||
* Exit a parse tree produced by the {@code exprCall}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
* @param ctx the parse tree
|
||||
*/
|
||||
void exitExprCall(KickCParser.ExprCallContext ctx);
|
||||
/**
|
||||
* Enter a parse tree produced by the {@code exprPar}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
@ -1187,6 +1115,138 @@ public interface KickCParserListener extends ParseTreeListener {
|
||||
* @param ctx the parse tree
|
||||
*/
|
||||
void exitExprPar(KickCParser.ExprParContext ctx);
|
||||
/**
|
||||
* Enter a parse tree produced by the {@code exprId}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
* @param ctx the parse tree
|
||||
*/
|
||||
void enterExprId(KickCParser.ExprIdContext ctx);
|
||||
/**
|
||||
* Exit a parse tree produced by the {@code exprId}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
* @param ctx the parse tree
|
||||
*/
|
||||
void exitExprId(KickCParser.ExprIdContext ctx);
|
||||
/**
|
||||
* Enter a parse tree produced by the {@code exprTernary}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
* @param ctx the parse tree
|
||||
*/
|
||||
void enterExprTernary(KickCParser.ExprTernaryContext ctx);
|
||||
/**
|
||||
* Exit a parse tree produced by the {@code exprTernary}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
* @param ctx the parse tree
|
||||
*/
|
||||
void exitExprTernary(KickCParser.ExprTernaryContext ctx);
|
||||
/**
|
||||
* Enter a parse tree produced by the {@code exprAssignment}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
* @param ctx the parse tree
|
||||
*/
|
||||
void enterExprAssignment(KickCParser.ExprAssignmentContext ctx);
|
||||
/**
|
||||
* Exit a parse tree produced by the {@code exprAssignment}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
* @param ctx the parse tree
|
||||
*/
|
||||
void exitExprAssignment(KickCParser.ExprAssignmentContext ctx);
|
||||
/**
|
||||
* Enter a parse tree produced by the {@code exprPreMod}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
* @param ctx the parse tree
|
||||
*/
|
||||
void enterExprPreMod(KickCParser.ExprPreModContext ctx);
|
||||
/**
|
||||
* Exit a parse tree produced by the {@code exprPreMod}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
* @param ctx the parse tree
|
||||
*/
|
||||
void exitExprPreMod(KickCParser.ExprPreModContext ctx);
|
||||
/**
|
||||
* Enter a parse tree produced by the {@code exprBinary}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
* @param ctx the parse tree
|
||||
*/
|
||||
void enterExprBinary(KickCParser.ExprBinaryContext ctx);
|
||||
/**
|
||||
* Exit a parse tree produced by the {@code exprBinary}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
* @param ctx the parse tree
|
||||
*/
|
||||
void exitExprBinary(KickCParser.ExprBinaryContext ctx);
|
||||
/**
|
||||
* Enter a parse tree produced by the {@code exprTypeIdType}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
* @param ctx the parse tree
|
||||
*/
|
||||
void enterExprTypeIdType(KickCParser.ExprTypeIdTypeContext ctx);
|
||||
/**
|
||||
* Exit a parse tree produced by the {@code exprTypeIdType}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
* @param ctx the parse tree
|
||||
*/
|
||||
void exitExprTypeIdType(KickCParser.ExprTypeIdTypeContext ctx);
|
||||
/**
|
||||
* Enter a parse tree produced by the {@code exprChar}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
* @param ctx the parse tree
|
||||
*/
|
||||
void enterExprChar(KickCParser.ExprCharContext ctx);
|
||||
/**
|
||||
* Exit a parse tree produced by the {@code exprChar}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
* @param ctx the parse tree
|
||||
*/
|
||||
void exitExprChar(KickCParser.ExprCharContext ctx);
|
||||
/**
|
||||
* Enter a parse tree produced by the {@code exprDot}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
* @param ctx the parse tree
|
||||
*/
|
||||
void enterExprDot(KickCParser.ExprDotContext ctx);
|
||||
/**
|
||||
* Exit a parse tree produced by the {@code exprDot}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
* @param ctx the parse tree
|
||||
*/
|
||||
void exitExprDot(KickCParser.ExprDotContext ctx);
|
||||
/**
|
||||
* Enter a parse tree produced by the {@code exprSizeOfType}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
* @param ctx the parse tree
|
||||
*/
|
||||
void enterExprSizeOfType(KickCParser.ExprSizeOfTypeContext ctx);
|
||||
/**
|
||||
* Exit a parse tree produced by the {@code exprSizeOfType}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
* @param ctx the parse tree
|
||||
*/
|
||||
void exitExprSizeOfType(KickCParser.ExprSizeOfTypeContext ctx);
|
||||
/**
|
||||
* Enter a parse tree produced by the {@code initList}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
* @param ctx the parse tree
|
||||
*/
|
||||
void enterInitList(KickCParser.InitListContext ctx);
|
||||
/**
|
||||
* Exit a parse tree produced by the {@code initList}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
* @param ctx the parse tree
|
||||
*/
|
||||
void exitInitList(KickCParser.InitListContext ctx);
|
||||
/**
|
||||
* Enter a parse tree produced by the {@code exprCall}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
* @param ctx the parse tree
|
||||
*/
|
||||
void enterExprCall(KickCParser.ExprCallContext ctx);
|
||||
/**
|
||||
* Exit a parse tree produced by the {@code exprCall}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
* @param ctx the parse tree
|
||||
*/
|
||||
void exitExprCall(KickCParser.ExprCallContext ctx);
|
||||
/**
|
||||
* Enter a parse tree produced by the {@code exprSizeOf}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
@ -1235,18 +1295,6 @@ public interface KickCParserListener extends ParseTreeListener {
|
||||
* @param ctx the parse tree
|
||||
*/
|
||||
void exitExprBool(KickCParser.ExprBoolContext ctx);
|
||||
/**
|
||||
* Enter a parse tree produced by the {@code exprId}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
* @param ctx the parse tree
|
||||
*/
|
||||
void enterExprId(KickCParser.ExprIdContext ctx);
|
||||
/**
|
||||
* Exit a parse tree produced by the {@code exprId}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
* @param ctx the parse tree
|
||||
*/
|
||||
void exitExprId(KickCParser.ExprIdContext ctx);
|
||||
/**
|
||||
* Enter a parse tree produced by the {@code exprDefined}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
@ -1259,30 +1307,6 @@ public interface KickCParserListener extends ParseTreeListener {
|
||||
* @param ctx the parse tree
|
||||
*/
|
||||
void exitExprDefined(KickCParser.ExprDefinedContext ctx);
|
||||
/**
|
||||
* Enter a parse tree produced by the {@code exprTernary}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
* @param ctx the parse tree
|
||||
*/
|
||||
void enterExprTernary(KickCParser.ExprTernaryContext ctx);
|
||||
/**
|
||||
* Exit a parse tree produced by the {@code exprTernary}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
* @param ctx the parse tree
|
||||
*/
|
||||
void exitExprTernary(KickCParser.ExprTernaryContext ctx);
|
||||
/**
|
||||
* Enter a parse tree produced by the {@code exprAssignment}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
* @param ctx the parse tree
|
||||
*/
|
||||
void enterExprAssignment(KickCParser.ExprAssignmentContext ctx);
|
||||
/**
|
||||
* Exit a parse tree produced by the {@code exprAssignment}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
* @param ctx the parse tree
|
||||
*/
|
||||
void exitExprAssignment(KickCParser.ExprAssignmentContext ctx);
|
||||
/**
|
||||
* Enter a parse tree produced by the {@code exprArray}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
@ -1417,6 +1441,18 @@ public interface KickCParserListener extends ParseTreeListener {
|
||||
* @param ctx the parse tree
|
||||
*/
|
||||
void exitAsmLabelName(KickCParser.AsmLabelNameContext ctx);
|
||||
/**
|
||||
* Enter a parse tree produced by the {@code asmLabelReplace}
|
||||
* labeled alternative in {@link KickCParser#asmLabel}.
|
||||
* @param ctx the parse tree
|
||||
*/
|
||||
void enterAsmLabelReplace(KickCParser.AsmLabelReplaceContext ctx);
|
||||
/**
|
||||
* Exit a parse tree produced by the {@code asmLabelReplace}
|
||||
* labeled alternative in {@link KickCParser#asmLabel}.
|
||||
* @param ctx the parse tree
|
||||
*/
|
||||
void exitAsmLabelReplace(KickCParser.AsmLabelReplaceContext ctx);
|
||||
/**
|
||||
* Enter a parse tree produced by the {@code asmLabelMulti}
|
||||
* labeled alternative in {@link KickCParser#asmLabel}.
|
||||
|
@ -612,20 +612,6 @@ public interface KickCParserVisitor<T> extends ParseTreeVisitor<T> {
|
||||
* @return the visitor result
|
||||
*/
|
||||
T visitExprPtr(KickCParser.ExprPtrContext ctx);
|
||||
/**
|
||||
* Visit a parse tree produced by the {@code exprPreMod}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
* @param ctx the parse tree
|
||||
* @return the visitor result
|
||||
*/
|
||||
T visitExprPreMod(KickCParser.ExprPreModContext ctx);
|
||||
/**
|
||||
* Visit a parse tree produced by the {@code exprBinary}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
* @param ctx the parse tree
|
||||
* @return the visitor result
|
||||
*/
|
||||
T visitExprBinary(KickCParser.ExprBinaryContext ctx);
|
||||
/**
|
||||
* Visit a parse tree produced by the {@code exprTypeId}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
@ -654,13 +640,6 @@ public interface KickCParserVisitor<T> extends ParseTreeVisitor<T> {
|
||||
* @return the visitor result
|
||||
*/
|
||||
T visitExprNumber(KickCParser.ExprNumberContext ctx);
|
||||
/**
|
||||
* Visit a parse tree produced by the {@code exprChar}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
* @param ctx the parse tree
|
||||
* @return the visitor result
|
||||
*/
|
||||
T visitExprChar(KickCParser.ExprCharContext ctx);
|
||||
/**
|
||||
* Visit a parse tree produced by the {@code exprArrow}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
@ -668,20 +647,6 @@ public interface KickCParserVisitor<T> extends ParseTreeVisitor<T> {
|
||||
* @return the visitor result
|
||||
*/
|
||||
T visitExprArrow(KickCParser.ExprArrowContext ctx);
|
||||
/**
|
||||
* Visit a parse tree produced by the {@code exprDot}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
* @param ctx the parse tree
|
||||
* @return the visitor result
|
||||
*/
|
||||
T visitExprDot(KickCParser.ExprDotContext ctx);
|
||||
/**
|
||||
* Visit a parse tree produced by the {@code initList}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
* @param ctx the parse tree
|
||||
* @return the visitor result
|
||||
*/
|
||||
T visitInitList(KickCParser.InitListContext ctx);
|
||||
/**
|
||||
* Visit a parse tree produced by the {@code exprCast}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
@ -689,13 +654,6 @@ public interface KickCParserVisitor<T> extends ParseTreeVisitor<T> {
|
||||
* @return the visitor result
|
||||
*/
|
||||
T visitExprCast(KickCParser.ExprCastContext ctx);
|
||||
/**
|
||||
* Visit a parse tree produced by the {@code exprCall}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
* @param ctx the parse tree
|
||||
* @return the visitor result
|
||||
*/
|
||||
T visitExprCall(KickCParser.ExprCallContext ctx);
|
||||
/**
|
||||
* Visit a parse tree produced by the {@code exprPar}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
@ -703,6 +661,83 @@ public interface KickCParserVisitor<T> extends ParseTreeVisitor<T> {
|
||||
* @return the visitor result
|
||||
*/
|
||||
T visitExprPar(KickCParser.ExprParContext ctx);
|
||||
/**
|
||||
* Visit a parse tree produced by the {@code exprId}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
* @param ctx the parse tree
|
||||
* @return the visitor result
|
||||
*/
|
||||
T visitExprId(KickCParser.ExprIdContext ctx);
|
||||
/**
|
||||
* Visit a parse tree produced by the {@code exprTernary}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
* @param ctx the parse tree
|
||||
* @return the visitor result
|
||||
*/
|
||||
T visitExprTernary(KickCParser.ExprTernaryContext ctx);
|
||||
/**
|
||||
* Visit a parse tree produced by the {@code exprAssignment}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
* @param ctx the parse tree
|
||||
* @return the visitor result
|
||||
*/
|
||||
T visitExprAssignment(KickCParser.ExprAssignmentContext ctx);
|
||||
/**
|
||||
* Visit a parse tree produced by the {@code exprPreMod}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
* @param ctx the parse tree
|
||||
* @return the visitor result
|
||||
*/
|
||||
T visitExprPreMod(KickCParser.ExprPreModContext ctx);
|
||||
/**
|
||||
* Visit a parse tree produced by the {@code exprBinary}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
* @param ctx the parse tree
|
||||
* @return the visitor result
|
||||
*/
|
||||
T visitExprBinary(KickCParser.ExprBinaryContext ctx);
|
||||
/**
|
||||
* Visit a parse tree produced by the {@code exprTypeIdType}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
* @param ctx the parse tree
|
||||
* @return the visitor result
|
||||
*/
|
||||
T visitExprTypeIdType(KickCParser.ExprTypeIdTypeContext ctx);
|
||||
/**
|
||||
* Visit a parse tree produced by the {@code exprChar}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
* @param ctx the parse tree
|
||||
* @return the visitor result
|
||||
*/
|
||||
T visitExprChar(KickCParser.ExprCharContext ctx);
|
||||
/**
|
||||
* Visit a parse tree produced by the {@code exprDot}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
* @param ctx the parse tree
|
||||
* @return the visitor result
|
||||
*/
|
||||
T visitExprDot(KickCParser.ExprDotContext ctx);
|
||||
/**
|
||||
* Visit a parse tree produced by the {@code exprSizeOfType}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
* @param ctx the parse tree
|
||||
* @return the visitor result
|
||||
*/
|
||||
T visitExprSizeOfType(KickCParser.ExprSizeOfTypeContext ctx);
|
||||
/**
|
||||
* Visit a parse tree produced by the {@code initList}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
* @param ctx the parse tree
|
||||
* @return the visitor result
|
||||
*/
|
||||
T visitInitList(KickCParser.InitListContext ctx);
|
||||
/**
|
||||
* Visit a parse tree produced by the {@code exprCall}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
* @param ctx the parse tree
|
||||
* @return the visitor result
|
||||
*/
|
||||
T visitExprCall(KickCParser.ExprCallContext ctx);
|
||||
/**
|
||||
* Visit a parse tree produced by the {@code exprSizeOf}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
@ -731,13 +766,6 @@ public interface KickCParserVisitor<T> extends ParseTreeVisitor<T> {
|
||||
* @return the visitor result
|
||||
*/
|
||||
T visitExprBool(KickCParser.ExprBoolContext ctx);
|
||||
/**
|
||||
* Visit a parse tree produced by the {@code exprId}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
* @param ctx the parse tree
|
||||
* @return the visitor result
|
||||
*/
|
||||
T visitExprId(KickCParser.ExprIdContext ctx);
|
||||
/**
|
||||
* Visit a parse tree produced by the {@code exprDefined}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
@ -745,20 +773,6 @@ public interface KickCParserVisitor<T> extends ParseTreeVisitor<T> {
|
||||
* @return the visitor result
|
||||
*/
|
||||
T visitExprDefined(KickCParser.ExprDefinedContext ctx);
|
||||
/**
|
||||
* Visit a parse tree produced by the {@code exprTernary}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
* @param ctx the parse tree
|
||||
* @return the visitor result
|
||||
*/
|
||||
T visitExprTernary(KickCParser.ExprTernaryContext ctx);
|
||||
/**
|
||||
* Visit a parse tree produced by the {@code exprAssignment}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
* @param ctx the parse tree
|
||||
* @return the visitor result
|
||||
*/
|
||||
T visitExprAssignment(KickCParser.ExprAssignmentContext ctx);
|
||||
/**
|
||||
* Visit a parse tree produced by the {@code exprArray}
|
||||
* labeled alternative in {@link KickCParser#expr}.
|
||||
@ -838,6 +852,13 @@ public interface KickCParserVisitor<T> extends ParseTreeVisitor<T> {
|
||||
* @return the visitor result
|
||||
*/
|
||||
T visitAsmLabelName(KickCParser.AsmLabelNameContext ctx);
|
||||
/**
|
||||
* Visit a parse tree produced by the {@code asmLabelReplace}
|
||||
* labeled alternative in {@link KickCParser#asmLabel}.
|
||||
* @param ctx the parse tree
|
||||
* @return the visitor result
|
||||
*/
|
||||
T visitAsmLabelReplace(KickCParser.AsmLabelReplaceContext ctx);
|
||||
/**
|
||||
* Visit a parse tree produced by the {@code asmLabelMulti}
|
||||
* labeled alternative in {@link KickCParser#asmLabel}.
|
||||
|
@ -2381,38 +2381,40 @@ public class Pass0GenerateStatementSequence extends KickCParserBaseVisitor<Objec
|
||||
|
||||
@Override
|
||||
public Object visitExprSizeOf(KickCParser.ExprSizeOfContext ctx) {
|
||||
if(ctx.typeName() != null) {
|
||||
// sizeof(type) - add directly
|
||||
SymbolType type = (SymbolType) this.visit(ctx.typeName());
|
||||
return SizeOfConstants.getSizeOfConstantVar(program.getScope(), type);
|
||||
} else {
|
||||
// sizeof(expression) - add a unary expression to be resolved later
|
||||
RValue child = (RValue) this.visit(ctx.expr());
|
||||
Variable tmpVar = addIntermediateVar();
|
||||
SymbolVariableRef tmpVarRef = tmpVar.getRef();
|
||||
Statement stmt = new StatementAssignment((LValue) tmpVarRef, Operators.SIZEOF, child, true, new StatementSource(ctx), ensureUnusedComments(getCommentsSymbol(ctx)));
|
||||
addStatement(stmt);
|
||||
consumeExpr(child);
|
||||
return tmpVarRef;
|
||||
}
|
||||
// sizeof(expression) - add a unary expression to be resolved later
|
||||
RValue child = (RValue) this.visit(ctx.expr());
|
||||
Variable tmpVar = addIntermediateVar();
|
||||
SymbolVariableRef tmpVarRef = tmpVar.getRef();
|
||||
Statement stmt = new StatementAssignment((LValue) tmpVarRef, Operators.SIZEOF, child, true, new StatementSource(ctx), ensureUnusedComments(getCommentsSymbol(ctx)));
|
||||
addStatement(stmt);
|
||||
consumeExpr(child);
|
||||
return tmpVarRef;
|
||||
}
|
||||
|
||||
@Override
|
||||
public Object visitExprSizeOfType(KickCParser.ExprSizeOfTypeContext ctx) {
|
||||
// sizeof(type) - add directly
|
||||
SymbolType type = (SymbolType) this.visit(ctx.typeName());
|
||||
return SizeOfConstants.getSizeOfConstantVar(program.getScope(), type);
|
||||
}
|
||||
|
||||
@Override
|
||||
public Object visitExprTypeId(KickCParser.ExprTypeIdContext ctx) {
|
||||
if(ctx.typeName() != null) {
|
||||
// typeid(type) - add directly
|
||||
SymbolType type = (SymbolType) this.visit(ctx.typeName());
|
||||
return OperatorTypeId.getTypeIdConstantVar(program.getScope(), type);
|
||||
} else {
|
||||
// typeid(expression) - add a unary expression to be resolved later
|
||||
RValue child = (RValue) this.visit(ctx.expr());
|
||||
Variable tmpVar = addIntermediateVar();
|
||||
SymbolVariableRef tmpVarRef = tmpVar.getRef();
|
||||
Statement stmt = new StatementAssignment((LValue) tmpVarRef, Operators.TYPEID, child, true, new StatementSource(ctx), ensureUnusedComments(getCommentsSymbol(ctx)));
|
||||
addStatement(stmt);
|
||||
consumeExpr(child);
|
||||
return tmpVarRef;
|
||||
}
|
||||
// typeid(expression) - add a unary expression to be resolved later
|
||||
RValue child = (RValue) this.visit(ctx.expr());
|
||||
Variable tmpVar = addIntermediateVar();
|
||||
SymbolVariableRef tmpVarRef = tmpVar.getRef();
|
||||
Statement stmt = new StatementAssignment((LValue) tmpVarRef, Operators.TYPEID, child, true, new StatementSource(ctx), ensureUnusedComments(getCommentsSymbol(ctx)));
|
||||
addStatement(stmt);
|
||||
consumeExpr(child);
|
||||
return tmpVarRef;
|
||||
}
|
||||
|
||||
@Override
|
||||
public Object visitExprTypeIdType(KickCParser.ExprTypeIdTypeContext ctx) {
|
||||
// typeid(type) - add directly
|
||||
SymbolType type = (SymbolType) this.visit(ctx.typeName());
|
||||
return OperatorTypeId.getTypeIdConstantVar(program.getScope(), type);
|
||||
}
|
||||
|
||||
@Override
|
||||
|
@ -192,11 +192,8 @@ public class Pass4CodeGeneration {
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* ASM names of variables being used for indirect calls in the current scope (procedure).
|
||||
* These will all be added as indirect JMP's at the end of the procedure scope.
|
||||
*/
|
||||
private List<String> indirectCallAsmNames = new ArrayList<>();
|
||||
/** Counter used to separate indirect calls */
|
||||
private int indirectCallCount = 1;
|
||||
|
||||
/**
|
||||
* Generate the end of a scope
|
||||
@ -206,30 +203,15 @@ public class Pass4CodeGeneration {
|
||||
*/
|
||||
private void generateScopeEnding(AsmProgram asm, ScopeRef currentScope) {
|
||||
if(!ScopeRef.ROOT.equals(currentScope)) {
|
||||
// Generate any indirect calls pending
|
||||
for(String indirectCallAsmName : indirectCallAsmNames) {
|
||||
asm.addLabel("bi_" + indirectCallAsmName);
|
||||
asm.addInstruction("jmp", CpuAddressingMode.IND, indirectCallAsmName, false);
|
||||
}
|
||||
indirectCallAsmNames = new ArrayList<>();
|
||||
if(asm.hasStash())
|
||||
asm.startChunk(currentScope, null, "Outside Flow");
|
||||
// Generate all stashed ASM lines
|
||||
asm.addStash();
|
||||
addData(asm, currentScope);
|
||||
asm.addScopeEnd();
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Add an indirect call to the assembler program. Also queues ASM for the indirect jump to be added at the end of the block.
|
||||
*
|
||||
* @param asm The ASM program being built
|
||||
* @param procedureVariable The variable containing the function pointer
|
||||
* @param codeScopeRef The scope containing the code being generated. Used for adding scope to the name when needed (eg. line.x1 when referencing x1 variable inside line scope from outside line scope).
|
||||
*/
|
||||
private void generateIndirectCall(AsmProgram asm, Variable procedureVariable, ScopeRef codeScopeRef) {
|
||||
String varAsmName = AsmFormat.getAsmSymbolName(program, procedureVariable, codeScopeRef);
|
||||
indirectCallAsmNames.add(varAsmName);
|
||||
asm.addInstruction("jsr", CpuAddressingMode.ABS, "bi_" + varAsmName, false);
|
||||
}
|
||||
|
||||
/**
|
||||
* Generate a comment that describes the procedure signature and parameter transfer
|
||||
*
|
||||
@ -913,52 +895,12 @@ public class Pass4CodeGeneration {
|
||||
} else if(statement instanceof StatementCallExecute) {
|
||||
StatementCallExecute call = (StatementCallExecute) statement;
|
||||
RValue procedureRVal = call.getProcedureRVal();
|
||||
boolean supported = false;
|
||||
if(procedureRVal instanceof ProcedureRef) {
|
||||
asm.getCurrentChunk().setFragment("jsr");
|
||||
asm.addInstruction("jsr", CpuAddressingMode.ABS, call.getProcedure().getFullName(), false);
|
||||
supported = true;
|
||||
} else if(procedureRVal instanceof PointerDereferenceSimple) {
|
||||
RValue pointer = ((PointerDereferenceSimple) procedureRVal).getPointer();
|
||||
while(pointer instanceof CastValue)
|
||||
pointer = ((CastValue) pointer).getValue();
|
||||
if(pointer instanceof VariableRef) {
|
||||
Variable variable = getScope().getVariable((VariableRef) pointer);
|
||||
generateIndirectCall(asm, variable, block.getScope());
|
||||
asm.getCurrentChunk().setClobberOverwrite(CpuClobber.CLOBBER_ALL);
|
||||
supported = true;
|
||||
} else {
|
||||
// Generate ASM for an indirect call
|
||||
AsmFragmentInstanceSpecBuilder asmFragmentInstanceSpecBuilder = AsmFragmentInstanceSpecBuilder.call(call, program);
|
||||
ensureEncoding(asm, asmFragmentInstanceSpecBuilder);
|
||||
generateAsm(asm, asmFragmentInstanceSpecBuilder.getAsmFragmentInstanceSpec());
|
||||
asm.getCurrentChunk().setClobberOverwrite(CpuClobber.CLOBBER_ALL);
|
||||
supported = true;
|
||||
}
|
||||
} else if(procedureRVal instanceof VariableRef) {
|
||||
Variable procedureVariable = getScope().getVariable((VariableRef) procedureRVal);
|
||||
SymbolType procedureVariableType = procedureVariable.getType();
|
||||
if(procedureVariableType instanceof SymbolTypePointer) {
|
||||
if(((SymbolTypePointer) procedureVariableType).getElementType() instanceof SymbolTypeProcedure) {
|
||||
generateIndirectCall(asm, procedureVariable, block.getScope());
|
||||
supported = true;
|
||||
asm.getCurrentChunk().setClobberOverwrite(CpuClobber.CLOBBER_ALL);
|
||||
}
|
||||
}
|
||||
} else if(procedureRVal instanceof ConstantRef) {
|
||||
Variable procedureVariable = getScope().getConstant((ConstantRef) procedureRVal);
|
||||
SymbolType procedureVariableType = procedureVariable.getType();
|
||||
if(procedureVariableType instanceof SymbolTypePointer) {
|
||||
if(((SymbolTypePointer) procedureVariableType).getElementType() instanceof SymbolTypeProcedure) {
|
||||
String varAsmName = AsmFormat.getAsmSymbolName(program, procedureVariable, block.getScope());
|
||||
asm.addInstruction("jsr", CpuAddressingMode.ABS, varAsmName, false);
|
||||
asm.getCurrentChunk().setClobberOverwrite(CpuClobber.CLOBBER_ALL);
|
||||
supported = true;
|
||||
}
|
||||
}
|
||||
}
|
||||
if(!supported) {
|
||||
throw new InternalError("Call Pointer not supported " + statement);
|
||||
// Generate ASM for a call
|
||||
AsmFragmentInstanceSpecBuilder asmFragmentInstanceSpecBuilder = AsmFragmentInstanceSpecBuilder.call(call, indirectCallCount++, program);
|
||||
ensureEncoding(asm, asmFragmentInstanceSpecBuilder);
|
||||
generateAsm(asm, asmFragmentInstanceSpecBuilder.getAsmFragmentInstanceSpec());
|
||||
if(!(procedureRVal instanceof ProcedureRef)) {
|
||||
asm.getCurrentChunk().setClobberOverwrite(CpuClobber.CLOBBER_ALL);
|
||||
}
|
||||
} else if(statement instanceof StatementExprSideEffect) {
|
||||
AsmFragmentInstanceSpecBuilder asmFragmentInstanceSpecBuilder = AsmFragmentInstanceSpecBuilder.exprSideEffect((StatementExprSideEffect) statement, program);
|
||||
|
@ -68,7 +68,7 @@ main: scope:[main] from __start
|
||||
*main::ptr = main::$1
|
||||
call2::param1#0 = 1
|
||||
call2::param2#0 = 2
|
||||
call call2
|
||||
call call2
|
||||
call2::return = call2::return
|
||||
to:main::@1
|
||||
main::@1: scope:[main] from main
|
||||
@ -76,7 +76,7 @@ main::@1: scope:[main] from main
|
||||
*main::ptr = main::$2
|
||||
call2::param1#1 = 3
|
||||
call2::param2#1 = 4
|
||||
call call2
|
||||
call call2
|
||||
call2::return = call2::return
|
||||
to:main::@2
|
||||
main::@2: scope:[main] from main::@1
|
||||
@ -84,7 +84,7 @@ main::@2: scope:[main] from main::@1
|
||||
*main::ptr = main::$3
|
||||
call3::param1#0 = 1
|
||||
call3::param2#0 = 2
|
||||
call call3
|
||||
call call3
|
||||
call3::return#2 = call3::return#1
|
||||
to:main::@3
|
||||
main::@3: scope:[main] from main::@2
|
||||
@ -93,7 +93,7 @@ main::@3: scope:[main] from main::@2
|
||||
*main::ptr = main::$4
|
||||
call3::param1#1 = 3
|
||||
call3::param2#1 = 4
|
||||
call call3
|
||||
call call3
|
||||
call3::return#3 = call3::return#1
|
||||
to:main::@4
|
||||
main::@4: scope:[main] from main::@3
|
||||
@ -107,7 +107,7 @@ main::@return: scope:[main] from main::@4
|
||||
|
||||
void __start()
|
||||
__start: scope:[__start] from
|
||||
call main
|
||||
call main
|
||||
to:__start::@1
|
||||
__start::@1: scope:[__start] from __start
|
||||
to:__start::@return
|
||||
@ -289,25 +289,25 @@ main: scope:[main] from
|
||||
sideeffect stackpullbytes(1)
|
||||
[10] main::$1 = stackpull(byte)
|
||||
[11] *main::ptr = main::$1
|
||||
[12] call call2
|
||||
[12] call call2
|
||||
[13] call2::return = call2::return
|
||||
to:main::@1
|
||||
main::@1: scope:[main] from main
|
||||
[14] main::$2 = call2::return
|
||||
[15] *main::ptr = main::$2
|
||||
[16] call call2
|
||||
[16] call call2
|
||||
[17] call2::return = call2::return
|
||||
to:main::@2
|
||||
main::@2: scope:[main] from main::@1
|
||||
[18] main::$3 = call2::return
|
||||
[19] *main::ptr = main::$3
|
||||
[20] call call3
|
||||
[20] call call3
|
||||
[21] call3::return#2 = call3::return#0
|
||||
to:main::@3
|
||||
main::@3: scope:[main] from main::@2
|
||||
[22] main::$4 = call3::return#2
|
||||
[23] *main::ptr = main::$4
|
||||
[24] call call3
|
||||
[24] call call3
|
||||
[25] call3::return#3 = call3::return#0
|
||||
to:main::@4
|
||||
main::@4: scope:[main] from main::@3
|
||||
@ -540,7 +540,7 @@ main: {
|
||||
// [1] stackpush(byte) = 2 -- _stackpushbyte_=vbuc1
|
||||
lda #2
|
||||
pha
|
||||
// [2] callexecute call1 -- jsr
|
||||
// [2] callexecute call1 -- call_vprc1
|
||||
jsr call1
|
||||
// sideeffect stackpullbytes(1) -- _stackpullbyte_1
|
||||
pla
|
||||
@ -554,7 +554,7 @@ main: {
|
||||
// [7] stackpush(byte) = 4 -- _stackpushbyte_=vbuc1
|
||||
lda #4
|
||||
pha
|
||||
// [8] callexecute call1 -- jsr
|
||||
// [8] callexecute call1 -- call_vprc1
|
||||
jsr call1
|
||||
// sideeffect stackpullbytes(1) -- _stackpullbyte_1
|
||||
pla
|
||||
@ -562,7 +562,7 @@ main: {
|
||||
pla
|
||||
// [11] *main::ptr = main::$1 -- _deref_pbuc1=vbuaa
|
||||
sta ptr
|
||||
// [12] call call2
|
||||
// [12] call call2
|
||||
// [34] phi from main to call2 [phi:main->call2]
|
||||
call2_from_main:
|
||||
// [34] phi call2::param2#2 = 2 [phi:main->call2#0] -- vbuaa=vbuc1
|
||||
@ -578,7 +578,7 @@ main: {
|
||||
lda.z call2.return
|
||||
// [15] *main::ptr = main::$2 -- _deref_pbuc1=vbuaa
|
||||
sta ptr
|
||||
// [16] call call2
|
||||
// [16] call call2
|
||||
// [34] phi from main::@1 to call2 [phi:main::@1->call2]
|
||||
call2_from___b1:
|
||||
// [34] phi call2::param2#2 = 4 [phi:main::@1->call2#0] -- vbuaa=vbuc1
|
||||
@ -594,7 +594,7 @@ main: {
|
||||
lda.z call2.return
|
||||
// [19] *main::ptr = main::$3 -- _deref_pbuc1=vbuaa
|
||||
sta ptr
|
||||
// [20] call call3
|
||||
// [20] call call3
|
||||
// [38] phi from main::@2 to call3 [phi:main::@2->call3]
|
||||
call3_from___b2:
|
||||
// [38] phi call3::param2#2 = 2 [phi:main::@2->call3#0] -- vbuaa=vbuc1
|
||||
@ -609,7 +609,7 @@ main: {
|
||||
// [22] main::$4 = call3::return#2
|
||||
// [23] *main::ptr = main::$4 -- _deref_pbuc1=vbuaa
|
||||
sta ptr
|
||||
// [24] call call3
|
||||
// [24] call call3
|
||||
// [38] phi from main::@3 to call3 [phi:main::@3->call3]
|
||||
call3_from___b3:
|
||||
// [38] phi call3::param2#2 = 4 [phi:main::@3->call3#0] -- vbuaa=vbuc1
|
||||
@ -798,7 +798,7 @@ main: {
|
||||
// [1] stackpush(byte) = 2 -- _stackpushbyte_=vbuc1
|
||||
lda #2
|
||||
pha
|
||||
// [2] callexecute call1 -- jsr
|
||||
// [2] callexecute call1 -- call_vprc1
|
||||
jsr call1
|
||||
// sideeffect stackpullbytes(1) -- _stackpullbyte_1
|
||||
pla
|
||||
@ -814,7 +814,7 @@ main: {
|
||||
// [7] stackpush(byte) = 4 -- _stackpushbyte_=vbuc1
|
||||
lda #4
|
||||
pha
|
||||
// [8] callexecute call1 -- jsr
|
||||
// [8] callexecute call1 -- call_vprc1
|
||||
jsr call1
|
||||
// sideeffect stackpullbytes(1) -- _stackpullbyte_1
|
||||
pla
|
||||
@ -824,7 +824,7 @@ main: {
|
||||
// [11] *main::ptr = main::$1 -- _deref_pbuc1=vbuaa
|
||||
sta ptr
|
||||
// call2(1,2)
|
||||
// [12] call call2
|
||||
// [12] call call2
|
||||
// [34] phi from main to call2 [phi:main->call2]
|
||||
// [34] phi call2::param2#2 = 2 [phi:main->call2#0] -- vbuaa=vbuc1
|
||||
lda #2
|
||||
@ -840,7 +840,7 @@ main: {
|
||||
// [15] *main::ptr = main::$2 -- _deref_pbuc1=vbuaa
|
||||
sta ptr
|
||||
// call2(3,4)
|
||||
// [16] call call2
|
||||
// [16] call call2
|
||||
// [34] phi from main::@1 to call2 [phi:main::@1->call2]
|
||||
// [34] phi call2::param2#2 = 4 [phi:main::@1->call2#0] -- vbuaa=vbuc1
|
||||
lda #4
|
||||
@ -856,7 +856,7 @@ main: {
|
||||
// [19] *main::ptr = main::$3 -- _deref_pbuc1=vbuaa
|
||||
sta ptr
|
||||
// call3(1,2)
|
||||
// [20] call call3
|
||||
// [20] call call3
|
||||
// [38] phi from main::@2 to call3 [phi:main::@2->call3]
|
||||
// [38] phi call3::param2#2 = 2 [phi:main::@2->call3#0] -- vbuaa=vbuc1
|
||||
lda #2
|
||||
@ -871,7 +871,7 @@ main: {
|
||||
// [23] *main::ptr = main::$4 -- _deref_pbuc1=vbuaa
|
||||
sta ptr
|
||||
// call3(3,4)
|
||||
// [24] call call3
|
||||
// [24] call call3
|
||||
// [38] phi from main::@3 to call3 [phi:main::@3->call3]
|
||||
// [38] phi call3::param2#2 = 4 [phi:main::@3->call3#0] -- vbuaa=vbuc1
|
||||
lda #4
|
||||
|
@ -212,7 +212,7 @@ exec: {
|
||||
ldy.z i
|
||||
lda INPUT,y
|
||||
pha
|
||||
jsr bi_collect
|
||||
jsr icall1
|
||||
pla
|
||||
// out = (*collect)(out,INPUT[i])
|
||||
pla
|
||||
@ -225,7 +225,7 @@ exec: {
|
||||
// for(char i=1;i<sizeof(INPUT);i++)
|
||||
inc.z i
|
||||
jmp __b1
|
||||
bi_collect:
|
||||
icall1:
|
||||
jmp (collect)
|
||||
}
|
||||
// print(byte zp(6) i)
|
||||
|
@ -13,7 +13,7 @@ Adding parameter assignment in __stackcall procedure min::b = param(min::b)
|
||||
Adding parameter assignment in __stackcall procedure min::a = param(min::a)
|
||||
Adding parameter assignment in __stackcall procedure xor::b = param(xor::b)
|
||||
Adding parameter assignment in __stackcall procedure xor::a = param(xor::a)
|
||||
Inlined call call __init
|
||||
Inlined call call __init
|
||||
Calling convention STACK_CALL adding prepare/execute/finalize for exec::$5 = call *exec::collect exec::out INPUT[exec::i]
|
||||
Calling convention STACK_CALL replacing param(sum::a) with stackidx(byte,sum::OFFSET_STACK_A)
|
||||
Calling convention STACK_CALL replacing param(sum::b) with stackidx(byte,sum::OFFSET_STACK_B)
|
||||
@ -77,7 +77,7 @@ print: scope:[print] from exec::@3 main::@2
|
||||
print::i#2 = phi( exec::@3/print::i#1, main::@2/print::i#0 )
|
||||
print::$0 = print::i#2 >> 4
|
||||
cout::c#0 = HEX[print::$0]
|
||||
call cout
|
||||
call cout
|
||||
to:print::@1
|
||||
print::@1: scope:[print] from print
|
||||
print::i#3 = phi( print/print::i#2 )
|
||||
@ -85,7 +85,7 @@ print::@1: scope:[print] from print
|
||||
idx#4 = idx#30
|
||||
print::$2 = print::i#3 & $f
|
||||
cout::c#1 = HEX[print::$2]
|
||||
call cout
|
||||
call cout
|
||||
to:print::@2
|
||||
print::@2: scope:[print] from print::@1
|
||||
idx#31 = phi( print::@1/idx#1 )
|
||||
@ -113,14 +113,14 @@ main::@2: scope:[main] from main::@1
|
||||
idx#54 = phi( main::@1/idx#59 )
|
||||
main::i#3 = phi( main::@1/main::i#2 )
|
||||
print::i#0 = INPUT[main::i#3]
|
||||
call print
|
||||
call print
|
||||
to:main::@4
|
||||
main::@4: scope:[main] from main::@2
|
||||
main::i#5 = phi( main::@2/main::i#3 )
|
||||
idx#33 = phi( main::@2/idx#6 )
|
||||
idx#7 = idx#33
|
||||
cout::c#2 = ' '
|
||||
call cout
|
||||
call cout
|
||||
to:main::@5
|
||||
main::@5: scope:[main] from main::@4
|
||||
main::i#4 = phi( main::@4/main::i#5 )
|
||||
@ -130,46 +130,46 @@ main::@5: scope:[main] from main::@4
|
||||
to:main::@1
|
||||
main::@3: scope:[main] from main::@1
|
||||
idx#55 = phi( main::@1/idx#59 )
|
||||
call ln
|
||||
call ln
|
||||
to:main::@6
|
||||
main::@6: scope:[main] from main::@3
|
||||
idx#35 = phi( main::@3/idx#3 )
|
||||
idx#9 = idx#35
|
||||
exec::collect#0 = &sum
|
||||
call exec
|
||||
call exec
|
||||
to:main::@7
|
||||
main::@7: scope:[main] from main::@6
|
||||
idx#36 = phi( main::@6/idx#23 )
|
||||
idx#10 = idx#36
|
||||
call ln
|
||||
call ln
|
||||
to:main::@8
|
||||
main::@8: scope:[main] from main::@7
|
||||
idx#37 = phi( main::@7/idx#3 )
|
||||
idx#11 = idx#37
|
||||
exec::collect#1 = &min
|
||||
call exec
|
||||
call exec
|
||||
to:main::@9
|
||||
main::@9: scope:[main] from main::@8
|
||||
idx#38 = phi( main::@8/idx#23 )
|
||||
idx#12 = idx#38
|
||||
call ln
|
||||
call ln
|
||||
to:main::@10
|
||||
main::@10: scope:[main] from main::@9
|
||||
idx#39 = phi( main::@9/idx#3 )
|
||||
idx#13 = idx#39
|
||||
exec::collect#2 = &max
|
||||
call exec
|
||||
call exec
|
||||
to:main::@11
|
||||
main::@11: scope:[main] from main::@10
|
||||
idx#40 = phi( main::@10/idx#23 )
|
||||
idx#14 = idx#40
|
||||
call ln
|
||||
call ln
|
||||
to:main::@12
|
||||
main::@12: scope:[main] from main::@11
|
||||
idx#41 = phi( main::@11/idx#3 )
|
||||
idx#15 = idx#41
|
||||
exec::collect#3 = &xor
|
||||
call exec
|
||||
call exec
|
||||
to:main::@13
|
||||
main::@13: scope:[main] from main::@12
|
||||
idx#42 = phi( main::@12/idx#23 )
|
||||
@ -186,21 +186,21 @@ exec: scope:[exec] from main::@10 main::@12 main::@6 main::@8
|
||||
exec::collect#12 = phi( main::@10/exec::collect#2, main::@12/exec::collect#3, main::@6/exec::collect#0, main::@8/exec::collect#1 )
|
||||
idx#52 = phi( main::@10/idx#13, main::@12/idx#15, main::@6/idx#9, main::@8/idx#11 )
|
||||
cout::c#3 = ' '
|
||||
call cout
|
||||
call cout
|
||||
to:exec::@4
|
||||
exec::@4: scope:[exec] from exec
|
||||
exec::collect#10 = phi( exec/exec::collect#12 )
|
||||
idx#44 = phi( exec/idx#1 )
|
||||
idx#18 = idx#44
|
||||
cout::c#4 = ' '
|
||||
call cout
|
||||
call cout
|
||||
to:exec::@5
|
||||
exec::@5: scope:[exec] from exec::@4
|
||||
exec::collect#8 = phi( exec::@4/exec::collect#10 )
|
||||
idx#45 = phi( exec::@4/idx#1 )
|
||||
idx#19 = idx#45
|
||||
cout::c#5 = ' '
|
||||
call cout
|
||||
call cout
|
||||
to:exec::@6
|
||||
exec::@6: scope:[exec] from exec::@5
|
||||
exec::collect#6 = phi( exec::@5/exec::collect#8 )
|
||||
@ -235,7 +235,7 @@ exec::@3: scope:[exec] from exec::@2
|
||||
idx#56 = phi( exec::@2/idx#60 )
|
||||
exec::out#1 = exec::$5
|
||||
print::i#1 = exec::out#1
|
||||
call print
|
||||
call print
|
||||
to:exec::@7
|
||||
exec::@7: scope:[exec] from exec::@3
|
||||
exec::collect#9 = phi( exec::@3/exec::collect#11 )
|
||||
@ -244,7 +244,7 @@ exec::@7: scope:[exec] from exec::@3
|
||||
idx#47 = phi( exec::@3/idx#6 )
|
||||
idx#21 = idx#47
|
||||
cout::c#6 = ' '
|
||||
call cout
|
||||
call cout
|
||||
to:exec::@8
|
||||
exec::@8: scope:[exec] from exec::@7
|
||||
exec::collect#7 = phi( exec::@7/exec::collect#9 )
|
||||
@ -327,7 +327,7 @@ __start::__init1: scope:[__start] from __start
|
||||
to:__start::@1
|
||||
__start::@1: scope:[__start] from __start::__init1
|
||||
idx#58 = phi( __start::__init1/idx#24 )
|
||||
call main
|
||||
call main
|
||||
to:__start::@2
|
||||
__start::@2: scope:[__start] from __start::@1
|
||||
idx#50 = phi( __start::@1/idx#17 )
|
||||
@ -759,7 +759,7 @@ __start::__init1: scope:[__start] from __start
|
||||
to:__start::@1
|
||||
__start::@1: scope:[__start] from __start::__init1
|
||||
[2] phi()
|
||||
[3] call main
|
||||
[3] call main
|
||||
to:__start::@return
|
||||
__start::@return: scope:[__start] from __start::@1
|
||||
[4] return
|
||||
@ -828,46 +828,46 @@ main::@1: scope:[main] from main main::@5
|
||||
to:main::@3
|
||||
main::@3: scope:[main] from main::@1
|
||||
[32] phi()
|
||||
[33] call ln
|
||||
[33] call ln
|
||||
to:main::@6
|
||||
main::@6: scope:[main] from main::@3
|
||||
[34] phi()
|
||||
[35] call exec
|
||||
[35] call exec
|
||||
to:main::@7
|
||||
main::@7: scope:[main] from main::@6
|
||||
[36] phi()
|
||||
[37] call ln
|
||||
[37] call ln
|
||||
to:main::@8
|
||||
main::@8: scope:[main] from main::@7
|
||||
[38] phi()
|
||||
[39] call exec
|
||||
[39] call exec
|
||||
to:main::@9
|
||||
main::@9: scope:[main] from main::@8
|
||||
[40] phi()
|
||||
[41] call ln
|
||||
[41] call ln
|
||||
to:main::@10
|
||||
main::@10: scope:[main] from main::@9
|
||||
[42] phi()
|
||||
[43] call exec
|
||||
[43] call exec
|
||||
to:main::@11
|
||||
main::@11: scope:[main] from main::@10
|
||||
[44] phi()
|
||||
[45] call ln
|
||||
[45] call ln
|
||||
to:main::@12
|
||||
main::@12: scope:[main] from main::@11
|
||||
[46] phi()
|
||||
[47] call exec
|
||||
[47] call exec
|
||||
to:main::@return
|
||||
main::@return: scope:[main] from main::@12
|
||||
[48] return
|
||||
to:@return
|
||||
main::@2: scope:[main] from main::@1
|
||||
[49] print::i#0 = INPUT[main::i#2]
|
||||
[50] call print
|
||||
[50] call print
|
||||
to:main::@4
|
||||
main::@4: scope:[main] from main::@2
|
||||
[51] phi()
|
||||
[52] call cout
|
||||
[52] call cout
|
||||
to:main::@5
|
||||
main::@5: scope:[main] from main::@4
|
||||
[53] main::i#1 = ++ main::i#2
|
||||
@ -884,15 +884,15 @@ ln::@return: scope:[ln] from ln
|
||||
void exec(byte(byte,byte)* exec::collect)
|
||||
exec: scope:[exec] from main::@10 main::@12 main::@6 main::@8
|
||||
[56] exec::collect#10 = phi( main::@10/&max, main::@12/&xor, main::@6/&sum, main::@8/&min )
|
||||
[57] call cout
|
||||
[57] call cout
|
||||
to:exec::@4
|
||||
exec::@4: scope:[exec] from exec
|
||||
[58] phi()
|
||||
[59] call cout
|
||||
[59] call cout
|
||||
to:exec::@5
|
||||
exec::@5: scope:[exec] from exec::@4
|
||||
[60] phi()
|
||||
[61] call cout
|
||||
[61] call cout
|
||||
to:exec::@6
|
||||
exec::@6: scope:[exec] from exec::@5
|
||||
[62] exec::out#0 = *INPUT
|
||||
@ -914,11 +914,11 @@ exec::@2: scope:[exec] from exec::@1
|
||||
to:exec::@3
|
||||
exec::@3: scope:[exec] from exec::@2
|
||||
[71] print::i#1 = exec::out#1
|
||||
[72] call print
|
||||
[72] call print
|
||||
to:exec::@7
|
||||
exec::@7: scope:[exec] from exec::@3
|
||||
[73] phi()
|
||||
[74] call cout
|
||||
[74] call cout
|
||||
to:exec::@8
|
||||
exec::@8: scope:[exec] from exec::@7
|
||||
[75] exec::i#1 = ++ exec::i#2
|
||||
@ -930,12 +930,12 @@ print: scope:[print] from exec::@3 main::@2
|
||||
[76] print::i#2 = phi( exec::@3/print::i#1, main::@2/print::i#0 )
|
||||
[77] print::$0 = print::i#2 >> 4
|
||||
[78] cout::c#0 = HEX[print::$0]
|
||||
[79] call cout
|
||||
[79] call cout
|
||||
to:print::@1
|
||||
print::@1: scope:[print] from print
|
||||
[80] print::$2 = print::i#2 & $f
|
||||
[81] cout::c#1 = HEX[print::$2]
|
||||
[82] call cout
|
||||
[82] call cout
|
||||
to:print::@return
|
||||
print::@return: scope:[print] from print::@1
|
||||
[83] return
|
||||
@ -1255,7 +1255,7 @@ __start: {
|
||||
jmp __b1
|
||||
// __start::@1
|
||||
__b1:
|
||||
// [3] call main
|
||||
// [3] call main
|
||||
// [29] phi from __start::@1 to main [phi:__start::@1->main]
|
||||
main_from___b1:
|
||||
jsr main
|
||||
@ -1409,14 +1409,14 @@ main: {
|
||||
jmp __b3
|
||||
// main::@3
|
||||
__b3:
|
||||
// [33] call ln
|
||||
// [33] call ln
|
||||
jsr ln
|
||||
// [34] phi from main::@3 to main::@6 [phi:main::@3->main::@6]
|
||||
__b6_from___b3:
|
||||
jmp __b6
|
||||
// main::@6
|
||||
__b6:
|
||||
// [35] call exec
|
||||
// [35] call exec
|
||||
// [56] phi from main::@6 to exec [phi:main::@6->exec]
|
||||
exec_from___b6:
|
||||
// [56] phi exec::collect#10 = &sum [phi:main::@6->exec#0] -- pprz1=pprc1
|
||||
@ -1430,14 +1430,14 @@ main: {
|
||||
jmp __b7
|
||||
// main::@7
|
||||
__b7:
|
||||
// [37] call ln
|
||||
// [37] call ln
|
||||
jsr ln
|
||||
// [38] phi from main::@7 to main::@8 [phi:main::@7->main::@8]
|
||||
__b8_from___b7:
|
||||
jmp __b8
|
||||
// main::@8
|
||||
__b8:
|
||||
// [39] call exec
|
||||
// [39] call exec
|
||||
// [56] phi from main::@8 to exec [phi:main::@8->exec]
|
||||
exec_from___b8:
|
||||
// [56] phi exec::collect#10 = &min [phi:main::@8->exec#0] -- pprz1=pprc1
|
||||
@ -1451,14 +1451,14 @@ main: {
|
||||
jmp __b9
|
||||
// main::@9
|
||||
__b9:
|
||||
// [41] call ln
|
||||
// [41] call ln
|
||||
jsr ln
|
||||
// [42] phi from main::@9 to main::@10 [phi:main::@9->main::@10]
|
||||
__b10_from___b9:
|
||||
jmp __b10
|
||||
// main::@10
|
||||
__b10:
|
||||
// [43] call exec
|
||||
// [43] call exec
|
||||
// [56] phi from main::@10 to exec [phi:main::@10->exec]
|
||||
exec_from___b10:
|
||||
// [56] phi exec::collect#10 = &max [phi:main::@10->exec#0] -- pprz1=pprc1
|
||||
@ -1472,14 +1472,14 @@ main: {
|
||||
jmp __b11
|
||||
// main::@11
|
||||
__b11:
|
||||
// [45] call ln
|
||||
// [45] call ln
|
||||
jsr ln
|
||||
// [46] phi from main::@11 to main::@12 [phi:main::@11->main::@12]
|
||||
__b12_from___b11:
|
||||
jmp __b12
|
||||
// main::@12
|
||||
__b12:
|
||||
// [47] call exec
|
||||
// [47] call exec
|
||||
// [56] phi from main::@12 to exec [phi:main::@12->exec]
|
||||
exec_from___b12:
|
||||
// [56] phi exec::collect#10 = &xor [phi:main::@12->exec#0] -- pprz1=pprc1
|
||||
@ -1499,7 +1499,7 @@ main: {
|
||||
ldy.z i
|
||||
lda INPUT,y
|
||||
sta.z print.i
|
||||
// [50] call print
|
||||
// [50] call print
|
||||
// [76] phi from main::@2 to print [phi:main::@2->print]
|
||||
print_from___b2:
|
||||
// [76] phi idx#53 = idx#54 [phi:main::@2->print#0] -- register_copy
|
||||
@ -1510,7 +1510,7 @@ main: {
|
||||
jmp __b4
|
||||
// main::@4
|
||||
__b4:
|
||||
// [52] call cout
|
||||
// [52] call cout
|
||||
// [84] phi from main::@4 to cout [phi:main::@4->cout]
|
||||
cout_from___b4:
|
||||
// [84] phi idx#27 = idx#0 [phi:main::@4->cout#0] -- register_copy
|
||||
@ -1550,7 +1550,7 @@ exec: {
|
||||
.label out = 6
|
||||
.label i = 5
|
||||
.label collect = 3
|
||||
// [57] call cout
|
||||
// [57] call cout
|
||||
// [84] phi from exec to cout [phi:exec->cout]
|
||||
cout_from_exec:
|
||||
// [84] phi idx#27 = 0 [phi:exec->cout#0] -- vbuz1=vbuc1
|
||||
@ -1564,7 +1564,7 @@ exec: {
|
||||
jmp __b4
|
||||
// exec::@4
|
||||
__b4:
|
||||
// [59] call cout
|
||||
// [59] call cout
|
||||
// [84] phi from exec::@4 to cout [phi:exec::@4->cout]
|
||||
cout_from___b4:
|
||||
// [84] phi idx#27 = idx#0 [phi:exec::@4->cout#0] -- register_copy
|
||||
@ -1576,7 +1576,7 @@ exec: {
|
||||
jmp __b5
|
||||
// exec::@5
|
||||
__b5:
|
||||
// [61] call cout
|
||||
// [61] call cout
|
||||
// [84] phi from exec::@5 to cout [phi:exec::@5->cout]
|
||||
cout_from___b5:
|
||||
// [84] phi idx#27 = idx#0 [phi:exec::@5->cout#0] -- register_copy
|
||||
@ -1616,8 +1616,8 @@ exec: {
|
||||
ldy.z i
|
||||
lda INPUT,y
|
||||
pha
|
||||
// [68] callexecute *exec::collect#10
|
||||
jsr bi_collect
|
||||
// [68] callexecute *exec::collect#10 -- call__deref_pprz1
|
||||
jsr icall1
|
||||
// sideeffect stackpullbytes(1) -- _stackpullbyte_1
|
||||
pla
|
||||
// [70] exec::out#1 = stackpull(byte) -- vbuz1=_stackpullbyte_
|
||||
@ -1627,7 +1627,7 @@ exec: {
|
||||
// exec::@3
|
||||
__b3:
|
||||
// [71] print::i#1 = exec::out#1
|
||||
// [72] call print
|
||||
// [72] call print
|
||||
// [76] phi from exec::@3 to print [phi:exec::@3->print]
|
||||
print_from___b3:
|
||||
// [76] phi idx#53 = idx#0 [phi:exec::@3->print#0] -- register_copy
|
||||
@ -1638,7 +1638,7 @@ exec: {
|
||||
jmp __b7
|
||||
// exec::@7
|
||||
__b7:
|
||||
// [74] call cout
|
||||
// [74] call cout
|
||||
// [84] phi from exec::@7 to cout [phi:exec::@7->cout]
|
||||
cout_from___b7:
|
||||
// [84] phi idx#27 = idx#0 [phi:exec::@7->cout#0] -- register_copy
|
||||
@ -1655,7 +1655,8 @@ exec: {
|
||||
// [63] phi exec::out#2 = exec::out#1 [phi:exec::@8->exec::@1#0] -- register_copy
|
||||
// [63] phi exec::i#2 = exec::i#1 [phi:exec::@8->exec::@1#1] -- register_copy
|
||||
jmp __b1
|
||||
bi_collect:
|
||||
// Outside Flow
|
||||
icall1:
|
||||
jmp (collect)
|
||||
}
|
||||
// print
|
||||
@ -1671,7 +1672,7 @@ print: {
|
||||
// [78] cout::c#0 = HEX[print::$0] -- vbuxx=pbuc1_derefidx_vbuaa
|
||||
tay
|
||||
ldx HEX,y
|
||||
// [79] call cout
|
||||
// [79] call cout
|
||||
// [84] phi from print to cout [phi:print->cout]
|
||||
cout_from_print:
|
||||
// [84] phi idx#27 = idx#53 [phi:print->cout#0] -- register_copy
|
||||
@ -1686,7 +1687,7 @@ print: {
|
||||
// [81] cout::c#1 = HEX[print::$2] -- vbuxx=pbuc1_derefidx_vbuaa
|
||||
tay
|
||||
ldx HEX,y
|
||||
// [82] call cout
|
||||
// [82] call cout
|
||||
// [84] phi from print::@1 to cout [phi:print::@1->cout]
|
||||
cout_from___b1:
|
||||
// [84] phi idx#27 = idx#0 [phi:print::@1->cout#0] -- register_copy
|
||||
@ -1963,7 +1964,7 @@ __start: {
|
||||
sta.z line+1
|
||||
// [2] phi from __start::__init1 to __start::@1 [phi:__start::__init1->__start::@1]
|
||||
// __start::@1
|
||||
// [3] call main
|
||||
// [3] call main
|
||||
// [29] phi from __start::@1 to main [phi:__start::@1->main]
|
||||
jsr main
|
||||
// __start::@return
|
||||
@ -2112,12 +2113,12 @@ main: {
|
||||
// [32] phi from main::@1 to main::@3 [phi:main::@1->main::@3]
|
||||
// main::@3
|
||||
// ln()
|
||||
// [33] call ln
|
||||
// [33] call ln
|
||||
jsr ln
|
||||
// [34] phi from main::@3 to main::@6 [phi:main::@3->main::@6]
|
||||
// main::@6
|
||||
// exec(&sum)
|
||||
// [35] call exec
|
||||
// [35] call exec
|
||||
// [56] phi from main::@6 to exec [phi:main::@6->exec]
|
||||
// [56] phi exec::collect#10 = &sum [phi:main::@6->exec#0] -- pprz1=pprc1
|
||||
lda #<sum
|
||||
@ -2128,12 +2129,12 @@ main: {
|
||||
// [36] phi from main::@6 to main::@7 [phi:main::@6->main::@7]
|
||||
// main::@7
|
||||
// ln()
|
||||
// [37] call ln
|
||||
// [37] call ln
|
||||
jsr ln
|
||||
// [38] phi from main::@7 to main::@8 [phi:main::@7->main::@8]
|
||||
// main::@8
|
||||
// exec(&min)
|
||||
// [39] call exec
|
||||
// [39] call exec
|
||||
// [56] phi from main::@8 to exec [phi:main::@8->exec]
|
||||
// [56] phi exec::collect#10 = &min [phi:main::@8->exec#0] -- pprz1=pprc1
|
||||
lda #<min
|
||||
@ -2144,12 +2145,12 @@ main: {
|
||||
// [40] phi from main::@8 to main::@9 [phi:main::@8->main::@9]
|
||||
// main::@9
|
||||
// ln()
|
||||
// [41] call ln
|
||||
// [41] call ln
|
||||
jsr ln
|
||||
// [42] phi from main::@9 to main::@10 [phi:main::@9->main::@10]
|
||||
// main::@10
|
||||
// exec(&max)
|
||||
// [43] call exec
|
||||
// [43] call exec
|
||||
// [56] phi from main::@10 to exec [phi:main::@10->exec]
|
||||
// [56] phi exec::collect#10 = &max [phi:main::@10->exec#0] -- pprz1=pprc1
|
||||
lda #<max
|
||||
@ -2160,12 +2161,12 @@ main: {
|
||||
// [44] phi from main::@10 to main::@11 [phi:main::@10->main::@11]
|
||||
// main::@11
|
||||
// ln()
|
||||
// [45] call ln
|
||||
// [45] call ln
|
||||
jsr ln
|
||||
// [46] phi from main::@11 to main::@12 [phi:main::@11->main::@12]
|
||||
// main::@12
|
||||
// exec(&xor)
|
||||
// [47] call exec
|
||||
// [47] call exec
|
||||
// [56] phi from main::@12 to exec [phi:main::@12->exec]
|
||||
// [56] phi exec::collect#10 = &xor [phi:main::@12->exec#0] -- pprz1=pprc1
|
||||
lda #<xor
|
||||
@ -2184,7 +2185,7 @@ main: {
|
||||
ldy.z i
|
||||
lda INPUT,y
|
||||
sta.z print.i
|
||||
// [50] call print
|
||||
// [50] call print
|
||||
// [76] phi from main::@2 to print [phi:main::@2->print]
|
||||
// [76] phi idx#53 = idx#54 [phi:main::@2->print#0] -- register_copy
|
||||
// [76] phi print::i#2 = print::i#0 [phi:main::@2->print#1] -- register_copy
|
||||
@ -2192,7 +2193,7 @@ main: {
|
||||
// [51] phi from main::@2 to main::@4 [phi:main::@2->main::@4]
|
||||
// main::@4
|
||||
// cout(' ')
|
||||
// [52] call cout
|
||||
// [52] call cout
|
||||
// [84] phi from main::@4 to cout [phi:main::@4->cout]
|
||||
// [84] phi idx#27 = idx#0 [phi:main::@4->cout#0] -- register_copy
|
||||
// [84] phi cout::c#7 = ' ' [phi:main::@4->cout#1] -- vbuxx=vbuc1
|
||||
@ -2230,7 +2231,7 @@ exec: {
|
||||
.label i = 5
|
||||
.label collect = 3
|
||||
// cout(' ')
|
||||
// [57] call cout
|
||||
// [57] call cout
|
||||
// [84] phi from exec to cout [phi:exec->cout]
|
||||
// [84] phi idx#27 = 0 [phi:exec->cout#0] -- vbuz1=vbuc1
|
||||
lda #0
|
||||
@ -2241,7 +2242,7 @@ exec: {
|
||||
// [58] phi from exec to exec::@4 [phi:exec->exec::@4]
|
||||
// exec::@4
|
||||
// cout(' ')
|
||||
// [59] call cout
|
||||
// [59] call cout
|
||||
// [84] phi from exec::@4 to cout [phi:exec::@4->cout]
|
||||
// [84] phi idx#27 = idx#0 [phi:exec::@4->cout#0] -- register_copy
|
||||
// [84] phi cout::c#7 = ' ' [phi:exec::@4->cout#1] -- vbuxx=vbuc1
|
||||
@ -2250,7 +2251,7 @@ exec: {
|
||||
// [60] phi from exec::@4 to exec::@5 [phi:exec::@4->exec::@5]
|
||||
// exec::@5
|
||||
// cout(' ')
|
||||
// [61] call cout
|
||||
// [61] call cout
|
||||
// [84] phi from exec::@5 to cout [phi:exec::@5->cout]
|
||||
// [84] phi idx#27 = idx#0 [phi:exec::@5->cout#0] -- register_copy
|
||||
// [84] phi cout::c#7 = ' ' [phi:exec::@5->cout#1] -- vbuxx=vbuc1
|
||||
@ -2287,8 +2288,8 @@ exec: {
|
||||
ldy.z i
|
||||
lda INPUT,y
|
||||
pha
|
||||
// [68] callexecute *exec::collect#10
|
||||
jsr bi_collect
|
||||
// [68] callexecute *exec::collect#10 -- call__deref_pprz1
|
||||
jsr icall1
|
||||
// sideeffect stackpullbytes(1) -- _stackpullbyte_1
|
||||
pla
|
||||
// out = (*collect)(out,INPUT[i])
|
||||
@ -2298,7 +2299,7 @@ exec: {
|
||||
// exec::@3
|
||||
// print(out)
|
||||
// [71] print::i#1 = exec::out#1
|
||||
// [72] call print
|
||||
// [72] call print
|
||||
// [76] phi from exec::@3 to print [phi:exec::@3->print]
|
||||
// [76] phi idx#53 = idx#0 [phi:exec::@3->print#0] -- register_copy
|
||||
// [76] phi print::i#2 = print::i#1 [phi:exec::@3->print#1] -- register_copy
|
||||
@ -2306,7 +2307,7 @@ exec: {
|
||||
// [73] phi from exec::@3 to exec::@7 [phi:exec::@3->exec::@7]
|
||||
// exec::@7
|
||||
// cout(' ')
|
||||
// [74] call cout
|
||||
// [74] call cout
|
||||
// [84] phi from exec::@7 to cout [phi:exec::@7->cout]
|
||||
// [84] phi idx#27 = idx#0 [phi:exec::@7->cout#0] -- register_copy
|
||||
// [84] phi cout::c#7 = ' ' [phi:exec::@7->cout#1] -- vbuxx=vbuc1
|
||||
@ -2320,7 +2321,8 @@ exec: {
|
||||
// [63] phi exec::out#2 = exec::out#1 [phi:exec::@8->exec::@1#0] -- register_copy
|
||||
// [63] phi exec::i#2 = exec::i#1 [phi:exec::@8->exec::@1#1] -- register_copy
|
||||
jmp __b1
|
||||
bi_collect:
|
||||
// Outside Flow
|
||||
icall1:
|
||||
jmp (collect)
|
||||
}
|
||||
// print
|
||||
@ -2338,7 +2340,7 @@ print: {
|
||||
// [78] cout::c#0 = HEX[print::$0] -- vbuxx=pbuc1_derefidx_vbuaa
|
||||
tay
|
||||
ldx HEX,y
|
||||
// [79] call cout
|
||||
// [79] call cout
|
||||
// [84] phi from print to cout [phi:print->cout]
|
||||
// [84] phi idx#27 = idx#53 [phi:print->cout#0] -- register_copy
|
||||
// [84] phi cout::c#7 = cout::c#0 [phi:print->cout#1] -- register_copy
|
||||
@ -2352,7 +2354,7 @@ print: {
|
||||
// [81] cout::c#1 = HEX[print::$2] -- vbuxx=pbuc1_derefidx_vbuaa
|
||||
tay
|
||||
ldx HEX,y
|
||||
// [82] call cout
|
||||
// [82] call cout
|
||||
// [84] phi from print::@1 to cout [phi:print::@1->cout]
|
||||
// [84] phi idx#27 = idx#0 [phi:print::@1->cout#0] -- register_copy
|
||||
// [84] phi cout::c#7 = cout::c#1 [phi:print::@1->cout#1] -- register_copy
|
||||
|
@ -88,7 +88,7 @@ do10: {
|
||||
sta.z i
|
||||
__b1:
|
||||
// (*fn)()
|
||||
jsr bi_fn
|
||||
jsr icall1
|
||||
// for( byte i: 0..9)
|
||||
inc.z i
|
||||
lda #$a
|
||||
@ -96,6 +96,6 @@ do10: {
|
||||
bne __b1
|
||||
// }
|
||||
rts
|
||||
bi_fn:
|
||||
icall1:
|
||||
jmp (fn)
|
||||
}
|
||||
|
@ -1,4 +1,4 @@
|
||||
Inlined call call __init
|
||||
Inlined call call __init
|
||||
Calling convention STACK_CALL adding prepare/execute/finalize for call *do10::fn
|
||||
|
||||
CONTROL FLOW GRAPH SSA
|
||||
@ -27,7 +27,7 @@ do10::@return: scope:[do10] from do10::@2
|
||||
void hello()
|
||||
hello: scope:[hello] from
|
||||
print::msg#0 = hello::msg
|
||||
call print
|
||||
call print
|
||||
to:hello::@1
|
||||
hello::@1: scope:[hello] from hello
|
||||
to:hello::@return
|
||||
@ -38,7 +38,7 @@ hello::@return: scope:[hello] from hello::@1
|
||||
void world()
|
||||
world: scope:[world] from
|
||||
print::msg#1 = world::msg
|
||||
call print
|
||||
call print
|
||||
to:world::@1
|
||||
world::@1: scope:[world] from world
|
||||
to:world::@return
|
||||
@ -49,11 +49,11 @@ world::@return: scope:[world] from world::@1
|
||||
void main()
|
||||
main: scope:[main] from __start::@1
|
||||
do10::fn#0 = &hello
|
||||
call do10
|
||||
call do10
|
||||
to:main::@1
|
||||
main::@1: scope:[main] from main
|
||||
do10::fn#1 = &world
|
||||
call do10
|
||||
call do10
|
||||
to:main::@2
|
||||
main::@2: scope:[main] from main::@1
|
||||
to:main::@return
|
||||
@ -86,7 +86,7 @@ __start::__init1: scope:[__start] from __start
|
||||
idx = 0
|
||||
to:__start::@1
|
||||
__start::@1: scope:[__start] from __start::__init1
|
||||
call main
|
||||
call main
|
||||
to:__start::@2
|
||||
__start::@2: scope:[__start] from __start::@1
|
||||
to:__start::@return
|
||||
@ -219,7 +219,7 @@ __start::__init1: scope:[__start] from __start
|
||||
to:__start::@1
|
||||
__start::@1: scope:[__start] from __start::__init1
|
||||
[2] phi()
|
||||
[3] call main
|
||||
[3] call main
|
||||
to:__start::@return
|
||||
__start::@return: scope:[__start] from __start::@1
|
||||
[4] return
|
||||
@ -228,7 +228,7 @@ __start::@return: scope:[__start] from __start::@1
|
||||
void world()
|
||||
world: scope:[world] from
|
||||
[5] phi()
|
||||
[6] call print
|
||||
[6] call print
|
||||
to:world::@return
|
||||
world::@return: scope:[world] from world
|
||||
[7] return
|
||||
@ -237,7 +237,7 @@ world::@return: scope:[world] from world
|
||||
void hello()
|
||||
hello: scope:[hello] from
|
||||
[8] phi()
|
||||
[9] call print
|
||||
[9] call print
|
||||
to:hello::@return
|
||||
hello::@return: scope:[hello] from hello
|
||||
[10] return
|
||||
@ -246,11 +246,11 @@ hello::@return: scope:[hello] from hello
|
||||
void main()
|
||||
main: scope:[main] from __start::@1
|
||||
[11] phi()
|
||||
[12] call do10
|
||||
[12] call do10
|
||||
to:main::@1
|
||||
main::@1: scope:[main] from main
|
||||
[13] phi()
|
||||
[14] call do10
|
||||
[14] call do10
|
||||
to:main::@return
|
||||
main::@return: scope:[main] from main::@1
|
||||
[15] return
|
||||
@ -355,17 +355,17 @@ Uplift Scope [world]
|
||||
Uplift Scope [main]
|
||||
Uplift Scope [__start]
|
||||
|
||||
Uplifting [do10] best 1054 combination zp[1]:7 [ do10::i#2 do10::i#1 ] zp[2]:5 [ do10::fn#3 ]
|
||||
Uplifting [print] best 934 combination reg byte y [ print::i#2 print::i#1 ] zp[2]:2 [ print::msg#3 ]
|
||||
Uplifting [] best 934 combination zp[1]:8 [ idx ]
|
||||
Uplifting [hello] best 934 combination
|
||||
Uplifting [world] best 934 combination
|
||||
Uplifting [main] best 934 combination
|
||||
Uplifting [__start] best 934 combination
|
||||
Uplifting [do10] best 1099 combination zp[1]:7 [ do10::i#2 do10::i#1 ] zp[2]:5 [ do10::fn#3 ]
|
||||
Uplifting [print] best 979 combination reg byte y [ print::i#2 print::i#1 ] zp[2]:2 [ print::msg#3 ]
|
||||
Uplifting [] best 979 combination zp[1]:8 [ idx ]
|
||||
Uplifting [hello] best 979 combination
|
||||
Uplifting [world] best 979 combination
|
||||
Uplifting [main] best 979 combination
|
||||
Uplifting [__start] best 979 combination
|
||||
Attempting to uplift remaining variables inzp[1]:7 [ do10::i#2 do10::i#1 ]
|
||||
Uplifting [do10] best 934 combination zp[1]:7 [ do10::i#2 do10::i#1 ]
|
||||
Uplifting [do10] best 979 combination zp[1]:7 [ do10::i#2 do10::i#1 ]
|
||||
Attempting to uplift remaining variables inzp[1]:8 [ idx ]
|
||||
Uplifting [] best 934 combination zp[1]:8 [ idx ]
|
||||
Uplifting [] best 979 combination zp[1]:8 [ idx ]
|
||||
Allocated (was zp[2]:5) zp[2]:4 [ do10::fn#3 ]
|
||||
Allocated (was zp[1]:7) zp[1]:6 [ do10::i#2 do10::i#1 ]
|
||||
Allocated (was zp[1]:8) zp[1]:7 [ idx ]
|
||||
@ -399,7 +399,7 @@ __start: {
|
||||
jmp __b1
|
||||
// __start::@1
|
||||
__b1:
|
||||
// [3] call main
|
||||
// [3] call main
|
||||
// [11] phi from __start::@1 to main [phi:__start::@1->main]
|
||||
main_from___b1:
|
||||
jsr main
|
||||
@ -411,7 +411,7 @@ __start: {
|
||||
}
|
||||
// world
|
||||
world: {
|
||||
// [6] call print
|
||||
// [6] call print
|
||||
// [16] phi from world to print [phi:world->print]
|
||||
print_from_world:
|
||||
// [16] phi print::msg#3 = world::msg [phi:world->print#0] -- pbuz1=pbuc1
|
||||
@ -432,7 +432,7 @@ world: {
|
||||
.segment Code
|
||||
// hello
|
||||
hello: {
|
||||
// [9] call print
|
||||
// [9] call print
|
||||
// [16] phi from hello to print [phi:hello->print]
|
||||
print_from_hello:
|
||||
// [16] phi print::msg#3 = hello::msg [phi:hello->print#0] -- pbuz1=pbuc1
|
||||
@ -453,7 +453,7 @@ hello: {
|
||||
.segment Code
|
||||
// main
|
||||
main: {
|
||||
// [12] call do10
|
||||
// [12] call do10
|
||||
// [23] phi from main to do10 [phi:main->do10]
|
||||
do10_from_main:
|
||||
// [23] phi do10::fn#3 = &hello [phi:main->do10#0] -- pprz1=pprc1
|
||||
@ -467,7 +467,7 @@ main: {
|
||||
jmp __b1
|
||||
// main::@1
|
||||
__b1:
|
||||
// [14] call do10
|
||||
// [14] call do10
|
||||
// [23] phi from main::@1 to do10 [phi:main::@1->do10]
|
||||
do10_from___b1:
|
||||
// [23] phi do10::fn#3 = &world [phi:main::@1->do10#0] -- pprz1=pprc1
|
||||
@ -532,8 +532,8 @@ do10: {
|
||||
jmp __b1
|
||||
// do10::@1
|
||||
__b1:
|
||||
// [25] callexecute *do10::fn#3
|
||||
jsr bi_fn
|
||||
// [25] callexecute *do10::fn#3 -- call__deref_pprz1
|
||||
jsr icall1
|
||||
jmp __b2
|
||||
// do10::@2
|
||||
__b2:
|
||||
@ -548,7 +548,8 @@ do10: {
|
||||
__breturn:
|
||||
// [28] return
|
||||
rts
|
||||
bi_fn:
|
||||
// Outside Flow
|
||||
icall1:
|
||||
jmp (fn)
|
||||
}
|
||||
// File Data
|
||||
@ -626,7 +627,7 @@ zp[1]:7 [ idx ]
|
||||
|
||||
|
||||
FINAL ASSEMBLER
|
||||
Score: 676
|
||||
Score: 721
|
||||
|
||||
// File Comments
|
||||
// Tests calling into different function pointers which call a common sub-method
|
||||
@ -652,7 +653,7 @@ __start: {
|
||||
sta.z idx
|
||||
// [2] phi from __start::__init1 to __start::@1 [phi:__start::__init1->__start::@1]
|
||||
// __start::@1
|
||||
// [3] call main
|
||||
// [3] call main
|
||||
// [11] phi from __start::@1 to main [phi:__start::@1->main]
|
||||
jsr main
|
||||
// __start::@return
|
||||
@ -662,7 +663,7 @@ __start: {
|
||||
// world
|
||||
world: {
|
||||
// print("world ")
|
||||
// [6] call print
|
||||
// [6] call print
|
||||
// [16] phi from world to print [phi:world->print]
|
||||
// [16] phi print::msg#3 = world::msg [phi:world->print#0] -- pbuz1=pbuc1
|
||||
lda #<msg
|
||||
@ -682,7 +683,7 @@ world: {
|
||||
// hello
|
||||
hello: {
|
||||
// print("hello ")
|
||||
// [9] call print
|
||||
// [9] call print
|
||||
// [16] phi from hello to print [phi:hello->print]
|
||||
// [16] phi print::msg#3 = hello::msg [phi:hello->print#0] -- pbuz1=pbuc1
|
||||
lda #<msg
|
||||
@ -702,7 +703,7 @@ hello: {
|
||||
// main
|
||||
main: {
|
||||
// do10(&hello)
|
||||
// [12] call do10
|
||||
// [12] call do10
|
||||
// [23] phi from main to do10 [phi:main->do10]
|
||||
// [23] phi do10::fn#3 = &hello [phi:main->do10#0] -- pprz1=pprc1
|
||||
lda #<hello
|
||||
@ -713,7 +714,7 @@ main: {
|
||||
// [13] phi from main to main::@1 [phi:main->main::@1]
|
||||
// main::@1
|
||||
// do10(&world)
|
||||
// [14] call do10
|
||||
// [14] call do10
|
||||
// [23] phi from main::@1 to do10 [phi:main::@1->do10]
|
||||
// [23] phi do10::fn#3 = &world [phi:main::@1->do10#0] -- pprz1=pprc1
|
||||
lda #<world
|
||||
@ -771,8 +772,8 @@ do10: {
|
||||
// do10::@1
|
||||
__b1:
|
||||
// (*fn)()
|
||||
// [25] callexecute *do10::fn#3
|
||||
jsr bi_fn
|
||||
// [25] callexecute *do10::fn#3 -- call__deref_pprz1
|
||||
jsr icall1
|
||||
// do10::@2
|
||||
// for( byte i: 0..9)
|
||||
// [26] do10::i#1 = ++ do10::i#2 -- vbuz1=_inc_vbuz1
|
||||
@ -785,7 +786,8 @@ do10: {
|
||||
// }
|
||||
// [28] return
|
||||
rts
|
||||
bi_fn:
|
||||
// Outside Flow
|
||||
icall1:
|
||||
jmp (fn)
|
||||
}
|
||||
// File Data
|
||||
|
@ -1,4 +1,4 @@
|
||||
Inlined call call __init
|
||||
Inlined call call __init
|
||||
Calling convention STACK_CALL adding prepare/execute/finalize for call *funcPointer
|
||||
Calling convention STACK_CALL adding prepare/execute/finalize for call *funcPointer
|
||||
|
||||
@ -43,7 +43,7 @@ __start::__init1: scope:[__start] from __start
|
||||
to:__start::@1
|
||||
__start::@1: scope:[__start] from __start::__init1
|
||||
funcPointer#9 = phi( __start::__init1/funcPointer#3 )
|
||||
call main
|
||||
call main
|
||||
to:__start::@2
|
||||
__start::@2: scope:[__start] from __start::@1
|
||||
funcPointer#7 = phi( __start::@1/funcPointer#2 )
|
||||
@ -180,14 +180,14 @@ ASSEMBLER BEFORE OPTIMIZATION
|
||||
.segment Code
|
||||
// main
|
||||
main: {
|
||||
// [1] callexecute myFunc -- jsr
|
||||
// [1] callexecute myFunc -- call_vprc1
|
||||
jsr myFunc
|
||||
// [2] phi from main to main::@1 [phi:main->main::@1]
|
||||
__b1_from_main:
|
||||
jmp __b1
|
||||
// main::@1
|
||||
__b1:
|
||||
// [3] callexecute myFunc2 -- jsr
|
||||
// [3] callexecute myFunc2 -- call_vprc1
|
||||
jsr myFunc2
|
||||
jmp __breturn
|
||||
// main::@return
|
||||
@ -262,12 +262,12 @@ Score: 42
|
||||
// main
|
||||
main: {
|
||||
// (*funcPointer)()
|
||||
// [1] callexecute myFunc -- jsr
|
||||
// [1] callexecute myFunc -- call_vprc1
|
||||
jsr myFunc
|
||||
// [2] phi from main to main::@1 [phi:main->main::@1]
|
||||
// main::@1
|
||||
// (*funcPointer)()
|
||||
// [3] callexecute myFunc2 -- jsr
|
||||
// [3] callexecute myFunc2 -- call_vprc1
|
||||
jsr myFunc2
|
||||
// main::@return
|
||||
// }
|
||||
|
@ -28,19 +28,19 @@ main: {
|
||||
lda addrtable+1
|
||||
sta.z fn+1
|
||||
// (*fn)()
|
||||
jsr bi_fn
|
||||
jsr icall1
|
||||
// fn = addrtable[1]
|
||||
lda addrtable+1*SIZEOF_POINTER
|
||||
sta.z fn_1
|
||||
lda addrtable+1*SIZEOF_POINTER+1
|
||||
sta.z fn_1+1
|
||||
// (*fn)()
|
||||
jsr bi_fn_1
|
||||
jsr icall2
|
||||
// }
|
||||
rts
|
||||
bi_fn:
|
||||
icall1:
|
||||
jmp (fn)
|
||||
bi_fn_1:
|
||||
icall2:
|
||||
jmp (fn_1)
|
||||
}
|
||||
myFunc2: {
|
||||
|
@ -40,7 +40,7 @@ main::@return: scope:[main] from main::@1
|
||||
|
||||
void __start()
|
||||
__start: scope:[__start] from
|
||||
call main
|
||||
call main
|
||||
to:__start::@1
|
||||
__start::@1: scope:[__start] from __start
|
||||
to:__start::@return
|
||||
@ -195,10 +195,10 @@ Uplift Scope [myFunc]
|
||||
Uplift Scope [myFunc2]
|
||||
Uplift Scope []
|
||||
|
||||
Uplifting [main] best 116 combination zp[2]:2 [ main::fn#0 ] zp[2]:4 [ main::fn#1 ]
|
||||
Uplifting [myFunc] best 116 combination
|
||||
Uplifting [myFunc2] best 116 combination
|
||||
Uplifting [] best 116 combination
|
||||
Uplifting [main] best 206 combination zp[2]:2 [ main::fn#0 ] zp[2]:4 [ main::fn#1 ]
|
||||
Uplifting [myFunc] best 206 combination
|
||||
Uplifting [myFunc2] best 206 combination
|
||||
Uplifting [] best 206 combination
|
||||
|
||||
ASSEMBLER BEFORE OPTIMIZATION
|
||||
// File Comments
|
||||
@ -234,8 +234,8 @@ main: {
|
||||
sta.z fn
|
||||
lda addrtable+1
|
||||
sta.z fn+1
|
||||
// [3] callexecute *main::fn#0
|
||||
jsr bi_fn
|
||||
// [3] callexecute *main::fn#0 -- call__deref_pprz1
|
||||
jsr icall1
|
||||
jmp __b1
|
||||
// main::@1
|
||||
__b1:
|
||||
@ -244,16 +244,17 @@ main: {
|
||||
sta.z fn_1
|
||||
lda addrtable+1*SIZEOF_POINTER+1
|
||||
sta.z fn_1+1
|
||||
// [5] callexecute *main::fn#1
|
||||
jsr bi_fn_1
|
||||
// [5] callexecute *main::fn#1 -- call__deref_pprz1
|
||||
jsr icall2
|
||||
jmp __breturn
|
||||
// main::@return
|
||||
__breturn:
|
||||
// [6] return
|
||||
rts
|
||||
bi_fn:
|
||||
// Outside Flow
|
||||
icall1:
|
||||
jmp (fn)
|
||||
bi_fn_1:
|
||||
icall2:
|
||||
jmp (fn_1)
|
||||
}
|
||||
// myFunc2
|
||||
@ -311,7 +312,7 @@ zp[2]:4 [ main::fn#1 ]
|
||||
|
||||
|
||||
FINAL ASSEMBLER
|
||||
Score: 104
|
||||
Score: 194
|
||||
|
||||
// File Comments
|
||||
// Tests calling through pointers to non-args no-return functions
|
||||
@ -350,8 +351,8 @@ main: {
|
||||
lda addrtable+1
|
||||
sta.z fn+1
|
||||
// (*fn)()
|
||||
// [3] callexecute *main::fn#0
|
||||
jsr bi_fn
|
||||
// [3] callexecute *main::fn#0 -- call__deref_pprz1
|
||||
jsr icall1
|
||||
// main::@1
|
||||
// fn = addrtable[1]
|
||||
// [4] main::fn#1 = *(addrtable+1*SIZEOF_POINTER) -- pprz1=_deref_qprc1
|
||||
@ -360,15 +361,16 @@ main: {
|
||||
lda addrtable+1*SIZEOF_POINTER+1
|
||||
sta.z fn_1+1
|
||||
// (*fn)()
|
||||
// [5] callexecute *main::fn#1
|
||||
jsr bi_fn_1
|
||||
// [5] callexecute *main::fn#1 -- call__deref_pprz1
|
||||
jsr icall2
|
||||
// main::@return
|
||||
// }
|
||||
// [6] return
|
||||
rts
|
||||
bi_fn:
|
||||
// Outside Flow
|
||||
icall1:
|
||||
jmp (fn)
|
||||
bi_fn_1:
|
||||
icall2:
|
||||
jmp (fn_1)
|
||||
}
|
||||
// myFunc2
|
||||
|
@ -203,10 +203,10 @@ gotoxy: {
|
||||
f1: {
|
||||
.label fn = 4
|
||||
// (*fn)()
|
||||
jsr bi_fn
|
||||
jsr icall1
|
||||
// }
|
||||
rts
|
||||
bi_fn:
|
||||
icall1:
|
||||
jmp (fn)
|
||||
}
|
||||
// Output one character at the current cursor position
|
||||
|
@ -4,7 +4,7 @@ Fixing struct type size struct printf_buffer_number to 12
|
||||
Fixing struct type SIZE_OF struct printf_buffer_number to 12
|
||||
Fixing struct type SIZE_OF struct printf_buffer_number to 12
|
||||
Inlined call vicSelectGfxBank::$0 = call toDd00(vicSelectGfxBank::gfx)
|
||||
Inlined call call __init
|
||||
Inlined call call __init
|
||||
Eliminating unused variable with no statement memcpy::$0
|
||||
Eliminating unused variable with no statement memset::$2
|
||||
Eliminating unused variable with no statement gotoxy::$4
|
||||
@ -142,7 +142,7 @@ cputc: scope:[cputc] from cputs::@2
|
||||
if(cputc::$0) goto cputc::@1
|
||||
to:cputc::@2
|
||||
cputc::@1: scope:[cputc] from cputc
|
||||
call cputln
|
||||
call cputln
|
||||
to:cputc::@4
|
||||
cputc::@4: scope:[cputc] from cputc::@1
|
||||
to:cputc::@return
|
||||
@ -156,7 +156,7 @@ cputc::@2: scope:[cputc] from cputc
|
||||
if(cputc::$2) goto cputc::@return
|
||||
to:cputc::@3
|
||||
cputc::@3: scope:[cputc] from cputc::@2
|
||||
call cputln
|
||||
call cputln
|
||||
to:cputc::@5
|
||||
cputc::@5: scope:[cputc] from cputc::@3
|
||||
to:cputc::@return
|
||||
@ -170,7 +170,7 @@ cputln: scope:[cputln] from cputc::@1 cputc::@3
|
||||
conio_line_color = conio_line_color + $28
|
||||
conio_cursor_x = 0
|
||||
conio_cursor_y = ++ conio_cursor_y
|
||||
call cscroll
|
||||
call cscroll
|
||||
to:cputln::@1
|
||||
cputln::@1: scope:[cputln] from cputln
|
||||
to:cputln::@return
|
||||
@ -195,7 +195,7 @@ cputs::@2: scope:[cputs] from cputs::@1
|
||||
cputs::s#6 = phi( cputs::@1/cputs::s#0 )
|
||||
cputs::c#2 = phi( cputs::@1/cputs::c#1 )
|
||||
cputc::c#0 = cputs::c#2
|
||||
call cputc
|
||||
call cputc
|
||||
to:cputs::@3
|
||||
cputs::@3: scope:[cputs] from cputs::@2
|
||||
cputs::s#5 = phi( cputs::@2/cputs::s#6 )
|
||||
@ -218,28 +218,28 @@ cscroll::@3: scope:[cscroll] from cscroll::@1
|
||||
memcpy::destination#0 = (void*)CONIO_SCREEN_TEXT
|
||||
memcpy::source#0 = (void*)CONIO_SCREEN_TEXT+$28
|
||||
memcpy::num#0 = $19*$28-$28
|
||||
call memcpy
|
||||
call memcpy
|
||||
memcpy::return#2 = memcpy::return#1
|
||||
to:cscroll::@4
|
||||
cscroll::@4: scope:[cscroll] from cscroll::@3
|
||||
memcpy::destination#1 = (void*)CONIO_SCREEN_COLORS
|
||||
memcpy::source#1 = (void*)CONIO_SCREEN_COLORS+$28
|
||||
memcpy::num#1 = $19*$28-$28
|
||||
call memcpy
|
||||
call memcpy
|
||||
memcpy::return#3 = memcpy::return#1
|
||||
to:cscroll::@5
|
||||
cscroll::@5: scope:[cscroll] from cscroll::@4
|
||||
memset::str#0 = (void*)CONIO_SCREEN_TEXT+$19*$28-$28
|
||||
memset::c#0 = ' '
|
||||
memset::num#0 = $28
|
||||
call memset
|
||||
call memset
|
||||
memset::return#2 = memset::return#1
|
||||
to:cscroll::@6
|
||||
cscroll::@6: scope:[cscroll] from cscroll::@5
|
||||
memset::str#1 = (void*)CONIO_SCREEN_COLORS+$19*$28-$28
|
||||
memset::c#1 = conio_textcolor
|
||||
memset::num#1 = $28
|
||||
call memset
|
||||
call memset
|
||||
memset::return#3 = memset::return#1
|
||||
to:cscroll::@7
|
||||
cscroll::@7: scope:[cscroll] from cscroll::@6
|
||||
@ -250,7 +250,7 @@ cscroll::@7: scope:[cscroll] from cscroll::@6
|
||||
cscroll::@2: scope:[cscroll] from cscroll::@1
|
||||
gotoxy::x#1 = 0
|
||||
gotoxy::y#1 = 0
|
||||
call gotoxy
|
||||
call gotoxy
|
||||
to:cscroll::@8
|
||||
cscroll::@8: scope:[cscroll] from cscroll::@2
|
||||
to:cscroll::@return
|
||||
@ -269,7 +269,7 @@ conio_c64_init::@1: scope:[conio_c64_init] from conio_c64_init conio_c64_init::
|
||||
conio_c64_init::line#2 = phi( conio_c64_init/conio_c64_init::line#0, conio_c64_init::@2/conio_c64_init::line#1 )
|
||||
gotoxy::x#2 = 0
|
||||
gotoxy::y#2 = conio_c64_init::line#2
|
||||
call gotoxy
|
||||
call gotoxy
|
||||
to:conio_c64_init::@3
|
||||
conio_c64_init::@3: scope:[conio_c64_init] from conio_c64_init::@1
|
||||
to:conio_c64_init::@return
|
||||
@ -292,7 +292,7 @@ f1::@return: scope:[f1] from f1
|
||||
void hello()
|
||||
hello: scope:[hello] from
|
||||
cputs::s#1 = hello::s
|
||||
call cputs
|
||||
call cputs
|
||||
to:hello::@1
|
||||
hello::@1: scope:[hello] from hello
|
||||
to:hello::@return
|
||||
@ -303,7 +303,7 @@ hello::@return: scope:[hello] from hello::@1
|
||||
void world()
|
||||
world: scope:[world] from
|
||||
cputs::s#2 = world::s
|
||||
call cputs
|
||||
call cputs
|
||||
to:world::@1
|
||||
world::@1: scope:[world] from world
|
||||
to:world::@return
|
||||
@ -314,11 +314,11 @@ world::@return: scope:[world] from world::@1
|
||||
void main()
|
||||
main: scope:[main] from __start::@1
|
||||
f1::fn#0 = &hello
|
||||
call f1
|
||||
call f1
|
||||
to:main::@1
|
||||
main::@1: scope:[main] from main
|
||||
f1::fn#1 = &world
|
||||
call f1
|
||||
call f1
|
||||
to:main::@2
|
||||
main::@2: scope:[main] from main::@1
|
||||
to:main::@return
|
||||
@ -336,12 +336,12 @@ __start::__init1: scope:[__start] from __start
|
||||
conio_line_color = CONIO_SCREEN_COLORS
|
||||
conio_textcolor = CONIO_TEXTCOLOR_DEFAULT
|
||||
conio_scroll_enable = 1
|
||||
call conio_c64_init
|
||||
call conio_c64_init
|
||||
to:__start::@2
|
||||
__start::@2: scope:[__start] from __start::__init1
|
||||
to:__start::@1
|
||||
__start::@1: scope:[__start] from __start::@2
|
||||
call main
|
||||
call main
|
||||
to:__start::@3
|
||||
__start::@3: scope:[__start] from __start::@1
|
||||
to:__start::@return
|
||||
@ -932,11 +932,11 @@ __start::__init1: scope:[__start] from __start
|
||||
[2] conio_cursor_y = 0
|
||||
[3] conio_line_text = DEFAULT_SCREEN
|
||||
[4] conio_line_color = COLORRAM
|
||||
[5] call conio_c64_init
|
||||
[5] call conio_c64_init
|
||||
to:__start::@1
|
||||
__start::@1: scope:[__start] from __start::__init1
|
||||
[6] phi()
|
||||
[7] call main
|
||||
[7] call main
|
||||
to:__start::@return
|
||||
__start::@return: scope:[__start] from __start::@1
|
||||
[8] return
|
||||
@ -945,7 +945,7 @@ __start::@return: scope:[__start] from __start::@1
|
||||
void world()
|
||||
world: scope:[world] from
|
||||
[9] phi()
|
||||
[10] call cputs
|
||||
[10] call cputs
|
||||
to:world::@return
|
||||
world::@return: scope:[world] from world
|
||||
[11] return
|
||||
@ -954,7 +954,7 @@ world::@return: scope:[world] from world
|
||||
void hello()
|
||||
hello: scope:[hello] from
|
||||
[12] phi()
|
||||
[13] call cputs
|
||||
[13] call cputs
|
||||
to:hello::@return
|
||||
hello::@return: scope:[hello] from hello
|
||||
[14] return
|
||||
@ -971,7 +971,7 @@ conio_c64_init::@2: scope:[conio_c64_init] from conio_c64_init
|
||||
conio_c64_init::@1: scope:[conio_c64_init] from conio_c64_init conio_c64_init::@2
|
||||
[18] conio_c64_init::line#2 = phi( conio_c64_init::@2/conio_c64_init::line#0, conio_c64_init/$19-1 )
|
||||
[19] gotoxy::y#2 = conio_c64_init::line#2
|
||||
[20] call gotoxy
|
||||
[20] call gotoxy
|
||||
to:conio_c64_init::@return
|
||||
conio_c64_init::@return: scope:[conio_c64_init] from conio_c64_init::@1
|
||||
[21] return
|
||||
@ -980,11 +980,11 @@ conio_c64_init::@return: scope:[conio_c64_init] from conio_c64_init::@1
|
||||
void main()
|
||||
main: scope:[main] from __start::@1
|
||||
[22] phi()
|
||||
[23] call f1
|
||||
[23] call f1
|
||||
to:main::@1
|
||||
main::@1: scope:[main] from main
|
||||
[24] phi()
|
||||
[25] call f1
|
||||
[25] call f1
|
||||
to:main::@return
|
||||
main::@return: scope:[main] from main::@1
|
||||
[26] return
|
||||
@ -1005,7 +1005,7 @@ cputs::@return: scope:[cputs] from cputs::@1
|
||||
to:@return
|
||||
cputs::@2: scope:[cputs] from cputs::@1
|
||||
[33] cputc::c#0 = cputs::c#1
|
||||
[34] call cputc
|
||||
[34] call cputc
|
||||
to:cputs::@1
|
||||
|
||||
void gotoxy(byte gotoxy::x , byte gotoxy::y)
|
||||
@ -1056,14 +1056,14 @@ cputc::@2: scope:[cputc] from cputc
|
||||
to:cputc::@3
|
||||
cputc::@3: scope:[cputc] from cputc::@2
|
||||
[57] phi()
|
||||
[58] call cputln
|
||||
[58] call cputln
|
||||
to:cputc::@return
|
||||
cputc::@return: scope:[cputc] from cputc::@1 cputc::@2 cputc::@3
|
||||
[59] return
|
||||
to:@return
|
||||
cputc::@1: scope:[cputc] from cputc
|
||||
[60] phi()
|
||||
[61] call cputln
|
||||
[61] call cputln
|
||||
to:cputc::@return
|
||||
|
||||
void cputln()
|
||||
@ -1072,7 +1072,7 @@ cputln: scope:[cputln] from cputc::@1 cputc::@3
|
||||
[63] conio_line_color = conio_line_color + $28
|
||||
[64] conio_cursor_x = 0
|
||||
[65] conio_cursor_y = ++ conio_cursor_y
|
||||
[66] call cscroll
|
||||
[66] call cscroll
|
||||
to:cputln::@return
|
||||
cputln::@return: scope:[cputln] from cputln
|
||||
[67] return
|
||||
@ -1084,19 +1084,19 @@ cscroll: scope:[cscroll] from cputln
|
||||
to:cscroll::@1
|
||||
cscroll::@1: scope:[cscroll] from cscroll
|
||||
[69] phi()
|
||||
[70] call memcpy
|
||||
[70] call memcpy
|
||||
to:cscroll::@2
|
||||
cscroll::@2: scope:[cscroll] from cscroll::@1
|
||||
[71] phi()
|
||||
[72] call memcpy
|
||||
[72] call memcpy
|
||||
to:cscroll::@3
|
||||
cscroll::@3: scope:[cscroll] from cscroll::@2
|
||||
[73] phi()
|
||||
[74] call memset
|
||||
[74] call memset
|
||||
to:cscroll::@4
|
||||
cscroll::@4: scope:[cscroll] from cscroll::@3
|
||||
[75] phi()
|
||||
[76] call memset
|
||||
[76] call memset
|
||||
to:cscroll::@5
|
||||
cscroll::@5: scope:[cscroll] from cscroll::@4
|
||||
[77] conio_line_text = conio_line_text - $28
|
||||
@ -1418,31 +1418,31 @@ Uplift Scope [world]
|
||||
Uplift Scope [main]
|
||||
Uplift Scope [__start]
|
||||
|
||||
Uplifting [memcpy] best 12986 combination zp[2]:12 [ memcpy::src#2 memcpy::src#4 memcpy::src#1 ] zp[2]:14 [ memcpy::dst#2 memcpy::dst#4 memcpy::dst#1 ] zp[2]:41 [ memcpy::src_end#0 ] zp[2]:8 [ memcpy::source#2 ] zp[2]:10 [ memcpy::destination#2 ]
|
||||
Uplifting [memset] best 12880 combination zp[2]:19 [ memset::dst#2 memset::dst#4 memset::dst#1 ] zp[2]:43 [ memset::end#0 ] reg byte x [ memset::c#4 ] zp[2]:16 [ memset::str#3 ]
|
||||
Uplifting [] best 12880 combination zp[1]:22 [ conio_cursor_y ] zp[2]:23 [ conio_line_text ] zp[2]:25 [ conio_line_color ] zp[1]:21 [ conio_cursor_x ]
|
||||
Uplifting [gotoxy] best 12867 combination zp[2]:31 [ gotoxy::$8 ] zp[2]:33 [ gotoxy::$9 ] zp[2]:37 [ gotoxy::$5 ] zp[2]:39 [ gotoxy::$6 ] zp[2]:29 [ gotoxy::$7 ] reg byte x [ gotoxy::y#4 gotoxy::y#2 ] zp[2]:35 [ gotoxy::line_offset#0 ]
|
||||
Uplifting [cputc] best 12831 combination reg byte a [ cputc::c#0 ]
|
||||
Uplifting [cputs] best 12761 combination zp[2]:3 [ cputs::s#3 cputs::s#4 cputs::s#0 ] reg byte a [ cputs::c#1 ]
|
||||
Uplifting [conio_c64_init] best 12749 combination reg byte x [ conio_c64_init::line#2 conio_c64_init::line#0 ]
|
||||
Uplifting [RADIX] best 12749 combination
|
||||
Uplifting [cputln] best 12749 combination
|
||||
Uplifting [MOS6526_CIA] best 12749 combination
|
||||
Uplifting [MOS6569_VICII] best 12749 combination
|
||||
Uplifting [MOS6581_SID] best 12749 combination
|
||||
Uplifting [cscroll] best 12749 combination
|
||||
Uplifting [printf_format_number] best 12749 combination
|
||||
Uplifting [printf_buffer_number] best 12749 combination
|
||||
Uplifting [printf_format_string] best 12749 combination
|
||||
Uplifting [f1] best 12749 combination zp[2]:6 [ f1::fn#2 ]
|
||||
Uplifting [hello] best 12749 combination
|
||||
Uplifting [world] best 12749 combination
|
||||
Uplifting [main] best 12749 combination
|
||||
Uplifting [__start] best 12749 combination
|
||||
Uplifting [memcpy] best 13031 combination zp[2]:12 [ memcpy::src#2 memcpy::src#4 memcpy::src#1 ] zp[2]:14 [ memcpy::dst#2 memcpy::dst#4 memcpy::dst#1 ] zp[2]:41 [ memcpy::src_end#0 ] zp[2]:8 [ memcpy::source#2 ] zp[2]:10 [ memcpy::destination#2 ]
|
||||
Uplifting [memset] best 12925 combination zp[2]:19 [ memset::dst#2 memset::dst#4 memset::dst#1 ] zp[2]:43 [ memset::end#0 ] reg byte x [ memset::c#4 ] zp[2]:16 [ memset::str#3 ]
|
||||
Uplifting [] best 12925 combination zp[1]:22 [ conio_cursor_y ] zp[2]:23 [ conio_line_text ] zp[2]:25 [ conio_line_color ] zp[1]:21 [ conio_cursor_x ]
|
||||
Uplifting [gotoxy] best 12912 combination zp[2]:31 [ gotoxy::$8 ] zp[2]:33 [ gotoxy::$9 ] zp[2]:37 [ gotoxy::$5 ] zp[2]:39 [ gotoxy::$6 ] zp[2]:29 [ gotoxy::$7 ] reg byte x [ gotoxy::y#4 gotoxy::y#2 ] zp[2]:35 [ gotoxy::line_offset#0 ]
|
||||
Uplifting [cputc] best 12876 combination reg byte a [ cputc::c#0 ]
|
||||
Uplifting [cputs] best 12806 combination zp[2]:3 [ cputs::s#3 cputs::s#4 cputs::s#0 ] reg byte a [ cputs::c#1 ]
|
||||
Uplifting [conio_c64_init] best 12794 combination reg byte x [ conio_c64_init::line#2 conio_c64_init::line#0 ]
|
||||
Uplifting [RADIX] best 12794 combination
|
||||
Uplifting [cputln] best 12794 combination
|
||||
Uplifting [MOS6526_CIA] best 12794 combination
|
||||
Uplifting [MOS6569_VICII] best 12794 combination
|
||||
Uplifting [MOS6581_SID] best 12794 combination
|
||||
Uplifting [cscroll] best 12794 combination
|
||||
Uplifting [printf_format_number] best 12794 combination
|
||||
Uplifting [printf_buffer_number] best 12794 combination
|
||||
Uplifting [printf_format_string] best 12794 combination
|
||||
Uplifting [f1] best 12794 combination zp[2]:6 [ f1::fn#2 ]
|
||||
Uplifting [hello] best 12794 combination
|
||||
Uplifting [world] best 12794 combination
|
||||
Uplifting [main] best 12794 combination
|
||||
Uplifting [__start] best 12794 combination
|
||||
Attempting to uplift remaining variables inzp[1]:22 [ conio_cursor_y ]
|
||||
Uplifting [] best 12749 combination zp[1]:22 [ conio_cursor_y ]
|
||||
Uplifting [] best 12794 combination zp[1]:22 [ conio_cursor_y ]
|
||||
Attempting to uplift remaining variables inzp[1]:21 [ conio_cursor_x ]
|
||||
Uplifting [] best 12749 combination zp[1]:21 [ conio_cursor_x ]
|
||||
Uplifting [] best 12794 combination zp[1]:21 [ conio_cursor_x ]
|
||||
Coalescing zero page register [ zp[2]:8 [ memcpy::source#2 ] ] with [ zp[2]:12 [ memcpy::src#2 memcpy::src#4 memcpy::src#1 ] ] - score: 1
|
||||
Coalescing zero page register [ zp[2]:10 [ memcpy::destination#2 ] ] with [ zp[2]:14 [ memcpy::dst#2 memcpy::dst#4 memcpy::dst#1 ] ] - score: 1
|
||||
Coalescing zero page register [ zp[2]:16 [ memset::str#3 ] ] with [ zp[2]:19 [ memset::dst#2 memset::dst#4 memset::dst#1 ] ] - score: 1
|
||||
@ -1513,14 +1513,14 @@ __start: {
|
||||
sta.z conio_line_color
|
||||
lda #>COLORRAM
|
||||
sta.z conio_line_color+1
|
||||
// [5] call conio_c64_init
|
||||
// [5] call conio_c64_init
|
||||
jsr conio_c64_init
|
||||
// [6] phi from __start::__init1 to __start::@1 [phi:__start::__init1->__start::@1]
|
||||
__b1_from___init1:
|
||||
jmp __b1
|
||||
// __start::@1
|
||||
__b1:
|
||||
// [7] call main
|
||||
// [7] call main
|
||||
// [22] phi from __start::@1 to main [phi:__start::@1->main]
|
||||
main_from___b1:
|
||||
jsr main
|
||||
@ -1532,7 +1532,7 @@ __start: {
|
||||
}
|
||||
// world
|
||||
world: {
|
||||
// [10] call cputs
|
||||
// [10] call cputs
|
||||
// [27] phi from world to cputs [phi:world->cputs]
|
||||
cputs_from_world:
|
||||
// [27] phi cputs::s#4 = world::s [phi:world->cputs#0] -- pbuz1=pbuc1
|
||||
@ -1553,7 +1553,7 @@ world: {
|
||||
.segment Code
|
||||
// hello
|
||||
hello: {
|
||||
// [13] call cputs
|
||||
// [13] call cputs
|
||||
// [27] phi from hello to cputs [phi:hello->cputs]
|
||||
cputs_from_hello:
|
||||
// [27] phi cputs::s#4 = hello::s [phi:hello->cputs#0] -- pbuz1=pbuc1
|
||||
@ -1599,7 +1599,7 @@ conio_c64_init: {
|
||||
// conio_c64_init::@1
|
||||
__b1:
|
||||
// [19] gotoxy::y#2 = conio_c64_init::line#2
|
||||
// [20] call gotoxy
|
||||
// [20] call gotoxy
|
||||
jsr gotoxy
|
||||
jmp __breturn
|
||||
// conio_c64_init::@return
|
||||
@ -1609,7 +1609,7 @@ conio_c64_init: {
|
||||
}
|
||||
// main
|
||||
main: {
|
||||
// [23] call f1
|
||||
// [23] call f1
|
||||
// [49] phi from main to f1 [phi:main->f1]
|
||||
f1_from_main:
|
||||
// [49] phi f1::fn#2 = &hello [phi:main->f1#0] -- pprz1=pprc1
|
||||
@ -1623,7 +1623,7 @@ main: {
|
||||
jmp __b1
|
||||
// main::@1
|
||||
__b1:
|
||||
// [25] call f1
|
||||
// [25] call f1
|
||||
// [49] phi from main::@1 to f1 [phi:main::@1->f1]
|
||||
f1_from___b1:
|
||||
// [49] phi f1::fn#2 = &world [phi:main::@1->f1#0] -- pprz1=pprc1
|
||||
@ -1669,7 +1669,7 @@ cputs: {
|
||||
// cputs::@2
|
||||
__b2:
|
||||
// [33] cputc::c#0 = cputs::c#1
|
||||
// [34] call cputc
|
||||
// [34] call cputc
|
||||
jsr cputc
|
||||
jmp __b1_from___b2
|
||||
}
|
||||
@ -1776,14 +1776,15 @@ gotoxy: {
|
||||
// f1(void()* zp(4) fn)
|
||||
f1: {
|
||||
.label fn = 4
|
||||
// [50] callexecute *f1::fn#2
|
||||
jsr bi_fn
|
||||
// [50] callexecute *f1::fn#2 -- call__deref_pprz1
|
||||
jsr icall1
|
||||
jmp __breturn
|
||||
// f1::@return
|
||||
__breturn:
|
||||
// [51] return
|
||||
rts
|
||||
bi_fn:
|
||||
// Outside Flow
|
||||
icall1:
|
||||
jmp (fn)
|
||||
}
|
||||
// cputc
|
||||
@ -1815,7 +1816,7 @@ cputc: {
|
||||
jmp __b3
|
||||
// cputc::@3
|
||||
__b3:
|
||||
// [58] call cputln
|
||||
// [58] call cputln
|
||||
jsr cputln
|
||||
jmp __breturn
|
||||
// cputc::@return
|
||||
@ -1827,7 +1828,7 @@ cputc: {
|
||||
jmp __b1
|
||||
// cputc::@1
|
||||
__b1:
|
||||
// [61] call cputln
|
||||
// [61] call cputln
|
||||
jsr cputln
|
||||
jmp __breturn
|
||||
}
|
||||
@ -1855,7 +1856,7 @@ cputln: {
|
||||
sta.z conio_cursor_x
|
||||
// [65] conio_cursor_y = ++ conio_cursor_y -- vbuz1=_inc_vbuz1
|
||||
inc.z conio_cursor_y
|
||||
// [66] call cscroll
|
||||
// [66] call cscroll
|
||||
jsr cscroll
|
||||
jmp __breturn
|
||||
// cputln::@return
|
||||
@ -1875,7 +1876,7 @@ cscroll: {
|
||||
jmp __b1
|
||||
// cscroll::@1
|
||||
__b1:
|
||||
// [70] call memcpy
|
||||
// [70] call memcpy
|
||||
// [81] phi from cscroll::@1 to memcpy [phi:cscroll::@1->memcpy]
|
||||
memcpy_from___b1:
|
||||
// [81] phi memcpy::destination#2 = (void*)DEFAULT_SCREEN [phi:cscroll::@1->memcpy#0] -- pvoz1=pvoc1
|
||||
@ -1894,7 +1895,7 @@ cscroll: {
|
||||
jmp __b2
|
||||
// cscroll::@2
|
||||
__b2:
|
||||
// [72] call memcpy
|
||||
// [72] call memcpy
|
||||
// [81] phi from cscroll::@2 to memcpy [phi:cscroll::@2->memcpy]
|
||||
memcpy_from___b2:
|
||||
// [81] phi memcpy::destination#2 = (void*)COLORRAM [phi:cscroll::@2->memcpy#0] -- pvoz1=pvoc1
|
||||
@ -1913,7 +1914,7 @@ cscroll: {
|
||||
jmp __b3
|
||||
// cscroll::@3
|
||||
__b3:
|
||||
// [74] call memset
|
||||
// [74] call memset
|
||||
// [91] phi from cscroll::@3 to memset [phi:cscroll::@3->memset]
|
||||
memset_from___b3:
|
||||
// [91] phi memset::c#4 = ' ' [phi:cscroll::@3->memset#0] -- vbuxx=vbuc1
|
||||
@ -1929,7 +1930,7 @@ cscroll: {
|
||||
jmp __b4
|
||||
// cscroll::@4
|
||||
__b4:
|
||||
// [76] call memset
|
||||
// [76] call memset
|
||||
// [91] phi from cscroll::@4 to memset [phi:cscroll::@4->memset]
|
||||
memset_from___b4:
|
||||
// [91] phi memset::c#4 = LIGHT_BLUE [phi:cscroll::@4->memset#0] -- vbuxx=vbuc1
|
||||
@ -2289,7 +2290,7 @@ zp[2]:22 [ memset::end#0 memcpy::destination#2 memcpy::dst#2 memcpy::dst#4 memcp
|
||||
|
||||
|
||||
FINAL ASSEMBLER
|
||||
Score: 11077
|
||||
Score: 11122
|
||||
|
||||
// File Comments
|
||||
// Tests trouble passing a function pointer
|
||||
@ -2341,11 +2342,11 @@ __start: {
|
||||
lda #>COLORRAM
|
||||
sta.z conio_line_color+1
|
||||
// #pragma constructor_for(conio_c64_init, cputc, clrscr, cscroll)
|
||||
// [5] call conio_c64_init
|
||||
// [5] call conio_c64_init
|
||||
jsr conio_c64_init
|
||||
// [6] phi from __start::__init1 to __start::@1 [phi:__start::__init1->__start::@1]
|
||||
// __start::@1
|
||||
// [7] call main
|
||||
// [7] call main
|
||||
// [22] phi from __start::@1 to main [phi:__start::@1->main]
|
||||
jsr main
|
||||
// __start::@return
|
||||
@ -2355,7 +2356,7 @@ __start: {
|
||||
// world
|
||||
world: {
|
||||
// printf("world!")
|
||||
// [10] call cputs
|
||||
// [10] call cputs
|
||||
// [27] phi from world to cputs [phi:world->cputs]
|
||||
// [27] phi cputs::s#4 = world::s [phi:world->cputs#0] -- pbuz1=pbuc1
|
||||
lda #<s
|
||||
@ -2375,7 +2376,7 @@ world: {
|
||||
// hello
|
||||
hello: {
|
||||
// printf("hello ")
|
||||
// [13] call cputs
|
||||
// [13] call cputs
|
||||
// [27] phi from hello to cputs [phi:hello->cputs]
|
||||
// [27] phi cputs::s#4 = hello::s [phi:hello->cputs#0] -- pbuz1=pbuc1
|
||||
lda #<s
|
||||
@ -2415,7 +2416,7 @@ conio_c64_init: {
|
||||
__b1:
|
||||
// gotoxy(0, line)
|
||||
// [19] gotoxy::y#2 = conio_c64_init::line#2
|
||||
// [20] call gotoxy
|
||||
// [20] call gotoxy
|
||||
jsr gotoxy
|
||||
// conio_c64_init::@return
|
||||
// }
|
||||
@ -2425,7 +2426,7 @@ conio_c64_init: {
|
||||
// main
|
||||
main: {
|
||||
// f1(&hello)
|
||||
// [23] call f1
|
||||
// [23] call f1
|
||||
// [49] phi from main to f1 [phi:main->f1]
|
||||
// [49] phi f1::fn#2 = &hello [phi:main->f1#0] -- pprz1=pprc1
|
||||
lda #<hello
|
||||
@ -2436,7 +2437,7 @@ main: {
|
||||
// [24] phi from main to main::@1 [phi:main->main::@1]
|
||||
// main::@1
|
||||
// f1(&world)
|
||||
// [25] call f1
|
||||
// [25] call f1
|
||||
// [49] phi from main::@1 to f1 [phi:main::@1->f1]
|
||||
// [49] phi f1::fn#2 = &world [phi:main::@1->f1#0] -- pprz1=pprc1
|
||||
lda #<world
|
||||
@ -2478,7 +2479,7 @@ cputs: {
|
||||
__b2:
|
||||
// cputc(c)
|
||||
// [33] cputc::c#0 = cputs::c#1
|
||||
// [34] call cputc
|
||||
// [34] call cputc
|
||||
jsr cputc
|
||||
jmp __b1
|
||||
}
|
||||
@ -2584,13 +2585,14 @@ gotoxy: {
|
||||
f1: {
|
||||
.label fn = 4
|
||||
// (*fn)()
|
||||
// [50] callexecute *f1::fn#2
|
||||
jsr bi_fn
|
||||
// [50] callexecute *f1::fn#2 -- call__deref_pprz1
|
||||
jsr icall1
|
||||
// f1::@return
|
||||
// }
|
||||
// [51] return
|
||||
rts
|
||||
bi_fn:
|
||||
// Outside Flow
|
||||
icall1:
|
||||
jmp (fn)
|
||||
}
|
||||
// cputc
|
||||
@ -2621,7 +2623,7 @@ cputc: {
|
||||
// [57] phi from cputc::@2 to cputc::@3 [phi:cputc::@2->cputc::@3]
|
||||
// cputc::@3
|
||||
// cputln()
|
||||
// [58] call cputln
|
||||
// [58] call cputln
|
||||
jsr cputln
|
||||
// cputc::@return
|
||||
__breturn:
|
||||
@ -2632,7 +2634,7 @@ cputc: {
|
||||
// cputc::@1
|
||||
__b1:
|
||||
// cputln()
|
||||
// [61] call cputln
|
||||
// [61] call cputln
|
||||
jsr cputln
|
||||
rts
|
||||
}
|
||||
@ -2665,7 +2667,7 @@ cputln: {
|
||||
// [65] conio_cursor_y = ++ conio_cursor_y -- vbuz1=_inc_vbuz1
|
||||
inc.z conio_cursor_y
|
||||
// cscroll()
|
||||
// [66] call cscroll
|
||||
// [66] call cscroll
|
||||
jsr cscroll
|
||||
// cputln::@return
|
||||
// }
|
||||
@ -2683,7 +2685,7 @@ cscroll: {
|
||||
// [69] phi from cscroll to cscroll::@1 [phi:cscroll->cscroll::@1]
|
||||
// cscroll::@1
|
||||
// memcpy(CONIO_SCREEN_TEXT, CONIO_SCREEN_TEXT+CONIO_WIDTH, CONIO_BYTES-CONIO_WIDTH)
|
||||
// [70] call memcpy
|
||||
// [70] call memcpy
|
||||
// [81] phi from cscroll::@1 to memcpy [phi:cscroll::@1->memcpy]
|
||||
// [81] phi memcpy::destination#2 = (void*)DEFAULT_SCREEN [phi:cscroll::@1->memcpy#0] -- pvoz1=pvoc1
|
||||
lda #<DEFAULT_SCREEN
|
||||
@ -2699,7 +2701,7 @@ cscroll: {
|
||||
// [71] phi from cscroll::@1 to cscroll::@2 [phi:cscroll::@1->cscroll::@2]
|
||||
// cscroll::@2
|
||||
// memcpy(CONIO_SCREEN_COLORS, CONIO_SCREEN_COLORS+CONIO_WIDTH, CONIO_BYTES-CONIO_WIDTH)
|
||||
// [72] call memcpy
|
||||
// [72] call memcpy
|
||||
// [81] phi from cscroll::@2 to memcpy [phi:cscroll::@2->memcpy]
|
||||
// [81] phi memcpy::destination#2 = (void*)COLORRAM [phi:cscroll::@2->memcpy#0] -- pvoz1=pvoc1
|
||||
lda #<COLORRAM
|
||||
@ -2715,7 +2717,7 @@ cscroll: {
|
||||
// [73] phi from cscroll::@2 to cscroll::@3 [phi:cscroll::@2->cscroll::@3]
|
||||
// cscroll::@3
|
||||
// memset(CONIO_SCREEN_TEXT+CONIO_BYTES-CONIO_WIDTH, ' ', CONIO_WIDTH)
|
||||
// [74] call memset
|
||||
// [74] call memset
|
||||
// [91] phi from cscroll::@3 to memset [phi:cscroll::@3->memset]
|
||||
// [91] phi memset::c#4 = ' ' [phi:cscroll::@3->memset#0] -- vbuxx=vbuc1
|
||||
ldx #' '
|
||||
@ -2728,7 +2730,7 @@ cscroll: {
|
||||
// [75] phi from cscroll::@3 to cscroll::@4 [phi:cscroll::@3->cscroll::@4]
|
||||
// cscroll::@4
|
||||
// memset(CONIO_SCREEN_COLORS+CONIO_BYTES-CONIO_WIDTH, conio_textcolor, CONIO_WIDTH)
|
||||
// [76] call memset
|
||||
// [76] call memset
|
||||
// [91] phi from cscroll::@4 to memset [phi:cscroll::@4->memset]
|
||||
// [91] phi memset::c#4 = LIGHT_BLUE [phi:cscroll::@4->memset#0] -- vbuxx=vbuc1
|
||||
ldx #LIGHT_BLUE
|
||||
|
@ -48,8 +48,8 @@ main: {
|
||||
sta.z f+1
|
||||
__b4:
|
||||
// (*f)()
|
||||
jsr bi_f
|
||||
jsr icall1
|
||||
jmp __b2
|
||||
bi_f:
|
||||
icall1:
|
||||
jmp (f)
|
||||
}
|
||||
|
@ -55,7 +55,7 @@ fn2::@return: scope:[fn2] from fn2
|
||||
|
||||
void __start()
|
||||
__start: scope:[__start] from
|
||||
call main
|
||||
call main
|
||||
to:__start::@1
|
||||
__start::@1: scope:[__start] from __start
|
||||
to:__start::@return
|
||||
@ -309,13 +309,14 @@ main: {
|
||||
jmp __b4
|
||||
// main::@4
|
||||
__b4:
|
||||
// [11] callexecute *main::f#3
|
||||
jsr bi_f
|
||||
// [11] callexecute *main::f#3 -- call__deref_pprz1
|
||||
jsr icall1
|
||||
// [5] phi from main::@4 to main::@1 [phi:main::@4->main::@1]
|
||||
__b1_from___b4:
|
||||
// [5] phi main::i#2 = main::i#1 [phi:main::@4->main::@1#0] -- register_copy
|
||||
jmp __b1
|
||||
bi_f:
|
||||
// Outside Flow
|
||||
icall1:
|
||||
jmp (f)
|
||||
}
|
||||
// File Data
|
||||
@ -438,12 +439,13 @@ main: {
|
||||
// main::@4
|
||||
__b4:
|
||||
// (*f)()
|
||||
// [11] callexecute *main::f#3
|
||||
jsr bi_f
|
||||
// [11] callexecute *main::f#3 -- call__deref_pprz1
|
||||
jsr icall1
|
||||
// [5] phi from main::@4 to main::@1 [phi:main::@4->main::@1]
|
||||
// [5] phi main::i#2 = main::i#1 [phi:main::@4->main::@1#0] -- register_copy
|
||||
jmp __b2
|
||||
bi_f:
|
||||
// Outside Flow
|
||||
icall1:
|
||||
jmp (f)
|
||||
}
|
||||
// File Data
|
||||
|
@ -34,9 +34,9 @@ main: {
|
||||
lda.z i
|
||||
jsr getfn
|
||||
// (*getfn(++i))()
|
||||
jsr bi___0
|
||||
jsr icall1
|
||||
jmp __b2
|
||||
bi___0:
|
||||
icall1:
|
||||
jmp (__0)
|
||||
}
|
||||
// declare getfn as function (char b) returning pointer to function (void) returning void
|
||||
|
@ -16,7 +16,7 @@ main::@2: scope:[main] from main::@1
|
||||
main::i#2 = phi( main::@1/main::i#3 )
|
||||
main::i#1 = ++ main::i#2
|
||||
getfn::b#0 = main::i#1
|
||||
call getfn
|
||||
call getfn
|
||||
getfn::return#0 = getfn::return#3
|
||||
to:main::@3
|
||||
main::@3: scope:[main] from main::@2
|
||||
@ -66,7 +66,7 @@ fn2::@return: scope:[fn2] from fn2
|
||||
|
||||
void __start()
|
||||
__start: scope:[__start] from
|
||||
call main
|
||||
call main
|
||||
to:__start::@1
|
||||
__start::@1: scope:[__start] from __start
|
||||
to:__start::@return
|
||||
@ -185,7 +185,7 @@ main::@1: scope:[main] from main main::@3
|
||||
main::@2: scope:[main] from main::@1
|
||||
[6] main::i#1 = ++ main::i#2
|
||||
[7] getfn::b#0 = main::i#1
|
||||
[8] call getfn
|
||||
[8] call getfn
|
||||
[9] getfn::return#0 = getfn::return#3
|
||||
to:main::@3
|
||||
main::@3: scope:[main] from main::@2
|
||||
@ -332,20 +332,21 @@ main: {
|
||||
inc.z i
|
||||
// [7] getfn::b#0 = main::i#1 -- vbuaa=vbuz1
|
||||
lda.z i
|
||||
// [8] call getfn
|
||||
// [8] call getfn
|
||||
jsr getfn
|
||||
// [9] getfn::return#0 = getfn::return#3
|
||||
jmp __b3
|
||||
// main::@3
|
||||
__b3:
|
||||
// [10] main::$0 = getfn::return#0
|
||||
// [11] callexecute *main::$0
|
||||
jsr bi___0
|
||||
// [11] callexecute *main::$0 -- call__deref_pprz1
|
||||
jsr icall1
|
||||
// [5] phi from main::@3 to main::@1 [phi:main::@3->main::@1]
|
||||
__b1_from___b3:
|
||||
// [5] phi main::i#2 = main::i#1 [phi:main::@3->main::@1#0] -- register_copy
|
||||
jmp __b1
|
||||
bi___0:
|
||||
// Outside Flow
|
||||
icall1:
|
||||
jmp (__0)
|
||||
}
|
||||
// getfn
|
||||
@ -492,18 +493,19 @@ main: {
|
||||
// getfn(++i)
|
||||
// [7] getfn::b#0 = main::i#1 -- vbuaa=vbuz1
|
||||
lda.z i
|
||||
// [8] call getfn
|
||||
// [8] call getfn
|
||||
jsr getfn
|
||||
// [9] getfn::return#0 = getfn::return#3
|
||||
// main::@3
|
||||
// [10] main::$0 = getfn::return#0
|
||||
// (*getfn(++i))()
|
||||
// [11] callexecute *main::$0
|
||||
jsr bi___0
|
||||
// [11] callexecute *main::$0 -- call__deref_pprz1
|
||||
jsr icall1
|
||||
// [5] phi from main::@3 to main::@1 [phi:main::@3->main::@1]
|
||||
// [5] phi main::i#2 = main::i#1 [phi:main::@3->main::@1#0] -- register_copy
|
||||
jmp __b2
|
||||
bi___0:
|
||||
// Outside Flow
|
||||
icall1:
|
||||
jmp (__0)
|
||||
}
|
||||
// getfn
|
||||
|
@ -15,7 +15,7 @@ main::@2: scope:[main] from main::@1
|
||||
main::i#2 = phi( main::@1/main::i#3 )
|
||||
main::i#1 = ++ main::i#2
|
||||
getfn::b#0 = main::i#1
|
||||
call getfn
|
||||
call getfn
|
||||
getfn::return#0 = getfn::return#2
|
||||
to:main::@3
|
||||
main::@3: scope:[main] from main::@2
|
||||
@ -48,7 +48,7 @@ fn1::@return: scope:[fn1] from fn1
|
||||
|
||||
void __start()
|
||||
__start: scope:[__start] from
|
||||
call main
|
||||
call main
|
||||
to:__start::@1
|
||||
__start::@1: scope:[__start] from __start
|
||||
to:__start::@return
|
||||
@ -105,7 +105,7 @@ Eliminating unused constant getfn::return#0
|
||||
Successful SSA optimization PassNEliminateUnusedVars
|
||||
Eliminating unused constant getfn::return#1
|
||||
Successful SSA optimization PassNEliminateUnusedVars
|
||||
Removing call to empty/unused procedure [2] call getfn
|
||||
Removing call to empty/unused procedure [2] call getfn
|
||||
Removing unused procedure getfn
|
||||
Removing unused procedure block getfn
|
||||
Removing unused procedure block getfn::@return
|
||||
@ -224,7 +224,7 @@ main: {
|
||||
jmp __b3
|
||||
// main::@3
|
||||
__b3:
|
||||
// [6] callexecute fn1 -- jsr
|
||||
// [6] callexecute fn1 -- call_vprc1
|
||||
jsr fn1
|
||||
// [3] phi from main::@3 to main::@1 [phi:main::@3->main::@1]
|
||||
__b1_from___b3:
|
||||
@ -301,7 +301,7 @@ main: {
|
||||
// [5] phi from main::@2 to main::@3 [phi:main::@2->main::@3]
|
||||
// main::@3
|
||||
// (*getfn(++i))()
|
||||
// [6] callexecute fn1 -- jsr
|
||||
// [6] callexecute fn1 -- call_vprc1
|
||||
jsr fn1
|
||||
// [3] phi from main::@3 to main::@1 [phi:main::@3->main::@1]
|
||||
// [3] phi main::i#2 = main::i#1 [phi:main::@3->main::@1#0] -- register_copy
|
||||
|
@ -27,9 +27,9 @@ main: {
|
||||
lda fns+1,y
|
||||
sta.z f+1
|
||||
// (*f)()
|
||||
jsr bi_f
|
||||
jsr icall1
|
||||
jmp __b2
|
||||
bi_f:
|
||||
icall1:
|
||||
jmp (f)
|
||||
}
|
||||
fn2: {
|
||||
|
@ -40,7 +40,7 @@ main::@return: scope:[main] from main::@1
|
||||
|
||||
void __start()
|
||||
__start: scope:[__start] from
|
||||
call main
|
||||
call main
|
||||
to:__start::@1
|
||||
__start::@1: scope:[__start] from __start
|
||||
to:__start::@return
|
||||
@ -242,13 +242,14 @@ main: {
|
||||
sta.z f
|
||||
lda fns+1,y
|
||||
sta.z f+1
|
||||
// [6] callexecute *main::f#0
|
||||
jsr bi_f
|
||||
// [6] callexecute *main::f#0 -- call__deref_pprz1
|
||||
jsr icall1
|
||||
// [1] phi from main::@2 to main::@1 [phi:main::@2->main::@1]
|
||||
__b1_from___b2:
|
||||
// [1] phi main::i#2 = main::i#1 [phi:main::@2->main::@1#0] -- register_copy
|
||||
jmp __b1
|
||||
bi_f:
|
||||
// Outside Flow
|
||||
icall1:
|
||||
jmp (f)
|
||||
}
|
||||
// fn2
|
||||
@ -358,12 +359,13 @@ main: {
|
||||
lda fns+1,y
|
||||
sta.z f+1
|
||||
// (*f)()
|
||||
// [6] callexecute *main::f#0
|
||||
jsr bi_f
|
||||
// [6] callexecute *main::f#0 -- call__deref_pprz1
|
||||
jsr icall1
|
||||
// [1] phi from main::@2 to main::@1 [phi:main::@2->main::@1]
|
||||
// [1] phi main::i#2 = main::i#1 [phi:main::@2->main::@1#0] -- register_copy
|
||||
jmp __b2
|
||||
bi_f:
|
||||
// Outside Flow
|
||||
icall1:
|
||||
jmp (f)
|
||||
}
|
||||
// fn2
|
||||
|
@ -44,7 +44,7 @@ main::@return: scope:[main] from main::@1
|
||||
|
||||
void __start()
|
||||
__start: scope:[__start] from
|
||||
call main
|
||||
call main
|
||||
to:__start::@1
|
||||
__start::@1: scope:[__start] from __start
|
||||
to:__start::@return
|
||||
@ -242,7 +242,7 @@ main: {
|
||||
jmp __b2
|
||||
// main::@2
|
||||
__b2:
|
||||
// [5] callexecute fn1 -- jsr
|
||||
// [5] callexecute fn1 -- call_vprc1
|
||||
jsr fn1
|
||||
jmp __b3
|
||||
// main::@3
|
||||
@ -395,7 +395,7 @@ main: {
|
||||
// main::@2
|
||||
__b2:
|
||||
// (*cls)()
|
||||
// [5] callexecute fn1 -- jsr
|
||||
// [5] callexecute fn1 -- call_vprc1
|
||||
jsr fn1
|
||||
// main::@3
|
||||
// (*cols)++;
|
||||
|
@ -1,4 +1,4 @@
|
||||
Inlined call call __init
|
||||
Inlined call call __init
|
||||
Calling convention STACK_CALL adding prepare/execute/finalize for call *do10::fn
|
||||
|
||||
CONTROL FLOW GRAPH SSA
|
||||
@ -43,7 +43,7 @@ hello::@return: scope:[hello] from hello::@1
|
||||
void main()
|
||||
main: scope:[main] from __start::@1
|
||||
do10::fn#0 = main::f
|
||||
call do10
|
||||
call do10
|
||||
to:main::@1
|
||||
main::@1: scope:[main] from main
|
||||
to:main::@return
|
||||
@ -58,7 +58,7 @@ __start::__init1: scope:[__start] from __start
|
||||
idx = 0
|
||||
to:__start::@1
|
||||
__start::@1: scope:[__start] from __start::__init1
|
||||
call main
|
||||
call main
|
||||
to:__start::@2
|
||||
__start::@2: scope:[__start] from __start::@1
|
||||
to:__start::@return
|
||||
@ -170,7 +170,7 @@ __start::__init1: scope:[__start] from __start
|
||||
to:__start::@1
|
||||
__start::@1: scope:[__start] from __start::__init1
|
||||
[2] phi()
|
||||
[3] call main
|
||||
[3] call main
|
||||
to:__start::@return
|
||||
__start::@return: scope:[__start] from __start::@1
|
||||
[4] return
|
||||
@ -194,7 +194,7 @@ hello::@return: scope:[hello] from hello::@1
|
||||
void main()
|
||||
main: scope:[main] from __start::@1
|
||||
[12] phi()
|
||||
[13] call do10
|
||||
[13] call do10
|
||||
to:main::@return
|
||||
main::@return: scope:[main] from main
|
||||
[14] return
|
||||
@ -306,7 +306,7 @@ __start: {
|
||||
jmp __b1
|
||||
// __start::@1
|
||||
__b1:
|
||||
// [3] call main
|
||||
// [3] call main
|
||||
// [12] phi from __start::@1 to main [phi:__start::@1->main]
|
||||
main_from___b1:
|
||||
jsr main
|
||||
@ -349,7 +349,7 @@ hello: {
|
||||
}
|
||||
// main
|
||||
main: {
|
||||
// [13] call do10
|
||||
// [13] call do10
|
||||
// [15] phi from main to do10 [phi:main->do10]
|
||||
do10_from_main:
|
||||
jsr do10
|
||||
@ -374,7 +374,7 @@ do10: {
|
||||
jmp __b1
|
||||
// do10::@1
|
||||
__b1:
|
||||
// [17] callexecute hello -- jsr
|
||||
// [17] callexecute hello -- call_vprc1
|
||||
jsr hello
|
||||
jmp __b2
|
||||
// do10::@2
|
||||
@ -477,7 +477,7 @@ __start: {
|
||||
sta.z idx
|
||||
// [2] phi from __start::__init1 to __start::@1 [phi:__start::__init1->__start::@1]
|
||||
// __start::@1
|
||||
// [3] call main
|
||||
// [3] call main
|
||||
// [12] phi from __start::@1 to main [phi:__start::@1->main]
|
||||
jsr main
|
||||
// __start::@return
|
||||
@ -516,7 +516,7 @@ hello: {
|
||||
// main
|
||||
main: {
|
||||
// do10(f)
|
||||
// [13] call do10
|
||||
// [13] call do10
|
||||
// [15] phi from main to do10 [phi:main->do10]
|
||||
jsr do10
|
||||
// main::@return
|
||||
@ -536,7 +536,7 @@ do10: {
|
||||
// do10::@1
|
||||
__b1:
|
||||
// (*fn)()
|
||||
// [17] callexecute hello -- jsr
|
||||
// [17] callexecute hello -- call_vprc1
|
||||
jsr hello
|
||||
// do10::@2
|
||||
// for( byte i: 0..9)
|
||||
|
@ -1,4 +1,4 @@
|
||||
Inlined call call __init
|
||||
Inlined call call __init
|
||||
Calling convention STACK_CALL adding prepare/execute/finalize for call *do10::fn
|
||||
|
||||
CONTROL FLOW GRAPH SSA
|
||||
@ -44,12 +44,12 @@ void main()
|
||||
main: scope:[main] from __start::@1
|
||||
msg = msg1
|
||||
do10::fn#0 = main::f
|
||||
call do10
|
||||
call do10
|
||||
to:main::@1
|
||||
main::@1: scope:[main] from main
|
||||
msg = msg2
|
||||
do10::fn#1 = main::f
|
||||
call do10
|
||||
call do10
|
||||
to:main::@2
|
||||
main::@2: scope:[main] from main::@1
|
||||
to:main::@return
|
||||
@ -65,7 +65,7 @@ __start::__init1: scope:[__start] from __start
|
||||
idx = 0
|
||||
to:__start::@1
|
||||
__start::@1: scope:[__start] from __start::__init1
|
||||
call main
|
||||
call main
|
||||
to:__start::@2
|
||||
__start::@2: scope:[__start] from __start::@1
|
||||
to:__start::@return
|
||||
@ -183,7 +183,7 @@ __start::__init1: scope:[__start] from __start
|
||||
to:__start::@1
|
||||
__start::@1: scope:[__start] from __start::__init1
|
||||
[3] phi()
|
||||
[4] call main
|
||||
[4] call main
|
||||
to:__start::@return
|
||||
__start::@return: scope:[__start] from __start::@1
|
||||
[5] return
|
||||
@ -207,11 +207,11 @@ hello::@return: scope:[hello] from hello::@1
|
||||
void main()
|
||||
main: scope:[main] from __start::@1
|
||||
[13] msg = msg1
|
||||
[14] call do10
|
||||
[14] call do10
|
||||
to:main::@1
|
||||
main::@1: scope:[main] from main
|
||||
[15] msg = msg2
|
||||
[16] call do10
|
||||
[16] call do10
|
||||
to:main::@return
|
||||
main::@return: scope:[main] from main::@1
|
||||
[17] return
|
||||
@ -341,7 +341,7 @@ __start: {
|
||||
jmp __b1
|
||||
// __start::@1
|
||||
__b1:
|
||||
// [4] call main
|
||||
// [4] call main
|
||||
jsr main
|
||||
jmp __breturn
|
||||
// __start::@return
|
||||
@ -387,7 +387,7 @@ main: {
|
||||
sta.z msg
|
||||
lda #>msg1
|
||||
sta.z msg+1
|
||||
// [14] call do10
|
||||
// [14] call do10
|
||||
// [18] phi from main to do10 [phi:main->do10]
|
||||
do10_from_main:
|
||||
jsr do10
|
||||
@ -399,7 +399,7 @@ main: {
|
||||
sta.z msg
|
||||
lda #>msg2
|
||||
sta.z msg+1
|
||||
// [16] call do10
|
||||
// [16] call do10
|
||||
// [18] phi from main::@1 to do10 [phi:main::@1->do10]
|
||||
do10_from___b1:
|
||||
jsr do10
|
||||
@ -424,7 +424,7 @@ do10: {
|
||||
jmp __b1
|
||||
// do10::@1
|
||||
__b1:
|
||||
// [20] callexecute hello -- jsr
|
||||
// [20] callexecute hello -- call_vprc1
|
||||
jsr hello
|
||||
jmp __b2
|
||||
// do10::@2
|
||||
@ -542,7 +542,7 @@ __start: {
|
||||
sta.z idx
|
||||
// [3] phi from __start::__init1 to __start::@1 [phi:__start::__init1->__start::@1]
|
||||
// __start::@1
|
||||
// [4] call main
|
||||
// [4] call main
|
||||
jsr main
|
||||
// __start::@return
|
||||
// [5] return
|
||||
@ -586,7 +586,7 @@ main: {
|
||||
lda #>msg1
|
||||
sta.z msg+1
|
||||
// do10(f)
|
||||
// [14] call do10
|
||||
// [14] call do10
|
||||
// [18] phi from main to do10 [phi:main->do10]
|
||||
jsr do10
|
||||
// main::@1
|
||||
@ -597,7 +597,7 @@ main: {
|
||||
lda #>msg2
|
||||
sta.z msg+1
|
||||
// do10(f)
|
||||
// [16] call do10
|
||||
// [16] call do10
|
||||
// [18] phi from main::@1 to do10 [phi:main::@1->do10]
|
||||
jsr do10
|
||||
// main::@return
|
||||
@ -617,7 +617,7 @@ do10: {
|
||||
// do10::@1
|
||||
__b1:
|
||||
// (*fn)()
|
||||
// [20] callexecute hello -- jsr
|
||||
// [20] callexecute hello -- call_vprc1
|
||||
jsr hello
|
||||
// do10::@2
|
||||
// for( byte i: 0..9)
|
||||
|
@ -1,4 +1,4 @@
|
||||
Inlined call call __init
|
||||
Inlined call call __init
|
||||
Calling convention STACK_CALL adding prepare/execute/finalize for call *main::f
|
||||
Calling convention STACK_CALL adding prepare/execute/finalize for call *main::f
|
||||
|
||||
@ -34,7 +34,7 @@ __start::__init1: scope:[__start] from __start
|
||||
idx = 0
|
||||
to:__start::@1
|
||||
__start::@1: scope:[__start] from __start::__init1
|
||||
call main
|
||||
call main
|
||||
to:__start::@2
|
||||
__start::@2: scope:[__start] from __start::@1
|
||||
to:__start::@return
|
||||
@ -83,7 +83,7 @@ __start::__init1: scope:[__start] from __start
|
||||
to:__start::@1
|
||||
__start::@1: scope:[__start] from __start::__init1
|
||||
[2] phi()
|
||||
[3] call main
|
||||
[3] call main
|
||||
to:__start::@return
|
||||
__start::@return: scope:[__start] from __start::@1
|
||||
[4] return
|
||||
@ -173,7 +173,7 @@ __start: {
|
||||
jmp __b1
|
||||
// __start::@1
|
||||
__b1:
|
||||
// [3] call main
|
||||
// [3] call main
|
||||
// [7] phi from __start::@1 to main [phi:__start::@1->main]
|
||||
main_from___b1:
|
||||
jsr main
|
||||
@ -195,7 +195,7 @@ fn1: {
|
||||
}
|
||||
// main
|
||||
main: {
|
||||
// [8] callexecute fn1 -- jsr
|
||||
// [8] callexecute fn1 -- call_vprc1
|
||||
jsr fn1
|
||||
jmp __b1
|
||||
// main::@1
|
||||
@ -204,7 +204,7 @@ main: {
|
||||
lda #'a'
|
||||
ldy.z idx
|
||||
sta SCREEN,y
|
||||
// [10] callexecute fn1 -- jsr
|
||||
// [10] callexecute fn1 -- call_vprc1
|
||||
jsr fn1
|
||||
jmp __b2
|
||||
// main::@2
|
||||
@ -279,7 +279,7 @@ __start: {
|
||||
sta.z idx
|
||||
// [2] phi from __start::__init1 to __start::@1 [phi:__start::__init1->__start::@1]
|
||||
// __start::@1
|
||||
// [3] call main
|
||||
// [3] call main
|
||||
// [7] phi from __start::@1 to main [phi:__start::@1->main]
|
||||
jsr main
|
||||
// __start::@return
|
||||
@ -299,7 +299,7 @@ fn1: {
|
||||
// main
|
||||
main: {
|
||||
// (*f)()
|
||||
// [8] callexecute fn1 -- jsr
|
||||
// [8] callexecute fn1 -- call_vprc1
|
||||
jsr fn1
|
||||
// main::@1
|
||||
// SCREEN[idx] = 'a'
|
||||
@ -308,7 +308,7 @@ main: {
|
||||
ldy.z idx
|
||||
sta SCREEN,y
|
||||
// (*f)()
|
||||
// [10] callexecute fn1 -- jsr
|
||||
// [10] callexecute fn1 -- call_vprc1
|
||||
jsr fn1
|
||||
// main::@2
|
||||
// SCREEN[idx] = 'a'
|
||||
|
@ -20,7 +20,7 @@ main::@return: scope:[main] from main
|
||||
|
||||
void __start()
|
||||
__start: scope:[__start] from
|
||||
call main
|
||||
call main
|
||||
to:__start::@1
|
||||
__start::@1: scope:[__start] from __start
|
||||
to:__start::@return
|
||||
@ -107,7 +107,7 @@ ASSEMBLER BEFORE OPTIMIZATION
|
||||
.segment Code
|
||||
// main
|
||||
main: {
|
||||
// [1] callexecute fn1 -- jsr
|
||||
// [1] callexecute fn1 -- call_vprc1
|
||||
jsr fn1
|
||||
jmp __breturn
|
||||
// main::@return
|
||||
@ -162,7 +162,7 @@ Score: 24
|
||||
// main
|
||||
main: {
|
||||
// (*f)()
|
||||
// [1] callexecute fn1 -- jsr
|
||||
// [1] callexecute fn1 -- call_vprc1
|
||||
jsr fn1
|
||||
// main::@return
|
||||
// }
|
||||
|
@ -97,9 +97,9 @@ main: {
|
||||
// (*f)(i)
|
||||
lda.z i
|
||||
pha
|
||||
jsr bi_f
|
||||
jsr icall2
|
||||
pla
|
||||
jmp __b4
|
||||
bi_f:
|
||||
icall2:
|
||||
jmp (f)
|
||||
}
|
||||
|
@ -96,7 +96,7 @@ fn3::@return: scope:[fn3] from fn3
|
||||
|
||||
void __start()
|
||||
__start: scope:[__start] from
|
||||
call main
|
||||
call main
|
||||
to:__start::@1
|
||||
__start::@1: scope:[__start] from __start
|
||||
to:__start::@return
|
||||
@ -482,7 +482,7 @@ main: {
|
||||
// [15] stackpush(byte) = main::i#2 -- _stackpushbyte_=vbuz1
|
||||
lda.z i
|
||||
pha
|
||||
// [16] callexecute fn3 -- jsr
|
||||
// [16] callexecute fn3 -- call_vprc1
|
||||
jsr fn3
|
||||
// sideeffect stackpullbytes(1) -- _stackpullbyte_1
|
||||
pla
|
||||
@ -529,12 +529,13 @@ main: {
|
||||
// [23] stackpush(byte) = main::i#2 -- _stackpushbyte_=vbuz1
|
||||
lda.z i
|
||||
pha
|
||||
// [24] callexecute *main::f#3
|
||||
jsr bi_f
|
||||
// [24] callexecute *main::f#3 -- call__deref_pprz1
|
||||
jsr icall2
|
||||
// sideeffect stackpullbytes(1) -- _stackpullbyte_1
|
||||
pla
|
||||
jmp __b4
|
||||
bi_f:
|
||||
// Outside Flow
|
||||
icall2:
|
||||
jmp (f)
|
||||
}
|
||||
// File Data
|
||||
@ -702,7 +703,7 @@ main: {
|
||||
// [15] stackpush(byte) = main::i#2 -- _stackpushbyte_=vbuz1
|
||||
lda.z i
|
||||
pha
|
||||
// [16] callexecute fn3 -- jsr
|
||||
// [16] callexecute fn3 -- call_vprc1
|
||||
jsr fn3
|
||||
// sideeffect stackpullbytes(1) -- _stackpullbyte_1
|
||||
pla
|
||||
@ -746,12 +747,13 @@ main: {
|
||||
// [23] stackpush(byte) = main::i#2 -- _stackpushbyte_=vbuz1
|
||||
lda.z i
|
||||
pha
|
||||
// [24] callexecute *main::f#3
|
||||
jsr bi_f
|
||||
// [24] callexecute *main::f#3 -- call__deref_pprz1
|
||||
jsr icall2
|
||||
// sideeffect stackpullbytes(1) -- _stackpullbyte_1
|
||||
pla
|
||||
jmp __b4
|
||||
bi_f:
|
||||
// Outside Flow
|
||||
icall2:
|
||||
jmp (f)
|
||||
}
|
||||
// File Data
|
||||
|
@ -151,11 +151,11 @@ main: {
|
||||
lda fns+1,y
|
||||
sta.z f+1
|
||||
// (*f)()
|
||||
jsr bi_f
|
||||
jsr icall1
|
||||
// for(char j=0;j<2;j++)
|
||||
inc.z j
|
||||
jmp __b2
|
||||
bi_f:
|
||||
icall1:
|
||||
jmp (f)
|
||||
.segment Data
|
||||
fns: .word fn1, fn2
|
||||
|
@ -1,7 +1,7 @@
|
||||
Setting inferred volatile on symbol affected by address-of: fn1::param_char in asm { pla staparam_char }
|
||||
Setting inferred volatile on symbol affected by address-of: fn2::param_char in asm { pla staparam_char }
|
||||
Setting inferred volatile on symbol affected by address-of: main::param_char in asm { ldaparam_char pha }
|
||||
Inlined call call __init
|
||||
Inlined call call __init
|
||||
Calling convention STACK_CALL adding prepare/execute/finalize for call *main::f
|
||||
|
||||
CONTROL FLOW GRAPH SSA
|
||||
@ -96,7 +96,7 @@ __start::__init1: scope:[__start] from __start
|
||||
idx2 = 0
|
||||
to:__start::@1
|
||||
__start::@1: scope:[__start] from __start::__init1
|
||||
call main
|
||||
call main
|
||||
to:__start::@2
|
||||
__start::@2: scope:[__start] from __start::@1
|
||||
to:__start::@return
|
||||
@ -240,7 +240,7 @@ __start::__init1: scope:[__start] from __start
|
||||
to:__start::@1
|
||||
__start::@1: scope:[__start] from __start::__init1
|
||||
[3] phi()
|
||||
[4] call main
|
||||
[4] call main
|
||||
to:__start::@return
|
||||
__start::@return: scope:[__start] from __start::@1
|
||||
[5] return
|
||||
@ -482,25 +482,25 @@ Uplift Scope [fn2] 1.2: zp[1]:8 [ fn2::param_char ] 1: zp[1]:9 [ fn2::b#0 ] 1: z
|
||||
Uplift Scope [] 1.27: zp[1]:4 [ idx1 ] 1.27: zp[1]:5 [ idx2 ]
|
||||
Uplift Scope [__start]
|
||||
|
||||
Uplifting [main] best 9907 combination zp[2]:18 [ main::f#0 ] zp[1]:3 [ main::j#2 main::j#1 ] reg byte a [ main::$3 ] zp[1]:16 [ main::param_char ] zp[1]:2 [ main::i#2 main::i#1 ]
|
||||
Uplifting [fn1] best 9899 combination zp[1]:13 [ fn1::param_char ] reg byte y [ fn1::b#0 ] reg byte x [ fn1::c#0 ] zp[2]:11 [ fn1::ret_addr ]
|
||||
Uplifting [fn2] best 9891 combination zp[1]:8 [ fn2::param_char ] reg byte y [ fn2::b#0 ] reg byte x [ fn2::c#0 ] zp[2]:6 [ fn2::ret_addr ]
|
||||
Uplifting [] best 9891 combination zp[1]:4 [ idx1 ] zp[1]:5 [ idx2 ]
|
||||
Uplifting [__start] best 9891 combination
|
||||
Uplifting [main] best 9457 combination zp[2]:18 [ main::f#0 ] zp[1]:3 [ main::j#2 main::j#1 ] reg byte a [ main::$3 ] zp[1]:16 [ main::param_char ] zp[1]:2 [ main::i#2 main::i#1 ]
|
||||
Uplifting [fn1] best 9449 combination zp[1]:13 [ fn1::param_char ] reg byte y [ fn1::b#0 ] reg byte x [ fn1::c#0 ] zp[2]:11 [ fn1::ret_addr ]
|
||||
Uplifting [fn2] best 9441 combination zp[1]:8 [ fn2::param_char ] reg byte y [ fn2::b#0 ] reg byte x [ fn2::c#0 ] zp[2]:6 [ fn2::ret_addr ]
|
||||
Uplifting [] best 9441 combination zp[1]:4 [ idx1 ] zp[1]:5 [ idx2 ]
|
||||
Uplifting [__start] best 9441 combination
|
||||
Attempting to uplift remaining variables inzp[1]:3 [ main::j#2 main::j#1 ]
|
||||
Uplifting [main] best 9891 combination zp[1]:3 [ main::j#2 main::j#1 ]
|
||||
Uplifting [main] best 9441 combination zp[1]:3 [ main::j#2 main::j#1 ]
|
||||
Attempting to uplift remaining variables inzp[1]:16 [ main::param_char ]
|
||||
Uplifting [main] best 9891 combination zp[1]:16 [ main::param_char ]
|
||||
Uplifting [main] best 9441 combination zp[1]:16 [ main::param_char ]
|
||||
Attempting to uplift remaining variables inzp[1]:2 [ main::i#2 main::i#1 ]
|
||||
Uplifting [main] best 9891 combination zp[1]:2 [ main::i#2 main::i#1 ]
|
||||
Uplifting [main] best 9441 combination zp[1]:2 [ main::i#2 main::i#1 ]
|
||||
Attempting to uplift remaining variables inzp[1]:4 [ idx1 ]
|
||||
Uplifting [] best 9891 combination zp[1]:4 [ idx1 ]
|
||||
Uplifting [] best 9441 combination zp[1]:4 [ idx1 ]
|
||||
Attempting to uplift remaining variables inzp[1]:5 [ idx2 ]
|
||||
Uplifting [] best 9891 combination zp[1]:5 [ idx2 ]
|
||||
Uplifting [] best 9441 combination zp[1]:5 [ idx2 ]
|
||||
Attempting to uplift remaining variables inzp[1]:8 [ fn2::param_char ]
|
||||
Uplifting [fn2] best 9891 combination zp[1]:8 [ fn2::param_char ]
|
||||
Uplifting [fn2] best 9441 combination zp[1]:8 [ fn2::param_char ]
|
||||
Attempting to uplift remaining variables inzp[1]:13 [ fn1::param_char ]
|
||||
Uplifting [fn1] best 9891 combination zp[1]:13 [ fn1::param_char ]
|
||||
Uplifting [fn1] best 9441 combination zp[1]:13 [ fn1::param_char ]
|
||||
Allocated (was zp[2]:11) zp[2]:9 [ fn1::ret_addr ]
|
||||
Allocated (was zp[1]:13) zp[1]:11 [ fn1::param_char ]
|
||||
Allocated (was zp[1]:16) zp[1]:12 [ main::param_char ]
|
||||
@ -545,7 +545,7 @@ __start: {
|
||||
jmp __b1
|
||||
// __start::@1
|
||||
__b1:
|
||||
// [4] call main
|
||||
// [4] call main
|
||||
// [32] phi from __start::@1 to main [phi:__start::@1->main]
|
||||
main_from___b1:
|
||||
jsr main
|
||||
@ -727,8 +727,8 @@ main: {
|
||||
sta.z f
|
||||
lda fns+1,y
|
||||
sta.z f+1
|
||||
// [46] callexecute *main::f#0
|
||||
jsr bi_f
|
||||
// [46] callexecute *main::f#0 -- call__deref_pprz1
|
||||
jsr icall1
|
||||
jmp __b5
|
||||
// main::@5
|
||||
__b5:
|
||||
@ -738,7 +738,8 @@ main: {
|
||||
__b2_from___b5:
|
||||
// [36] phi main::j#2 = main::j#1 [phi:main::@5->main::@2#0] -- register_copy
|
||||
jmp __b2
|
||||
bi_f:
|
||||
// Outside Flow
|
||||
icall1:
|
||||
jmp (f)
|
||||
.segment Data
|
||||
fns: .word fn1, fn2
|
||||
@ -838,7 +839,7 @@ zp[2]:13 [ main::f#0 ]
|
||||
|
||||
|
||||
FINAL ASSEMBLER
|
||||
Score: 8075
|
||||
Score: 7625
|
||||
|
||||
// File Comments
|
||||
// Demonstrates work-around for passing parameters to function pointers
|
||||
@ -874,7 +875,7 @@ __start: {
|
||||
sta.z idx2
|
||||
// [3] phi from __start::__init1 to __start::@1 [phi:__start::__init1->__start::@1]
|
||||
// __start::@1
|
||||
// [4] call main
|
||||
// [4] call main
|
||||
// [32] phi from __start::@1 to main [phi:__start::@1->main]
|
||||
jsr main
|
||||
// __start::@return
|
||||
@ -1059,8 +1060,8 @@ main: {
|
||||
lda fns+1,y
|
||||
sta.z f+1
|
||||
// (*f)()
|
||||
// [46] callexecute *main::f#0
|
||||
jsr bi_f
|
||||
// [46] callexecute *main::f#0 -- call__deref_pprz1
|
||||
jsr icall1
|
||||
// main::@5
|
||||
// for(char j=0;j<2;j++)
|
||||
// [47] main::j#1 = ++ main::j#2 -- vbuz1=_inc_vbuz1
|
||||
@ -1068,7 +1069,8 @@ main: {
|
||||
// [36] phi from main::@5 to main::@2 [phi:main::@5->main::@2]
|
||||
// [36] phi main::j#2 = main::j#1 [phi:main::@5->main::@2#0] -- register_copy
|
||||
jmp __b2
|
||||
bi_f:
|
||||
// Outside Flow
|
||||
icall1:
|
||||
jmp (f)
|
||||
.segment Data
|
||||
fns: .word fn1, fn2
|
||||
|
@ -61,12 +61,12 @@ main: {
|
||||
__b3:
|
||||
// (*f)()
|
||||
pha
|
||||
jsr bi_f
|
||||
jsr icall1
|
||||
// char v = (*f)()
|
||||
pla
|
||||
// SCREEN[0] = v
|
||||
sta SCREEN
|
||||
jmp __b1
|
||||
bi_f:
|
||||
icall1:
|
||||
jmp (f)
|
||||
}
|
||||
|
@ -71,7 +71,7 @@ fn2::@return: scope:[fn2] from fn2
|
||||
|
||||
void __start()
|
||||
__start: scope:[__start] from
|
||||
call main
|
||||
call main
|
||||
to:__start::@1
|
||||
__start::@1: scope:[__start] from __start
|
||||
to:__start::@return
|
||||
@ -393,8 +393,8 @@ main: {
|
||||
__b3:
|
||||
// sideeffect stackpushbytes(1) -- _stackpushbyte_1
|
||||
pha
|
||||
// [16] callexecute *main::f#3
|
||||
jsr bi_f
|
||||
// [16] callexecute *main::f#3 -- call__deref_pprz1
|
||||
jsr icall1
|
||||
// [17] main::v#0 = stackpull(byte) -- vbuaa=_stackpullbyte_
|
||||
pla
|
||||
jmp __b4
|
||||
@ -406,7 +406,8 @@ main: {
|
||||
__b1_from___b4:
|
||||
// [9] phi main::i#2 = main::i#1 [phi:main::@4->main::@1#0] -- register_copy
|
||||
jmp __b1
|
||||
bi_f:
|
||||
// Outside Flow
|
||||
icall1:
|
||||
jmp (f)
|
||||
}
|
||||
// File Data
|
||||
@ -558,8 +559,8 @@ main: {
|
||||
// (*f)()
|
||||
// sideeffect stackpushbytes(1) -- _stackpushbyte_1
|
||||
pha
|
||||
// [16] callexecute *main::f#3
|
||||
jsr bi_f
|
||||
// [16] callexecute *main::f#3 -- call__deref_pprz1
|
||||
jsr icall1
|
||||
// char v = (*f)()
|
||||
// [17] main::v#0 = stackpull(byte) -- vbuaa=_stackpullbyte_
|
||||
pla
|
||||
@ -570,7 +571,8 @@ main: {
|
||||
// [9] phi from main::@4 to main::@1 [phi:main::@4->main::@1]
|
||||
// [9] phi main::i#2 = main::i#1 [phi:main::@4->main::@1#0] -- register_copy
|
||||
jmp __b1
|
||||
bi_f:
|
||||
// Outside Flow
|
||||
icall1:
|
||||
jmp (f)
|
||||
}
|
||||
// File Data
|
||||
|
@ -52,13 +52,13 @@ set_border: {
|
||||
.label fn = 2
|
||||
// fn()
|
||||
pha
|
||||
jsr bi_fn
|
||||
jsr icall1
|
||||
pla
|
||||
// *BORDER = fn()
|
||||
// Call pointer to a function without *
|
||||
sta BORDER
|
||||
// }
|
||||
rts
|
||||
bi_fn:
|
||||
icall1:
|
||||
jmp (fn)
|
||||
}
|
||||
|
@ -230,11 +230,11 @@ Uplift Scope [fn2]
|
||||
Uplift Scope [main]
|
||||
Uplift Scope []
|
||||
|
||||
Uplifting [set_border] best 200 combination reg byte a [ set_border::$0 ] zp[2]:2 [ set_border::fn#2 ]
|
||||
Uplifting [fn1] best 194 combination reg byte a [ fn1::return#0 ]
|
||||
Uplifting [fn2] best 194 combination
|
||||
Uplifting [main] best 194 combination
|
||||
Uplifting [] best 194 combination
|
||||
Uplifting [set_border] best 245 combination reg byte a [ set_border::$0 ] zp[2]:2 [ set_border::fn#2 ]
|
||||
Uplifting [fn1] best 239 combination reg byte a [ fn1::return#0 ]
|
||||
Uplifting [fn2] best 239 combination
|
||||
Uplifting [main] best 239 combination
|
||||
Uplifting [] best 239 combination
|
||||
|
||||
ASSEMBLER BEFORE OPTIMIZATION
|
||||
// File Comments
|
||||
@ -322,8 +322,8 @@ set_border: {
|
||||
.label fn = 2
|
||||
// sideeffect stackpushbytes(1) -- _stackpushbyte_1
|
||||
pha
|
||||
// [13] callexecute *set_border::fn#2
|
||||
jsr bi_fn
|
||||
// [13] callexecute *set_border::fn#2 -- call__deref_pprz1
|
||||
jsr icall1
|
||||
// [14] set_border::$0 = stackpull(byte) -- vbuaa=_stackpullbyte_
|
||||
pla
|
||||
jmp __b1
|
||||
@ -337,7 +337,8 @@ set_border: {
|
||||
__breturn:
|
||||
// [16] return
|
||||
rts
|
||||
bi_fn:
|
||||
// Outside Flow
|
||||
icall1:
|
||||
jmp (fn)
|
||||
}
|
||||
// File Data
|
||||
@ -388,7 +389,7 @@ reg byte a [ set_border::$0 ]
|
||||
|
||||
|
||||
FINAL ASSEMBLER
|
||||
Score: 95
|
||||
Score: 140
|
||||
|
||||
// File Comments
|
||||
// Calling a function pointer with return value
|
||||
@ -469,8 +470,8 @@ set_border: {
|
||||
// fn()
|
||||
// sideeffect stackpushbytes(1) -- _stackpushbyte_1
|
||||
pha
|
||||
// [13] callexecute *set_border::fn#2
|
||||
jsr bi_fn
|
||||
// [13] callexecute *set_border::fn#2 -- call__deref_pprz1
|
||||
jsr icall1
|
||||
// [14] set_border::$0 = stackpull(byte) -- vbuaa=_stackpullbyte_
|
||||
pla
|
||||
// set_border::@1
|
||||
@ -482,7 +483,8 @@ set_border: {
|
||||
// }
|
||||
// [16] return
|
||||
rts
|
||||
bi_fn:
|
||||
// Outside Flow
|
||||
icall1:
|
||||
jmp (fn)
|
||||
}
|
||||
// File Data
|
||||
|
@ -38,7 +38,7 @@ plus::@return: scope:[plus] from plus
|
||||
|
||||
void __start()
|
||||
__start: scope:[__start] from
|
||||
call main
|
||||
call main
|
||||
to:__start::@1
|
||||
__start::@1: scope:[__start] from __start
|
||||
to:__start::@return
|
||||
@ -231,7 +231,7 @@ main: {
|
||||
// [6] stackpush(byte) = 7 -- _stackpushbyte_=vbuc1
|
||||
lda #7
|
||||
pha
|
||||
// [7] callexecute plus -- jsr
|
||||
// [7] callexecute plus -- call_vprc1
|
||||
jsr plus
|
||||
// sideeffect stackpullbytes(1) -- _stackpullbyte_1
|
||||
pla
|
||||
@ -330,7 +330,7 @@ main: {
|
||||
// [6] stackpush(byte) = 7 -- _stackpushbyte_=vbuc1
|
||||
lda #7
|
||||
pha
|
||||
// [7] callexecute plus -- jsr
|
||||
// [7] callexecute plus -- call_vprc1
|
||||
jsr plus
|
||||
// sideeffect stackpullbytes(1) -- _stackpullbyte_1
|
||||
pla
|
||||
|
@ -38,7 +38,7 @@ plus::@return: scope:[plus] from plus
|
||||
|
||||
void __start()
|
||||
__start: scope:[__start] from
|
||||
call main
|
||||
call main
|
||||
to:__start::@1
|
||||
__start::@1: scope:[__start] from __start
|
||||
to:__start::@return
|
||||
@ -231,7 +231,7 @@ main: {
|
||||
// [6] stackpush(byte) = 7 -- _stackpushbyte_=vbuc1
|
||||
lda #7
|
||||
pha
|
||||
// [7] callexecute plus -- jsr
|
||||
// [7] callexecute plus -- call_vprc1
|
||||
jsr plus
|
||||
// sideeffect stackpullbytes(1) -- _stackpullbyte_1
|
||||
pla
|
||||
@ -330,7 +330,7 @@ main: {
|
||||
// [6] stackpush(byte) = 7 -- _stackpushbyte_=vbuc1
|
||||
lda #7
|
||||
pha
|
||||
// [7] callexecute plus -- jsr
|
||||
// [7] callexecute plus -- call_vprc1
|
||||
jsr plus
|
||||
// sideeffect stackpullbytes(1) -- _stackpullbyte_1
|
||||
pla
|
||||
|
@ -1,11 +1,11 @@
|
||||
Converting variable modified inside __stackcall procedure main() to load/store idx
|
||||
Adding parameter assignment in __stackcall procedure get::i = param(get::i)
|
||||
Adding parameter assignment in __stackcall procedure print::p = param(print::p)
|
||||
Inlined call call __init
|
||||
Inlined call call __init
|
||||
Eliminating unused variable with no statement main::$1
|
||||
Calling convention __stackcall adding prepare/execute/finalize for main::p = call get(main::i)
|
||||
Calling convention __stackcall adding prepare/execute/finalize for call print(main::p)
|
||||
Calling convention __stackcall adding prepare/execute/finalize for call main
|
||||
Calling convention __stackcall adding prepare/execute/finalize for call main
|
||||
Calling convention STACK_CALL replacing param(get::i) with stackidx(byte,get::OFFSET_STACK_I)
|
||||
Calling convention STACK_CALL replacing param(print::p) with stackidx(struct Point,print::OFFSET_STACK_P)
|
||||
Calling convention STACK_CALL adding stack return stackidx(struct Point,get::OFFSET_STACK_RETURN_0) = get::return
|
||||
@ -358,7 +358,7 @@ __start: {
|
||||
jmp __b1
|
||||
// __start::@1
|
||||
__b1:
|
||||
// [3] callexecute main -- jsr
|
||||
// [3] callexecute main -- call_vprc1
|
||||
jsr main
|
||||
jmp __breturn
|
||||
// __start::@return
|
||||
@ -460,7 +460,7 @@ main: {
|
||||
pha
|
||||
// sideeffect stackpushbytes(1) -- _stackpushbyte_1
|
||||
pha
|
||||
// [24] callexecute get -- jsr
|
||||
// [24] callexecute get -- call_vprc1
|
||||
jsr get
|
||||
// [25] main::p = stackpull(struct Point) -- vssz1=_stackpullstruct_2_
|
||||
pla
|
||||
@ -472,7 +472,7 @@ main: {
|
||||
pha
|
||||
lda.z p
|
||||
pha
|
||||
// [27] callexecute print -- jsr
|
||||
// [27] callexecute print -- call_vprc1
|
||||
jsr print
|
||||
// sideeffect stackpullbytes(2) -- _stackpullbyte_2
|
||||
pla
|
||||
@ -573,7 +573,7 @@ __start: {
|
||||
sta.z idx
|
||||
// [2] phi from __start::__init1 to __start::@1 [phi:__start::__init1->__start::@1]
|
||||
// __start::@1
|
||||
// [3] callexecute main -- jsr
|
||||
// [3] callexecute main -- call_vprc1
|
||||
jsr main
|
||||
// __start::@return
|
||||
// [4] return
|
||||
@ -677,7 +677,7 @@ main: {
|
||||
pha
|
||||
// sideeffect stackpushbytes(1) -- _stackpushbyte_1
|
||||
pha
|
||||
// [24] callexecute get -- jsr
|
||||
// [24] callexecute get -- call_vprc1
|
||||
jsr get
|
||||
// [25] main::p = stackpull(struct Point) -- vssz1=_stackpullstruct_2_
|
||||
pla
|
||||
@ -689,7 +689,7 @@ main: {
|
||||
pha
|
||||
lda.z p
|
||||
pha
|
||||
// [27] callexecute print -- jsr
|
||||
// [27] callexecute print -- call_vprc1
|
||||
jsr print
|
||||
// sideeffect stackpullbytes(2) -- _stackpullbyte_2
|
||||
pla
|
||||
|
@ -1,11 +1,11 @@
|
||||
Converting variable modified inside __stackcall procedure main() to load/store idx
|
||||
Adding parameter assignment in __stackcall procedure get::i = param(get::i)
|
||||
Adding parameter assignment in __stackcall procedure print::v = param(print::v)
|
||||
Inlined call call __init
|
||||
Inlined call call __init
|
||||
Eliminating unused variable with no statement main::$1
|
||||
Calling convention __stackcall adding prepare/execute/finalize for main::v = call get(main::i)
|
||||
Calling convention __stackcall adding prepare/execute/finalize for call print(main::v)
|
||||
Calling convention __stackcall adding prepare/execute/finalize for call main
|
||||
Calling convention __stackcall adding prepare/execute/finalize for call main
|
||||
Calling convention STACK_CALL replacing param(get::i) with stackidx(byte,get::OFFSET_STACK_I)
|
||||
Calling convention STACK_CALL replacing param(print::v) with stackidx(struct Vector,print::OFFSET_STACK_V)
|
||||
Calling convention STACK_CALL adding stack return stackidx(struct Vector,get::OFFSET_STACK_RETURN_0) = get::return
|
||||
@ -430,7 +430,7 @@ __start: {
|
||||
jmp __b1
|
||||
// __start::@1
|
||||
__b1:
|
||||
// [3] callexecute main -- jsr
|
||||
// [3] callexecute main -- call_vprc1
|
||||
jsr main
|
||||
jmp __breturn
|
||||
// __start::@return
|
||||
@ -577,7 +577,7 @@ main: {
|
||||
pha
|
||||
pha
|
||||
pha
|
||||
// [34] callexecute get -- jsr
|
||||
// [34] callexecute get -- call_vprc1
|
||||
jsr get
|
||||
// [35] main::v = stackpull(struct Vector) -- vssz1=_stackpullstruct_4_
|
||||
pla
|
||||
@ -597,7 +597,7 @@ main: {
|
||||
pha
|
||||
lda.z v
|
||||
pha
|
||||
// [37] callexecute print -- jsr
|
||||
// [37] callexecute print -- call_vprc1
|
||||
jsr print
|
||||
// sideeffect stackpullbytes(4) -- _stackpullbyte_4
|
||||
tsx
|
||||
@ -706,7 +706,7 @@ __start: {
|
||||
sta.z idx
|
||||
// [2] phi from __start::__init1 to __start::@1 [phi:__start::__init1->__start::@1]
|
||||
// __start::@1
|
||||
// [3] callexecute main -- jsr
|
||||
// [3] callexecute main -- call_vprc1
|
||||
jsr main
|
||||
// __start::@return
|
||||
// [4] return
|
||||
@ -863,7 +863,7 @@ main: {
|
||||
pha
|
||||
pha
|
||||
pha
|
||||
// [34] callexecute get -- jsr
|
||||
// [34] callexecute get -- call_vprc1
|
||||
jsr get
|
||||
// [35] main::v = stackpull(struct Vector) -- vssz1=_stackpullstruct_4_
|
||||
pla
|
||||
@ -883,7 +883,7 @@ main: {
|
||||
pha
|
||||
lda.z v
|
||||
pha
|
||||
// [37] callexecute print -- jsr
|
||||
// [37] callexecute print -- call_vprc1
|
||||
jsr print
|
||||
// sideeffect stackpullbytes(4) -- _stackpullbyte_4
|
||||
tsx
|
||||
|
@ -1,10 +1,10 @@
|
||||
Converting variable modified inside __stackcall procedure main() to load/store idx
|
||||
Adding parameter assignment in __stackcall procedure print::spacing = param(print::spacing)
|
||||
Adding parameter assignment in __stackcall procedure print::str = param(print::str)
|
||||
Inlined call call __init
|
||||
Inlined call call __init
|
||||
Calling convention __stackcall adding prepare/execute/finalize for call print(main::str, 1)
|
||||
Calling convention __stackcall adding prepare/execute/finalize for call print(main::str1, 2)
|
||||
Calling convention __stackcall adding prepare/execute/finalize for call main
|
||||
Calling convention __stackcall adding prepare/execute/finalize for call main
|
||||
Calling convention STACK_CALL replacing param(print::str) with stackidx(byte*,print::OFFSET_STACK_STR)
|
||||
Calling convention STACK_CALL replacing param(print::spacing) with stackidx(byte,print::OFFSET_STACK_SPACING)
|
||||
Calling convention STACK_CALL adding stack push stackpush(byte*) = main::str
|
||||
@ -337,7 +337,7 @@ __start: {
|
||||
jmp __b1
|
||||
// __start::@1
|
||||
__b1:
|
||||
// [3] callexecute main -- jsr
|
||||
// [3] callexecute main -- call_vprc1
|
||||
jsr main
|
||||
jmp __breturn
|
||||
// __start::@return
|
||||
@ -430,7 +430,7 @@ main: {
|
||||
// [19] stackpush(byte) = 1 -- _stackpushbyte_=vbuc1
|
||||
lda #1
|
||||
pha
|
||||
// [20] callexecute print -- jsr
|
||||
// [20] callexecute print -- call_vprc1
|
||||
jsr print
|
||||
// sideeffect stackpullbytes(3) -- _stackpullbyte_3
|
||||
tsx
|
||||
@ -446,7 +446,7 @@ main: {
|
||||
// [23] stackpush(byte) = 2 -- _stackpushbyte_=vbuc1
|
||||
lda #2
|
||||
pha
|
||||
// [24] callexecute print -- jsr
|
||||
// [24] callexecute print -- call_vprc1
|
||||
jsr print
|
||||
// sideeffect stackpullbytes(3) -- _stackpullbyte_3
|
||||
tsx
|
||||
@ -545,7 +545,7 @@ __start: {
|
||||
sta.z idx
|
||||
// [2] phi from __start::__init1 to __start::@1 [phi:__start::__init1->__start::@1]
|
||||
// __start::@1
|
||||
// [3] callexecute main -- jsr
|
||||
// [3] callexecute main -- call_vprc1
|
||||
jsr main
|
||||
// __start::@return
|
||||
// [4] return
|
||||
@ -637,7 +637,7 @@ main: {
|
||||
// [19] stackpush(byte) = 1 -- _stackpushbyte_=vbuc1
|
||||
lda #1
|
||||
pha
|
||||
// [20] callexecute print -- jsr
|
||||
// [20] callexecute print -- call_vprc1
|
||||
jsr print
|
||||
// sideeffect stackpullbytes(3) -- _stackpullbyte_3
|
||||
tsx
|
||||
@ -654,7 +654,7 @@ main: {
|
||||
// [23] stackpush(byte) = 2 -- _stackpushbyte_=vbuc1
|
||||
lda #2
|
||||
pha
|
||||
// [24] callexecute print -- jsr
|
||||
// [24] callexecute print -- call_vprc1
|
||||
jsr print
|
||||
// sideeffect stackpullbytes(3) -- _stackpullbyte_3
|
||||
tsx
|
||||
|
@ -48,7 +48,7 @@ pow2::@return: scope:[pow2] from pow2::@1 pow2::@2
|
||||
|
||||
void __start()
|
||||
__start: scope:[__start] from
|
||||
call main
|
||||
call main
|
||||
to:__start::@1
|
||||
__start::@1: scope:[__start] from __start
|
||||
to:__start::@return
|
||||
@ -246,7 +246,7 @@ pow2: {
|
||||
sbc #1
|
||||
// [3] stackpush(byte) = pow2::$1 -- _stackpushbyte_=vbuaa
|
||||
pha
|
||||
// [4] callexecute pow2 -- jsr
|
||||
// [4] callexecute pow2 -- call_vprc1
|
||||
jsr pow2
|
||||
// [5] pow2::c#0 = stackpull(byte) -- vbuaa=_stackpullbyte_
|
||||
pla
|
||||
@ -274,7 +274,7 @@ main: {
|
||||
// [10] stackpush(byte) = 6 -- _stackpushbyte_=vbuc1
|
||||
lda #6
|
||||
pha
|
||||
// [11] callexecute pow2 -- jsr
|
||||
// [11] callexecute pow2 -- call_vprc1
|
||||
jsr pow2
|
||||
// [12] main::$0 = stackpull(byte) -- vbuaa=_stackpullbyte_
|
||||
pla
|
||||
@ -363,7 +363,7 @@ pow2: {
|
||||
// char c = pow2(n-1)
|
||||
// [3] stackpush(byte) = pow2::$1 -- _stackpushbyte_=vbuaa
|
||||
pha
|
||||
// [4] callexecute pow2 -- jsr
|
||||
// [4] callexecute pow2 -- call_vprc1
|
||||
jsr pow2
|
||||
// [5] pow2::c#0 = stackpull(byte) -- vbuaa=_stackpullbyte_
|
||||
pla
|
||||
@ -392,7 +392,7 @@ main: {
|
||||
// [10] stackpush(byte) = 6 -- _stackpushbyte_=vbuc1
|
||||
lda #6
|
||||
pha
|
||||
// [11] callexecute pow2 -- jsr
|
||||
// [11] callexecute pow2 -- call_vprc1
|
||||
jsr pow2
|
||||
// [12] main::$0 = stackpull(byte) -- vbuaa=_stackpullbyte_
|
||||
pla
|
||||
|
@ -39,7 +39,7 @@ plus::@return: scope:[plus] from plus
|
||||
|
||||
void __start()
|
||||
__start: scope:[__start] from
|
||||
call main
|
||||
call main
|
||||
to:__start::@1
|
||||
__start::@1: scope:[__start] from __start
|
||||
to:__start::@return
|
||||
@ -262,7 +262,7 @@ main: {
|
||||
pha
|
||||
lda #<$2345
|
||||
pha
|
||||
// [7] callexecute plus -- jsr
|
||||
// [7] callexecute plus -- call_vprc1
|
||||
jsr plus
|
||||
// sideeffect stackpullbytes(2) -- _stackpullbyte_2
|
||||
pla
|
||||
@ -386,7 +386,7 @@ main: {
|
||||
pha
|
||||
lda #<$2345
|
||||
pha
|
||||
// [7] callexecute plus -- jsr
|
||||
// [7] callexecute plus -- call_vprc1
|
||||
jsr plus
|
||||
// sideeffect stackpullbytes(2) -- _stackpullbyte_2
|
||||
pla
|
||||
|
@ -39,7 +39,7 @@ plus::@return: scope:[plus] from plus
|
||||
|
||||
void __start()
|
||||
__start: scope:[__start] from
|
||||
call main
|
||||
call main
|
||||
to:__start::@1
|
||||
__start::@1: scope:[__start] from __start
|
||||
to:__start::@return
|
||||
@ -261,7 +261,7 @@ main: {
|
||||
pha
|
||||
lda #<7
|
||||
pha
|
||||
// [7] callexecute plus -- jsr
|
||||
// [7] callexecute plus -- call_vprc1
|
||||
jsr plus
|
||||
// sideeffect stackpullbytes(2) -- _stackpullbyte_2
|
||||
pla
|
||||
@ -388,7 +388,7 @@ main: {
|
||||
pha
|
||||
lda #<7
|
||||
pha
|
||||
// [7] callexecute plus -- jsr
|
||||
// [7] callexecute plus -- call_vprc1
|
||||
jsr plus
|
||||
// sideeffect stackpullbytes(2) -- _stackpullbyte_2
|
||||
pla
|
||||
|
@ -1,7 +1,7 @@
|
||||
Converting variable modified inside __stackcall procedure plus() to load/store i
|
||||
Adding parameter assignment in __stackcall procedure plus::b = param(plus::b)
|
||||
Adding parameter assignment in __stackcall procedure plus::a = param(plus::a)
|
||||
Inlined call call __init
|
||||
Inlined call call __init
|
||||
Eliminating unused variable with no statement main::$0
|
||||
Eliminating unused variable with no statement main::$1
|
||||
Calling convention __stackcall adding prepare/execute/finalize for main::w = call plus('0', main::v)
|
||||
@ -57,7 +57,7 @@ __start::__init1: scope:[__start] from __start
|
||||
i = 0
|
||||
to:__start::@1
|
||||
__start::@1: scope:[__start] from __start::__init1
|
||||
call main
|
||||
call main
|
||||
to:__start::@2
|
||||
__start::@2: scope:[__start] from __start::@1
|
||||
to:__start::@return
|
||||
@ -149,7 +149,7 @@ __start::__init1: scope:[__start] from __start
|
||||
to:__start::@1
|
||||
__start::@1: scope:[__start] from __start::__init1
|
||||
[2] phi()
|
||||
[3] call main
|
||||
[3] call main
|
||||
to:__start::@return
|
||||
__start::@return: scope:[__start] from __start::@1
|
||||
[4] return
|
||||
@ -324,7 +324,7 @@ __start: {
|
||||
jmp __b1
|
||||
// __start::@1
|
||||
__b1:
|
||||
// [3] call main
|
||||
// [3] call main
|
||||
// [11] phi from __start::@1 to main [phi:__start::@1->main]
|
||||
main_from___b1:
|
||||
jsr main
|
||||
@ -386,7 +386,7 @@ main: {
|
||||
// [15] stackpush(byte) = main::v#0 -- _stackpushbyte_=vbuxx
|
||||
txa
|
||||
pha
|
||||
// [16] callexecute plus -- jsr
|
||||
// [16] callexecute plus -- call_vprc1
|
||||
jsr plus
|
||||
// sideeffect stackpullbytes(1) -- _stackpullbyte_1
|
||||
pla
|
||||
@ -499,7 +499,7 @@ __start: {
|
||||
sta.z i
|
||||
// [2] phi from __start::__init1 to __start::@1 [phi:__start::__init1->__start::@1]
|
||||
// __start::@1
|
||||
// [3] call main
|
||||
// [3] call main
|
||||
// [11] phi from __start::@1 to main [phi:__start::@1->main]
|
||||
jsr main
|
||||
// __start::@return
|
||||
@ -557,7 +557,7 @@ main: {
|
||||
// [15] stackpush(byte) = main::v#0 -- _stackpushbyte_=vbuxx
|
||||
txa
|
||||
pha
|
||||
// [16] callexecute plus -- jsr
|
||||
// [16] callexecute plus -- call_vprc1
|
||||
jsr plus
|
||||
// sideeffect stackpullbytes(1) -- _stackpullbyte_1
|
||||
pla
|
||||
|
@ -1,7 +1,7 @@
|
||||
Converting variable modified inside __stackcall procedure next() to load/store current
|
||||
Inlined call call __init
|
||||
Calling convention __stackcall adding prepare/execute/finalize for main::$0 = call next
|
||||
Calling convention __stackcall adding prepare/execute/finalize for main::$1 = call next
|
||||
Inlined call call __init
|
||||
Calling convention __stackcall adding prepare/execute/finalize for main::$0 = call next
|
||||
Calling convention __stackcall adding prepare/execute/finalize for main::$1 = call next
|
||||
Calling convention STACK_CALL adding stack return stackidx(signed word,next::OFFSET_STACK_RETURN_0) = next::return
|
||||
Calling convention STACK_CALL adding stack pull main::$0 = stackpull(signed word)
|
||||
Calling convention STACK_CALL adding stack pull main::$1 = stackpull(signed word)
|
||||
@ -43,7 +43,7 @@ __start::__init1: scope:[__start] from __start
|
||||
current = $30
|
||||
to:__start::@1
|
||||
__start::@1: scope:[__start] from __start::__init1
|
||||
call main
|
||||
call main
|
||||
to:__start::@2
|
||||
__start::@2: scope:[__start] from __start::@1
|
||||
to:__start::@return
|
||||
@ -127,7 +127,7 @@ __start::__init1: scope:[__start] from __start
|
||||
to:__start::@1
|
||||
__start::@1: scope:[__start] from __start::__init1
|
||||
[2] phi()
|
||||
[3] call main
|
||||
[3] call main
|
||||
to:__start::@return
|
||||
__start::@return: scope:[__start] from __start::@1
|
||||
[4] return
|
||||
@ -245,7 +245,7 @@ __start: {
|
||||
jmp __b1
|
||||
// __start::@1
|
||||
__b1:
|
||||
// [3] call main
|
||||
// [3] call main
|
||||
jsr main
|
||||
jmp __breturn
|
||||
// __start::@return
|
||||
@ -286,7 +286,7 @@ main: {
|
||||
// sideeffect stackpushbytes(2) -- _stackpushbyte_2
|
||||
pha
|
||||
pha
|
||||
// [10] callexecute next -- jsr
|
||||
// [10] callexecute next -- call_vprc1
|
||||
jsr next
|
||||
// [11] main::$0 = stackpull(signed word) -- vwsz1=_stackpullsword_
|
||||
pla
|
||||
@ -301,7 +301,7 @@ main: {
|
||||
// sideeffect stackpushbytes(2) -- _stackpushbyte_2
|
||||
pha
|
||||
pha
|
||||
// [14] callexecute next -- jsr
|
||||
// [14] callexecute next -- call_vprc1
|
||||
jsr next
|
||||
// [15] main::$1 = stackpull(signed word) -- vwsz1=_stackpullsword_
|
||||
pla
|
||||
@ -387,7 +387,7 @@ __start: {
|
||||
sta.z current+1
|
||||
// [2] phi from __start::__init1 to __start::@1 [phi:__start::__init1->__start::@1]
|
||||
// __start::@1
|
||||
// [3] call main
|
||||
// [3] call main
|
||||
jsr main
|
||||
// __start::@return
|
||||
// [4] return
|
||||
@ -427,7 +427,7 @@ main: {
|
||||
// sideeffect stackpushbytes(2) -- _stackpushbyte_2
|
||||
pha
|
||||
pha
|
||||
// [10] callexecute next -- jsr
|
||||
// [10] callexecute next -- call_vprc1
|
||||
jsr next
|
||||
// [11] main::$0 = stackpull(signed word) -- vwsz1=_stackpullsword_
|
||||
pla
|
||||
@ -444,7 +444,7 @@ main: {
|
||||
// sideeffect stackpushbytes(2) -- _stackpushbyte_2
|
||||
pha
|
||||
pha
|
||||
// [14] callexecute next -- jsr
|
||||
// [14] callexecute next -- call_vprc1
|
||||
jsr next
|
||||
// [15] main::$1 = stackpull(signed word) -- vwsz1=_stackpullsword_
|
||||
pla
|
||||
|
@ -1,5 +1,5 @@
|
||||
Calling convention __stackcall adding prepare/execute/finalize for call printline
|
||||
Calling convention __stackcall adding prepare/execute/finalize for call main
|
||||
Calling convention __stackcall adding prepare/execute/finalize for call printline
|
||||
Calling convention __stackcall adding prepare/execute/finalize for call main
|
||||
|
||||
CONTROL FLOW GRAPH SSA
|
||||
|
||||
@ -184,7 +184,7 @@ ASSEMBLER BEFORE OPTIMIZATION
|
||||
.segment Code
|
||||
// __start
|
||||
__start: {
|
||||
// [1] callexecute main -- jsr
|
||||
// [1] callexecute main -- call_vprc1
|
||||
jsr main
|
||||
jmp __breturn
|
||||
// __start::@return
|
||||
@ -225,7 +225,7 @@ printline: {
|
||||
main: {
|
||||
// [9] main::val#1 = *SCREEN -- vbuyy=_deref_pbuc1
|
||||
ldy SCREEN
|
||||
// [10] callexecute printline -- jsr
|
||||
// [10] callexecute printline -- call_vprc1
|
||||
jsr printline
|
||||
// [11] *(SCREEN+$50) = main::val#1 -- _deref_pbuc1=vbuyy
|
||||
sty SCREEN+$50
|
||||
@ -285,7 +285,7 @@ Score: 223
|
||||
.segment Code
|
||||
// __start
|
||||
__start: {
|
||||
// [1] callexecute main -- jsr
|
||||
// [1] callexecute main -- call_vprc1
|
||||
jsr main
|
||||
// __start::@return
|
||||
// [2] return
|
||||
@ -325,7 +325,7 @@ main: {
|
||||
// [9] main::val#1 = *SCREEN -- vbuyy=_deref_pbuc1
|
||||
ldy SCREEN
|
||||
// printline()
|
||||
// [10] callexecute printline -- jsr
|
||||
// [10] callexecute printline -- call_vprc1
|
||||
jsr printline
|
||||
// SCREEN[80] = val
|
||||
// [11] *(SCREEN+$50) = main::val#1 -- _deref_pbuc1=vbuyy
|
||||
|
@ -1,7 +1,7 @@
|
||||
Converting variable modified inside __stackcall procedure main() to load/store val
|
||||
Inlined call call __init
|
||||
Calling convention __stackcall adding prepare/execute/finalize for call printline
|
||||
Calling convention __stackcall adding prepare/execute/finalize for call main
|
||||
Inlined call call __init
|
||||
Calling convention __stackcall adding prepare/execute/finalize for call printline
|
||||
Calling convention __stackcall adding prepare/execute/finalize for call main
|
||||
|
||||
CONTROL FLOW GRAPH SSA
|
||||
|
||||
@ -212,7 +212,7 @@ __start: {
|
||||
jmp __b1
|
||||
// __start::@1
|
||||
__b1:
|
||||
// [3] callexecute main -- jsr
|
||||
// [3] callexecute main -- call_vprc1
|
||||
jsr main
|
||||
jmp __breturn
|
||||
// __start::@return
|
||||
@ -254,7 +254,7 @@ main: {
|
||||
// [11] val = '-' -- vbuz1=vbuc1
|
||||
lda #'-'
|
||||
sta.z val
|
||||
// [12] callexecute printline -- jsr
|
||||
// [12] callexecute printline -- call_vprc1
|
||||
jsr printline
|
||||
// [13] *(SCREEN+$50) = val -- _deref_pbuc1=vbuz1
|
||||
lda.z val
|
||||
@ -328,7 +328,7 @@ __start: {
|
||||
sta.z val
|
||||
// [2] phi from __start::__init1 to __start::@1 [phi:__start::__init1->__start::@1]
|
||||
// __start::@1
|
||||
// [3] callexecute main -- jsr
|
||||
// [3] callexecute main -- call_vprc1
|
||||
jsr main
|
||||
// __start::@return
|
||||
// [4] return
|
||||
@ -369,7 +369,7 @@ main: {
|
||||
lda #'-'
|
||||
sta.z val
|
||||
// printline()
|
||||
// [12] callexecute printline -- jsr
|
||||
// [12] callexecute printline -- call_vprc1
|
||||
jsr printline
|
||||
// SCREEN[80] = val
|
||||
// [13] *(SCREEN+$50) = val -- _deref_pbuc1=vbuz1
|
||||
|
@ -1,11 +1,11 @@
|
||||
Converting variable modified inside __stackcall procedure main() to load/store val
|
||||
Inlined call call __init
|
||||
Calling convention __stackcall adding prepare/execute/finalize for call pval
|
||||
Calling convention __stackcall adding prepare/execute/finalize for call printother
|
||||
Calling convention __stackcall adding prepare/execute/finalize for call ival
|
||||
Calling convention __stackcall adding prepare/execute/finalize for call printval
|
||||
Calling convention __stackcall adding prepare/execute/finalize for call incval
|
||||
Calling convention __stackcall adding prepare/execute/finalize for call main
|
||||
Inlined call call __init
|
||||
Calling convention __stackcall adding prepare/execute/finalize for call pval
|
||||
Calling convention __stackcall adding prepare/execute/finalize for call printother
|
||||
Calling convention __stackcall adding prepare/execute/finalize for call ival
|
||||
Calling convention __stackcall adding prepare/execute/finalize for call printval
|
||||
Calling convention __stackcall adding prepare/execute/finalize for call incval
|
||||
Calling convention __stackcall adding prepare/execute/finalize for call main
|
||||
|
||||
CONTROL FLOW GRAPH SSA
|
||||
|
||||
@ -346,7 +346,7 @@ __start: {
|
||||
jmp __b1
|
||||
// __start::@1
|
||||
__b1:
|
||||
// [3] callexecute main -- jsr
|
||||
// [3] callexecute main -- call_vprc1
|
||||
jsr main
|
||||
jmp __breturn
|
||||
// __start::@return
|
||||
@ -403,7 +403,7 @@ printval: {
|
||||
}
|
||||
// ival
|
||||
ival: {
|
||||
// [16] callexecute incval -- jsr
|
||||
// [16] callexecute incval -- call_vprc1
|
||||
jsr incval
|
||||
jmp __breturn
|
||||
// ival::@return
|
||||
@ -413,7 +413,7 @@ ival: {
|
||||
}
|
||||
// pval
|
||||
pval: {
|
||||
// [19] callexecute printval -- jsr
|
||||
// [19] callexecute printval -- call_vprc1
|
||||
jsr printval
|
||||
jmp __breturn
|
||||
// pval::@return
|
||||
@ -434,11 +434,11 @@ main: {
|
||||
jmp __b1
|
||||
// main::@1
|
||||
__b1:
|
||||
// [23] callexecute pval -- jsr
|
||||
// [23] callexecute pval -- call_vprc1
|
||||
jsr pval
|
||||
// [24] callexecute printother -- jsr
|
||||
// [24] callexecute printother -- call_vprc1
|
||||
jsr printother
|
||||
// [25] callexecute ival -- jsr
|
||||
// [25] callexecute ival -- call_vprc1
|
||||
jsr ival
|
||||
// [26] main::i#1 = ++ main::i#2 -- vbuyy=_inc_vbuyy
|
||||
iny
|
||||
@ -538,7 +538,7 @@ __start: {
|
||||
sta.z val
|
||||
// [2] phi from __start::__init1 to __start::@1 [phi:__start::__init1->__start::@1]
|
||||
// __start::@1
|
||||
// [3] callexecute main -- jsr
|
||||
// [3] callexecute main -- call_vprc1
|
||||
jsr main
|
||||
// __start::@return
|
||||
// [4] return
|
||||
@ -591,7 +591,7 @@ printval: {
|
||||
// ival
|
||||
ival: {
|
||||
// incval()
|
||||
// [16] callexecute incval -- jsr
|
||||
// [16] callexecute incval -- call_vprc1
|
||||
jsr incval
|
||||
// ival::@return
|
||||
// }
|
||||
@ -601,7 +601,7 @@ ival: {
|
||||
// pval
|
||||
pval: {
|
||||
// printval()
|
||||
// [19] callexecute printval -- jsr
|
||||
// [19] callexecute printval -- call_vprc1
|
||||
jsr printval
|
||||
// pval::@return
|
||||
// }
|
||||
@ -618,13 +618,13 @@ main: {
|
||||
// main::@1
|
||||
__b1:
|
||||
// pval()
|
||||
// [23] callexecute pval -- jsr
|
||||
// [23] callexecute pval -- call_vprc1
|
||||
jsr pval
|
||||
// printother()
|
||||
// [24] callexecute printother -- jsr
|
||||
// [24] callexecute printother -- call_vprc1
|
||||
jsr printother
|
||||
// ival()
|
||||
// [25] callexecute ival -- jsr
|
||||
// [25] callexecute ival -- call_vprc1
|
||||
jsr ival
|
||||
// for(char i:0..5)
|
||||
// [26] main::i#1 = ++ main::i#2 -- vbuyy=_inc_vbuyy
|
||||
|
@ -1,4 +1,4 @@
|
||||
Inlined call call __init
|
||||
Inlined call call __init
|
||||
Calling convention STACK_CALL adding prepare/execute/finalize for call *proc_ptr
|
||||
Calling convention STACK_CALL adding prepare/execute/finalize for call *proc_ptr
|
||||
|
||||
@ -43,7 +43,7 @@ __start::__init1: scope:[__start] from __start
|
||||
to:__start::@1
|
||||
__start::@1: scope:[__start] from __start::__init1
|
||||
proc_ptr#9 = phi( __start::__init1/proc_ptr#3 )
|
||||
call main
|
||||
call main
|
||||
to:__start::@2
|
||||
__start::@2: scope:[__start] from __start::@1
|
||||
proc_ptr#7 = phi( __start::@1/proc_ptr#2 )
|
||||
@ -193,14 +193,14 @@ ASSEMBLER BEFORE OPTIMIZATION
|
||||
.segment Code
|
||||
// main
|
||||
main: {
|
||||
// [1] callexecute proc1 -- jsr
|
||||
// [1] callexecute proc1 -- call_vprc1
|
||||
jsr proc1
|
||||
// [2] phi from main to main::@1 [phi:main->main::@1]
|
||||
__b1_from_main:
|
||||
jmp __b1
|
||||
// main::@1
|
||||
__b1:
|
||||
// [3] callexecute proc2 -- jsr
|
||||
// [3] callexecute proc2 -- call_vprc1
|
||||
jsr proc2
|
||||
jmp __breturn
|
||||
// main::@return
|
||||
@ -275,12 +275,12 @@ Score: 42
|
||||
// main
|
||||
main: {
|
||||
// (*proc_ptr)()
|
||||
// [1] callexecute proc1 -- jsr
|
||||
// [1] callexecute proc1 -- call_vprc1
|
||||
jsr proc1
|
||||
// [2] phi from main to main::@1 [phi:main->main::@1]
|
||||
// main::@1
|
||||
// (*proc_ptr)()
|
||||
// [3] callexecute proc2 -- jsr
|
||||
// [3] callexecute proc2 -- call_vprc1
|
||||
jsr proc2
|
||||
// main::@return
|
||||
// }
|
||||
|
@ -25,7 +25,7 @@ setbg::@return: scope:[setbg] from setbg
|
||||
|
||||
void __start()
|
||||
__start: scope:[__start] from
|
||||
call main
|
||||
call main
|
||||
to:__start::@1
|
||||
__start::@1: scope:[__start] from __start
|
||||
to:__start::@return
|
||||
@ -147,12 +147,12 @@ main: {
|
||||
// [2] setbg::col = 0 -- vbuz1=vbuc1
|
||||
lda #0
|
||||
sta.z setbg.col
|
||||
// [3] callexecute setbg -- jsr
|
||||
// [3] callexecute setbg -- call_vprc1
|
||||
jsr setbg
|
||||
// [4] setbg::col = $b -- vbuz1=vbuc1
|
||||
lda #$b
|
||||
sta.z setbg.col
|
||||
// [5] callexecute setbg -- jsr
|
||||
// [5] callexecute setbg -- call_vprc1
|
||||
jsr setbg
|
||||
jmp __breturn
|
||||
// main::@return
|
||||
@ -216,13 +216,13 @@ main: {
|
||||
// [2] setbg::col = 0 -- vbuz1=vbuc1
|
||||
lda #0
|
||||
sta.z setbg.col
|
||||
// [3] callexecute setbg -- jsr
|
||||
// [3] callexecute setbg -- call_vprc1
|
||||
jsr setbg
|
||||
// setbg(0x0b)
|
||||
// [4] setbg::col = $b -- vbuz1=vbuc1
|
||||
lda #$b
|
||||
sta.z setbg.col
|
||||
// [5] callexecute setbg -- jsr
|
||||
// [5] callexecute setbg -- call_vprc1
|
||||
jsr setbg
|
||||
// main::@return
|
||||
// }
|
||||
|
@ -40,7 +40,7 @@ plus::@return: scope:[plus] from plus
|
||||
|
||||
void __start()
|
||||
__start: scope:[__start] from
|
||||
call main
|
||||
call main
|
||||
to:__start::@1
|
||||
__start::@1: scope:[__start] from __start
|
||||
to:__start::@return
|
||||
@ -234,7 +234,7 @@ main: {
|
||||
// [5] plus::b = 1 -- vbuz1=vbuc1
|
||||
lda #1
|
||||
sta.z plus.b
|
||||
// [6] callexecute plus -- jsr
|
||||
// [6] callexecute plus -- call_vprc1
|
||||
jsr plus
|
||||
// [7] main::a#1 = plus::return -- vbuaa=vbuz1
|
||||
lda.z plus.return
|
||||
@ -244,7 +244,7 @@ main: {
|
||||
sta.z plus.a
|
||||
// [10] plus::b = main::a#1 -- vbuz1=vbuaa
|
||||
sta.z plus.b
|
||||
// [11] callexecute plus -- jsr
|
||||
// [11] callexecute plus -- call_vprc1
|
||||
jsr plus
|
||||
// [12] main::a#2 = plus::return -- vbuaa=vbuz1
|
||||
lda.z plus.return
|
||||
@ -337,7 +337,7 @@ main: {
|
||||
sta.z plus.a
|
||||
// [5] plus::b = 1 -- vbuz1=vbuc1
|
||||
sta.z plus.b
|
||||
// [6] callexecute plus -- jsr
|
||||
// [6] callexecute plus -- call_vprc1
|
||||
jsr plus
|
||||
// a = plus(a, 1)
|
||||
// [7] main::a#1 = plus::return -- vbuaa=vbuz1
|
||||
@ -350,7 +350,7 @@ main: {
|
||||
sta.z plus.a
|
||||
// [10] plus::b = main::a#1 -- vbuz1=vbuaa
|
||||
sta.z plus.b
|
||||
// [11] callexecute plus -- jsr
|
||||
// [11] callexecute plus -- call_vprc1
|
||||
jsr plus
|
||||
// a = plus(a, a)
|
||||
// [12] main::a#2 = plus::return -- vbuaa=vbuz1
|
||||
|
@ -40,7 +40,7 @@ plus::@return: scope:[plus] from plus
|
||||
|
||||
void __start()
|
||||
__start: scope:[__start] from
|
||||
call main
|
||||
call main
|
||||
to:__start::@1
|
||||
__start::@1: scope:[__start] from __start
|
||||
to:__start::@return
|
||||
@ -249,7 +249,7 @@ main: {
|
||||
sta.z plus.b
|
||||
lda #>$203
|
||||
sta.z plus.b+1
|
||||
// [6] callexecute plus -- jsr
|
||||
// [6] callexecute plus -- call_vprc1
|
||||
jsr plus
|
||||
// [7] main::a#1 = plus::return -- vwsz1=vwsz2
|
||||
lda.z plus.return
|
||||
@ -267,7 +267,7 @@ main: {
|
||||
lda.z a+1
|
||||
sta.z plus.a+1
|
||||
// [10] plus::b = main::a#1
|
||||
// [11] callexecute plus -- jsr
|
||||
// [11] callexecute plus -- call_vprc1
|
||||
jsr plus
|
||||
// [12] main::a#2 = plus::return
|
||||
// [13] *BGCOL = main::a#2 -- _deref_pwsc1=vwsz1
|
||||
@ -369,7 +369,7 @@ main: {
|
||||
sta.z plus.b
|
||||
lda #>$203
|
||||
sta.z plus.b+1
|
||||
// [6] callexecute plus -- jsr
|
||||
// [6] callexecute plus -- call_vprc1
|
||||
jsr plus
|
||||
// a = plus(a, 0x0203)
|
||||
// [7] main::a#1 = plus::return -- vwsz1=vwsz2
|
||||
@ -390,7 +390,7 @@ main: {
|
||||
lda.z a+1
|
||||
sta.z plus.a+1
|
||||
// [10] plus::b = main::a#1
|
||||
// [11] callexecute plus -- jsr
|
||||
// [11] callexecute plus -- call_vprc1
|
||||
jsr plus
|
||||
// a = plus(a, a)
|
||||
// [12] main::a#2 = plus::return
|
||||
|
@ -50,7 +50,7 @@ fg_sum::@return: scope:[fg_sum] from fg_sum
|
||||
|
||||
void __start()
|
||||
__start: scope:[__start] from
|
||||
call main
|
||||
call main
|
||||
to:__start::@1
|
||||
__start::@1: scope:[__start] from __start
|
||||
to:__start::@return
|
||||
@ -333,7 +333,7 @@ main: {
|
||||
// [8] fg_sum::b_fg = *((byte*)&b+OFFSET_STRUCT_COLS_FG) -- vbuz1=_deref_pbuc1
|
||||
lda b+OFFSET_STRUCT_COLS_FG
|
||||
sta.z fg_sum.b_fg
|
||||
// [9] callexecute fg_sum -- jsr
|
||||
// [9] callexecute fg_sum -- call_vprc1
|
||||
jsr fg_sum
|
||||
// [10] main::sum1#0 = fg_sum::return -- vbuaa=vbuz1
|
||||
lda.z fg_sum.return
|
||||
@ -364,7 +364,7 @@ main: {
|
||||
// [18] fg_sum::b_fg = *((byte*)&d+OFFSET_STRUCT_COLS_FG) -- vbuz1=_deref_pbuc1
|
||||
lda d+OFFSET_STRUCT_COLS_FG
|
||||
sta.z fg_sum.b_fg
|
||||
// [19] callexecute fg_sum -- jsr
|
||||
// [19] callexecute fg_sum -- call_vprc1
|
||||
jsr fg_sum
|
||||
// [20] main::sum2#0 = fg_sum::return -- vbuaa=vbuz1
|
||||
lda.z fg_sum.return
|
||||
@ -496,7 +496,7 @@ main: {
|
||||
// [8] fg_sum::b_fg = *((byte*)&b+OFFSET_STRUCT_COLS_FG) -- vbuz1=_deref_pbuc1
|
||||
lda b+OFFSET_STRUCT_COLS_FG
|
||||
sta.z fg_sum.b_fg
|
||||
// [9] callexecute fg_sum -- jsr
|
||||
// [9] callexecute fg_sum -- call_vprc1
|
||||
jsr fg_sum
|
||||
// [10] main::sum1#0 = fg_sum::return -- vbuaa=vbuz1
|
||||
lda.z fg_sum.return
|
||||
@ -530,7 +530,7 @@ main: {
|
||||
// [18] fg_sum::b_fg = *((byte*)&d+OFFSET_STRUCT_COLS_FG) -- vbuz1=_deref_pbuc1
|
||||
lda d+OFFSET_STRUCT_COLS_FG
|
||||
sta.z fg_sum.b_fg
|
||||
// [19] callexecute fg_sum -- jsr
|
||||
// [19] callexecute fg_sum -- call_vprc1
|
||||
jsr fg_sum
|
||||
// [20] main::sum2#0 = fg_sum::return -- vbuaa=vbuz1
|
||||
lda.z fg_sum.return
|
||||
|
Loading…
x
Reference in New Issue
Block a user