mirror of
https://gitlab.com/camelot/kickc.git
synced 2025-01-12 11:31:11 +00:00
Introduces void-pointer synthesis. This enables removal of a lot of pointer fragments. #449
This commit is contained in:
parent
74d83caaf9
commit
08d90f90d9
@ -1,6 +0,0 @@
|
||||
ldy #0
|
||||
lda {m2}
|
||||
sta ({z1}),y
|
||||
iny
|
||||
lda {m2}+1
|
||||
sta ({z1}),y
|
@ -1 +0,0 @@
|
||||
// No operation needed
|
@ -1,4 +0,0 @@
|
||||
lda {m2}
|
||||
sta {m1}
|
||||
lda {m2}+1
|
||||
sta {m1}+1
|
@ -1,5 +0,0 @@
|
||||
tsx
|
||||
lda STACK_BASE+{c1},x
|
||||
sta {m1}
|
||||
lda STACK_BASE+{c1}+1,x
|
||||
sta {m1}+1
|
@ -1,4 +0,0 @@
|
||||
pla
|
||||
sta {m1}
|
||||
pla
|
||||
sta {m1}+1
|
@ -1,4 +0,0 @@
|
||||
lda {m2}
|
||||
sta {m1}
|
||||
lda {m2}+1
|
||||
sta {m1}+1
|
@ -1,4 +0,0 @@
|
||||
lda #<{c1}
|
||||
sta {m1}
|
||||
lda #>{c1}
|
||||
sta {m1}+1
|
@ -1,8 +0,0 @@
|
||||
ldy #0
|
||||
lda ({z1}),y
|
||||
pha
|
||||
iny
|
||||
lda ({z1}),y
|
||||
sta {z1}+1
|
||||
pla
|
||||
sta {z1}
|
@ -1,7 +0,0 @@
|
||||
lda ({z1}),y
|
||||
pha
|
||||
iny
|
||||
lda ({z1}),y
|
||||
sta {z1}+1
|
||||
pla
|
||||
sta {z1}
|
@ -1,4 +0,0 @@
|
||||
lda {c1}
|
||||
sta {m1}
|
||||
lda {c1}+1
|
||||
sta {m1}+1
|
@ -1,4 +0,0 @@
|
||||
lda #<{c1}
|
||||
sta {m1}
|
||||
lda #>{c1}
|
||||
sta {m1}+1
|
@ -1,4 +0,0 @@
|
||||
lda {c1}
|
||||
sta {m1}
|
||||
lda {c1}+1
|
||||
sta {m1}+1
|
@ -1,5 +0,0 @@
|
||||
tsx
|
||||
lda STACK_BASE+{c1},x
|
||||
sta {m1}
|
||||
lda STACK_BASE+{c1}+1,x
|
||||
sta {m1}+1
|
@ -1,4 +0,0 @@
|
||||
lda #<{c1}
|
||||
sta {m1}
|
||||
lda #>{c1}
|
||||
sta {m1}+1
|
@ -1,4 +0,0 @@
|
||||
lda {m2}
|
||||
sta {m1}
|
||||
lda {m2}+1
|
||||
sta {m1}+1
|
@ -1,4 +0,0 @@
|
||||
lda {c1},x
|
||||
sta {m1}
|
||||
lda {c1}+1,x
|
||||
sta {m1}+1
|
@ -1,4 +0,0 @@
|
||||
lda {c1},y
|
||||
sta {m1}
|
||||
lda {c1}+1,y
|
||||
sta {m1}+1
|
@ -1,4 +0,0 @@
|
||||
lda {m1}
|
||||
sta {c1},y
|
||||
lda {m1}+1
|
||||
sta {c1}+1,y
|
@ -1 +0,0 @@
|
||||
// No operation needed
|
@ -1,4 +0,0 @@
|
||||
lda {m2}
|
||||
sta {m1}
|
||||
lda {m2}+1
|
||||
sta {m1}+1
|
@ -1,5 +0,0 @@
|
||||
tsx
|
||||
lda STACK_BASE+{c1},x
|
||||
sta {m1}
|
||||
lda STACK_BASE+{c1}+1,x
|
||||
sta {m1}+1
|
@ -1,4 +0,0 @@
|
||||
lda #<{c1}
|
||||
sta {m1}
|
||||
lda #>{c1}
|
||||
sta {m1}+1
|
@ -1,4 +0,0 @@
|
||||
lda {m2}
|
||||
sta {m1}
|
||||
lda {m2}+1
|
||||
sta {m1}+1
|
@ -1,6 +0,0 @@
|
||||
ldy #{c1}
|
||||
lda {m2}
|
||||
sta ({z1}),y
|
||||
iny
|
||||
lda {m2}+1
|
||||
sta ({z1}),y
|
@ -1,6 +0,0 @@
|
||||
ldy #{c1}
|
||||
lda {m2}
|
||||
sta ({z1}),y
|
||||
iny
|
||||
lda {m2}+1
|
||||
sta ({z1}),y
|
@ -1,6 +0,0 @@
|
||||
ldy #{c1}
|
||||
lda {m2}
|
||||
sta ({z1}),y
|
||||
iny
|
||||
lda {m2}+1
|
||||
sta ({z1}),y
|
@ -1,4 +1,3 @@
|
||||
ldy #{c1}
|
||||
sta ({z1}),y
|
||||
lda #0
|
||||
iny
|
@ -1,4 +1,3 @@
|
||||
ldy #0
|
||||
lda {m2}
|
||||
sta ({z1}),y
|
||||
iny
|
@ -1,5 +1,5 @@
|
||||
lda ({z2}),y
|
||||
sta {m1}
|
||||
sta ({z1}),y
|
||||
iny
|
||||
lda ({z2}),y
|
||||
sta {m1}+1
|
||||
sta ({z1}),y
|
@ -1,4 +0,0 @@
|
||||
lda #<{c1}
|
||||
sta {m1}
|
||||
lda #>{c1}
|
||||
sta {m1}+1
|
@ -1,6 +0,0 @@
|
||||
ldy #0
|
||||
lda ({z2}),y
|
||||
sta {m1}
|
||||
iny
|
||||
lda ({z2}),y
|
||||
sta {m1}+1
|
@ -1,5 +0,0 @@
|
||||
tsx
|
||||
lda STACK_BASE+{c1},x
|
||||
sta {m1}
|
||||
lda STACK_BASE+{c1}+1,x
|
||||
sta {m1}+1
|
@ -1,4 +0,0 @@
|
||||
lda {m2}
|
||||
sta {m1}
|
||||
lda {m2}+1
|
||||
sta {m1}+1
|
@ -1,4 +0,0 @@
|
||||
lda #<{c1}
|
||||
sta {m1}
|
||||
lda #>{c1}
|
||||
sta {m1}+1
|
@ -1,5 +0,0 @@
|
||||
tsx
|
||||
lda STACK_BASE+{c1},x
|
||||
sta {m1}
|
||||
lda STACK_BASE+{c1}+1,x
|
||||
sta {m1}+1
|
@ -1,4 +0,0 @@
|
||||
lda #<{c1}
|
||||
sta {m1}
|
||||
lda #>{c1}
|
||||
sta {m1}+1
|
@ -1,4 +0,0 @@
|
||||
lda {m2}
|
||||
sta {m1}
|
||||
lda {m2}+1
|
||||
sta {m1}+1
|
@ -1,4 +0,0 @@
|
||||
lda {c1}
|
||||
sta {m1}
|
||||
lda {c1}+1
|
||||
sta {m1}+1
|
@ -1,6 +0,0 @@
|
||||
ldy #0
|
||||
lda ({z2}),y
|
||||
sta {m1}
|
||||
iny
|
||||
lda ({z2}),y
|
||||
sta {m1}+1
|
@ -1 +0,0 @@
|
||||
// No operation needed
|
@ -1,4 +0,0 @@
|
||||
lda {m2}
|
||||
sta {m1}
|
||||
lda {m2}+1
|
||||
sta {m1}+1
|
@ -1,5 +0,0 @@
|
||||
tsx
|
||||
lda STACK_BASE+{c1},x
|
||||
sta {m1}
|
||||
lda STACK_BASE+{c1}+1,x
|
||||
sta {m1}+1
|
@ -1,4 +0,0 @@
|
||||
pla
|
||||
sta {m1}
|
||||
pla
|
||||
sta {m1}+1
|
@ -1,4 +0,0 @@
|
||||
lda #<{c1}
|
||||
sta {m1}
|
||||
lda #>{c1}
|
||||
sta {m1}+1
|
@ -1,4 +0,0 @@
|
||||
lda {c1},x
|
||||
sta {m1}
|
||||
lda {c1}+1,x
|
||||
sta {m1}+1
|
@ -1,4 +0,0 @@
|
||||
lda {c1},y
|
||||
sta {m1}
|
||||
lda {c1}+1,y
|
||||
sta {m1}+1
|
@ -1,4 +0,0 @@
|
||||
lda #<{c1}
|
||||
sta {m1}
|
||||
lda #>{c1}
|
||||
sta {m1}+1
|
@ -1,4 +0,0 @@
|
||||
lda {m2}
|
||||
sta {m1}
|
||||
lda {m2}+1
|
||||
sta {m1}+1
|
@ -1,8 +0,0 @@
|
||||
ldy #0
|
||||
lda ({z1}),y
|
||||
pha
|
||||
iny
|
||||
lda ({z1}),y
|
||||
sta {z1}+1
|
||||
pla
|
||||
sta {z1}
|
@ -1,7 +0,0 @@
|
||||
lda ({z1}),y
|
||||
pha
|
||||
iny
|
||||
lda ({z1}),y
|
||||
sta {z1}+1
|
||||
pla
|
||||
sta {z1}
|
@ -1,4 +0,0 @@
|
||||
lda {m2}
|
||||
sta {m1}
|
||||
lda {m2}+1
|
||||
sta {m1}+1
|
@ -710,6 +710,10 @@ class AsmFragmentTemplateSynthesisRule {
|
||||
// Rewrite (Z1),a to save A to $FF and reload it into YY
|
||||
synths.add(new AsmFragmentTemplateSynthesisRule("pb(.)z1_derefidx_vbuaa=(.*)", twoZM1, "sta $ff" , "vb$1aa=$2", "ldy $ff\nsta ({z1}),y", mapZM1));
|
||||
|
||||
// Synthesize typed pointer math using void pointers
|
||||
synths.add(new AsmFragmentTemplateSynthesisRule("(.*)p..([czm][1-9])(.*)", null, null, "$1pvo$2$3", null, null));
|
||||
synths.add(new AsmFragmentTemplateSynthesisRule("(.*)p..([czm][1-9])(.*p.*)", null, null, "$1pvo$2$3", null, null));
|
||||
|
||||
// Synthesize some constant pointers as constant words (remove when the above section can be included)
|
||||
synths.add(new AsmFragmentTemplateSynthesisRule("(.*)_(lt|gt|le|ge|eq|neq)_p..([czm].)_then_(.*)", null, null, "$1_$2_vwu$3_then_$4", null, null));
|
||||
synths.add(new AsmFragmentTemplateSynthesisRule("p..([czm].)_(lt|gt|le|ge|eq|neq)_(.*)", null, null, "vwu$1_$2_$3", null, null));
|
||||
|
@ -518,7 +518,6 @@ public class TestPrograms {
|
||||
compileAndCompare("millfork-benchmarks/linkedlist-kc.c");
|
||||
}
|
||||
|
||||
|
||||
@Test
|
||||
public void testSqrDelta() throws IOException, URISyntaxException {
|
||||
compileAndCompare("sqr-delta.c");
|
||||
|
@ -3147,12 +3147,12 @@ main: {
|
||||
rol
|
||||
sta.z __12+1
|
||||
// [8] (signed word*~) main::$16 ← (const signed word*) primenum + (signed word~) main::$12 -- pwsz1=pwsc1_plus_vwsz2
|
||||
lda.z __12
|
||||
lda #<primenum
|
||||
clc
|
||||
adc #<primenum
|
||||
adc.z __12
|
||||
sta.z __16
|
||||
lda.z __12+1
|
||||
adc #>primenum
|
||||
lda #>primenum
|
||||
adc.z __12+1
|
||||
sta.z __16+1
|
||||
// [9] (signed word) main::p#0 ← *((signed word*~) main::$16) -- vwsz1=_deref_pwsz2
|
||||
ldy #0
|
||||
@ -3260,12 +3260,12 @@ main: {
|
||||
lda.z testnum+1
|
||||
sta.z div16s.dividend+1
|
||||
// [23] (signed word*~) main::$17 ← (const signed word*) primenum + (signed word~) main::$13 -- pwsz1=pwsc1_plus_vwsz2
|
||||
lda.z __13
|
||||
lda #<primenum
|
||||
clc
|
||||
adc #<primenum
|
||||
adc.z __13
|
||||
sta.z __17
|
||||
lda.z __13+1
|
||||
adc #>primenum
|
||||
lda #>primenum
|
||||
adc.z __13+1
|
||||
sta.z __17+1
|
||||
// [24] (signed word) div16s::divisor#0 ← *((signed word*~) main::$17) -- vwsz1=_deref_pwsz2
|
||||
ldy #0
|
||||
@ -3341,12 +3341,12 @@ main: {
|
||||
rol
|
||||
sta.z __14+1
|
||||
// [33] (signed word*~) main::$18 ← (const signed word*) primenum + (signed word~) main::$14 -- pwsz1=pwsc1_plus_vwsz2
|
||||
lda.z __14
|
||||
lda #<primenum
|
||||
clc
|
||||
adc #<primenum
|
||||
adc.z __14
|
||||
sta.z __18
|
||||
lda.z __14+1
|
||||
adc #>primenum
|
||||
lda #>primenum
|
||||
adc.z __14+1
|
||||
sta.z __18+1
|
||||
// [34] *((signed word*~) main::$18) ← (signed word) testnum#10 -- _deref_pwsz1=vwsz2
|
||||
ldy #0
|
||||
|
Loading…
x
Reference in New Issue
Block a user