From d3483650108365ee2688fe4e4a4cd03802d5cc4d Mon Sep 17 00:00:00 2001 From: jespergravgaard Date: Thu, 23 Nov 2017 07:31:26 +0100 Subject: [PATCH] Improved fragment synthesis --- .../kickc/fragment/AsmFragmentManager.java | 54 ++++++++----------- .../kickc/fragment/asm/aby=aby_bor_xby.asm | 2 + .../kickc/fragment/asm/aby=aby_bor_yby.asm | 2 + ...y_then_la1.asm => aby_ge_xby_then_la1.asm} | 2 +- ...y_then_la1.asm => aby_ge_yby_then_la1.asm} | 2 +- .../fragment/asm/aby_lt_yby_then_la1.asm | 3 ++ .../fragment/asm/coby1_lt_aby_then_la1.asm | 2 - .../fragment/asm/coby1_lt_xby_then_la1.asm | 2 - .../fragment/asm/coby1_lt_yby_then_la1.asm | 2 - .../fragment/asm/xby_ge_aby_then_la1.asm | 3 -- ...y_then_la1.asm => xby_ge_yby_then_la1.asm} | 2 +- .../fragment/asm/xby_lt_aby_then_la1.asm | 3 -- .../fragment/asm/yby_ge_aby_then_la1.asm | 3 -- .../fragment/asm/yby_lt_aby_then_la1.asm | 3 -- .../fragment/asm/yby_lt_xby_then_la1.asm | 3 -- .../fragment/asm/zpby1_eq_aby_then_la1.asm | 2 - .../fragment/asm/zpby1_eq_xby_then_la1.asm | 2 - .../fragment/asm/zpby1_eq_yby_then_la1.asm | 2 - 18 files changed, 33 insertions(+), 61 deletions(-) create mode 100644 src/main/java/dk/camelot64/kickc/fragment/asm/aby=aby_bor_xby.asm create mode 100644 src/main/java/dk/camelot64/kickc/fragment/asm/aby=aby_bor_yby.asm rename src/main/java/dk/camelot64/kickc/fragment/asm/{xby_eq_aby_then_la1.asm => aby_ge_xby_then_la1.asm} (64%) rename src/main/java/dk/camelot64/kickc/fragment/asm/{yby_eq_aby_then_la1.asm => aby_ge_yby_then_la1.asm} (64%) create mode 100644 src/main/java/dk/camelot64/kickc/fragment/asm/aby_lt_yby_then_la1.asm delete mode 100644 src/main/java/dk/camelot64/kickc/fragment/asm/coby1_lt_aby_then_la1.asm delete mode 100644 src/main/java/dk/camelot64/kickc/fragment/asm/coby1_lt_xby_then_la1.asm delete mode 100644 src/main/java/dk/camelot64/kickc/fragment/asm/coby1_lt_yby_then_la1.asm delete mode 100644 src/main/java/dk/camelot64/kickc/fragment/asm/xby_ge_aby_then_la1.asm rename src/main/java/dk/camelot64/kickc/fragment/asm/{yby_eq_xby_then_la1.asm => xby_ge_yby_then_la1.asm} (61%) delete mode 100644 src/main/java/dk/camelot64/kickc/fragment/asm/xby_lt_aby_then_la1.asm delete mode 100644 src/main/java/dk/camelot64/kickc/fragment/asm/yby_ge_aby_then_la1.asm delete mode 100644 src/main/java/dk/camelot64/kickc/fragment/asm/yby_lt_aby_then_la1.asm delete mode 100644 src/main/java/dk/camelot64/kickc/fragment/asm/yby_lt_xby_then_la1.asm delete mode 100644 src/main/java/dk/camelot64/kickc/fragment/asm/zpby1_eq_aby_then_la1.asm delete mode 100644 src/main/java/dk/camelot64/kickc/fragment/asm/zpby1_eq_xby_then_la1.asm delete mode 100644 src/main/java/dk/camelot64/kickc/fragment/asm/zpby1_eq_yby_then_la1.asm diff --git a/src/main/java/dk/camelot64/kickc/fragment/AsmFragmentManager.java b/src/main/java/dk/camelot64/kickc/fragment/AsmFragmentManager.java index f77bce4dc..c905678d0 100644 --- a/src/main/java/dk/camelot64/kickc/fragment/AsmFragmentManager.java +++ b/src/main/java/dk/camelot64/kickc/fragment/AsmFragmentManager.java @@ -70,37 +70,6 @@ public class AsmFragmentManager { */ private static CharStream synthesizeFragment(String signature) { - String sigNew = signature; - sigNew = regexpRewriteSignature(sigNew, "(.*)=(.*)_band_aby", "$1=aby_band_$2"); - sigNew = regexpRewriteSignature(sigNew, "(.*)=(.*)_band_xby", "$1=xby_band_$2"); - sigNew = regexpRewriteSignature(sigNew, "(.*)=(.*)_band_yby", "$1=yby_band_$2"); - sigNew = regexpRewriteSignature(sigNew, "(.*)=(.*)_bor_aby", "$1=aby_bor_$2"); - sigNew = regexpRewriteSignature(sigNew, "(.*)=(.*)_bor_xby", "$1=xby_bor_$2"); - sigNew = regexpRewriteSignature(sigNew, "(.*)=(.*)_bor_yby", "$1=yby_bor_$2"); - sigNew = regexpRewriteSignature(sigNew, "(.*)=(.*)_plus_aby", "$1=aby_plus_$2"); - sigNew = regexpRewriteSignature(sigNew, "(.*)=(.*)_plus_xby", "$1=xby_plus_$2"); - sigNew = regexpRewriteSignature(sigNew, "(.*)=(.*)_plus_yby", "$1=yby_plus_$2"); - sigNew = regexpRewriteSignature(sigNew, "(.*)_lt_aby_then_(.*)", "aby_ge_$1_then_$2"); - sigNew = regexpRewriteSignature(sigNew, "(.*)_lt_xby_then_(.*)", "xby_ge_$1_then_$2"); - sigNew = regexpRewriteSignature(sigNew, "(.*)_lt_yby_then_(.*)", "yby_ge_$1_then_$2"); - sigNew = regexpRewriteSignature(sigNew, "(.*)_ge_aby_then_(.*)", "aby_lt_$1_then_$2"); - sigNew = regexpRewriteSignature(sigNew, "(.*)_ge_xby_then_(.*)", "xby_lt_$1_then_$2"); - sigNew = regexpRewriteSignature(sigNew, "(.*)_ge_yby_then_(.*)", "yby_lt_$1_then_$2"); - sigNew = regexpRewriteSignature(sigNew, "(.*)_gt_aby_then_(.*)", "aby_le_$1_then_$2"); - sigNew = regexpRewriteSignature(sigNew, "(.*)_gt_xby_then_(.*)", "xby_le_$1_then_$2"); - sigNew = regexpRewriteSignature(sigNew, "(.*)_gt_yby_then_(.*)", "yby_le_$1_then_$2"); - sigNew = regexpRewriteSignature(sigNew, "(.*)_neq_aby_then_(.*)", "aby_neq_$1_then_$2"); - sigNew = regexpRewriteSignature(sigNew, "(.*)_neq_xby_then_(.*)", "xby_neq_$1_then_$2"); - sigNew = regexpRewriteSignature(sigNew, "(.*)_neq_yby_then_(.*)", "yby_neq_$1_then_$2"); - if (!signature.equals(sigNew)) { - CharStream loadFragment = loadFragment(sigNew); - if(loadFragment!=null) { - return loadFragment; - } else { - signature = sigNew; - } - } - Map mapZpsby = new LinkedHashMap<>(); mapZpsby.put("zpsby2", "zpsby1"); mapZpsby.put("zpsby3", "zpsby2"); @@ -117,6 +86,11 @@ public class AsmFragmentManager { mapConst.put("coby3", "coby2"); List synths = new ArrayList<>(); + + synths.add(new FragmentSynthesis("(.*)=(.*)_(band|bor|plus)_(as?by)", ".*=as?by_.*", null, "$1=$4_$3_$2", null, null)); + synths.add(new FragmentSynthesis("(.*)=(.*)_(band|bor|plus)_(xs?by)", ".*=[xa]s?by_.*", null, "$1=$4_$3_$2", null, null)); + synths.add(new FragmentSynthesis("(.*)=(.*)_(band|bor|plus)_(ys?by)", ".*=[axy]s?by_.*", null, "$1=$4_$3_$2", null, null)); + synths.add(new FragmentSynthesis("xby=(.*)", null, null, "aby=$1", "tax\n", null)); synths.add(new FragmentSynthesis("yby=(.*)", null, null, "aby=$1", "tay\n", null)); synths.add(new FragmentSynthesis("zpby1=(.*)", ".*=.*zps?by1.*", null, "aby=$1", "sta {zpby1}\n", mapZpby)); @@ -143,6 +117,24 @@ public class AsmFragmentManager { synths.add(new FragmentSynthesis("zpsby1_(lt|gt|le|ge|eq|neq)_(.*)", ".*as?by.*", "lda {zpsby1}\n", "asby_$1_$2", null, mapZpsby)); synths.add(new FragmentSynthesis("_deref_cowo1_(lt|gt|le|ge|eq|neq)_(.*)", ".*as?by.*", "lda {cowo1}\n", "aby_$1_$2", null, mapConst)); synths.add(new FragmentSynthesis("_deref_zpptrby1_(lt|gt|le|ge|eq|neq)_(.*)", ".*=.*as?by.*|.*=.*ys?by.*", "ldy #0\n"+"lda ({zpptrby1}),y\n", "aby_$1_$2", null, mapZpptrby)); + synths.add(new FragmentSynthesis("(.*)_ge_(as?by)_then_(.*)", ".*[a]s?by.*_ge.*", null, "$2_lt_$1_then_$3", null, null)); + synths.add(new FragmentSynthesis("(.*)_ge_(xs?by)_then_(.*)", ".*[ax]s?by.*_ge.*", null, "$2_lt_$1_then_$3", null, null)); + synths.add(new FragmentSynthesis("(.*)_ge_(ys?by)_then_(.*)", ".*[axy]s?by.*_ge.*", null, "$2_lt_$1_then_$3", null, null)); + synths.add(new FragmentSynthesis("(.*)_lt_(as?by)_then_(.*)", ".*[a]s?by.*_lt.*", null, "$2_ge_$1_then_$3", null, null)); + synths.add(new FragmentSynthesis("(.*)_lt_(xs?by)_then_(.*)", ".*[ax]s?by.*_lt.*", null, "$2_ge_$1_then_$3", null, null)); + synths.add(new FragmentSynthesis("(.*)_lt_(ys?by)_then_(.*)", ".*[axy]s?by.*_lt.*", null, "$2_ge_$1_then_$3", null, null)); + synths.add(new FragmentSynthesis("(.*)_gt_(as?by)_then_(.*)", ".*[a]s?by.*_gt.*", null, "$2_le_$1_then_$3", null, null)); + synths.add(new FragmentSynthesis("(.*)_gt_(xs?by)_then_(.*)", ".*[ax]s?by.*_gt.*", null, "$2_le_$1_then_$3", null, null)); + synths.add(new FragmentSynthesis("(.*)_gt_(ys?by)_then_(.*)", ".*[axy]s?by.*_gt.*", null, "$2_le_$1_then_$3", null, null)); + synths.add(new FragmentSynthesis("(.*)_le_(as?by)_then_(.*)", ".*[a]s?by.*_le.*", null, "$2_gt_$1_then_$3", null, null)); + synths.add(new FragmentSynthesis("(.*)_le_(xs?by)_then_(.*)", ".*[ax]s?by.*_le.*", null, "$2_gt_$1_then_$3", null, null)); + synths.add(new FragmentSynthesis("(.*)_le_(ys?by)_then_(.*)", ".*[axy]s?by.*_le.*", null, "$2_gt_$1_then_$3", null, null)); + synths.add(new FragmentSynthesis("(.*)_neq_(as?by)_then_(.*)", ".*[a]s?by.*_neq.*", null, "$2_neq_$1_then_$3", null, null)); + synths.add(new FragmentSynthesis("(.*)_neq_(xs?by)_then_(.*)", ".*[ax]s?by.*_neq.*", null, "$2_neq_$1_then_$3", null, null)); + synths.add(new FragmentSynthesis("(.*)_neq_(ys?by)_then_(.*)", ".*[axy]s?by.*_neq.*", null, "$2_neq_$1_then_$3", null, null)); + synths.add(new FragmentSynthesis("(.*)_eq_(as?by)_then_(.*)", ".*[a]s?by.*_eq.*", null, "$2_eq_$1_then_$3", null, null)); + synths.add(new FragmentSynthesis("(.*)_eq_(xs?by)_then_(.*)", ".*[ax]s?by.*_eq.*", null, "$2_eq_$1_then_$3", null, null)); + synths.add(new FragmentSynthesis("(.*)_eq_(ys?by)_then_(.*)", ".*[axy]s?by.*_eq.*", null, "$2_eq_$1_then_$3", null, null)); for (FragmentSynthesis synth : synths) { CharStream synthesized = synth.synthesize(signature); diff --git a/src/main/java/dk/camelot64/kickc/fragment/asm/aby=aby_bor_xby.asm b/src/main/java/dk/camelot64/kickc/fragment/asm/aby=aby_bor_xby.asm new file mode 100644 index 000000000..183127d79 --- /dev/null +++ b/src/main/java/dk/camelot64/kickc/fragment/asm/aby=aby_bor_xby.asm @@ -0,0 +1,2 @@ +stx $ff +ora $ff \ No newline at end of file diff --git a/src/main/java/dk/camelot64/kickc/fragment/asm/aby=aby_bor_yby.asm b/src/main/java/dk/camelot64/kickc/fragment/asm/aby=aby_bor_yby.asm new file mode 100644 index 000000000..7c0b29e3c --- /dev/null +++ b/src/main/java/dk/camelot64/kickc/fragment/asm/aby=aby_bor_yby.asm @@ -0,0 +1,2 @@ +sty $ff +ora $ff \ No newline at end of file diff --git a/src/main/java/dk/camelot64/kickc/fragment/asm/xby_eq_aby_then_la1.asm b/src/main/java/dk/camelot64/kickc/fragment/asm/aby_ge_xby_then_la1.asm similarity index 64% rename from src/main/java/dk/camelot64/kickc/fragment/asm/xby_eq_aby_then_la1.asm rename to src/main/java/dk/camelot64/kickc/fragment/asm/aby_ge_xby_then_la1.asm index 0b137a468..ab1a16eeb 100644 --- a/src/main/java/dk/camelot64/kickc/fragment/asm/xby_eq_aby_then_la1.asm +++ b/src/main/java/dk/camelot64/kickc/fragment/asm/aby_ge_xby_then_la1.asm @@ -1,3 +1,3 @@ stx $ff cmp $ff -beq {la1} \ No newline at end of file +bcs {la1} \ No newline at end of file diff --git a/src/main/java/dk/camelot64/kickc/fragment/asm/yby_eq_aby_then_la1.asm b/src/main/java/dk/camelot64/kickc/fragment/asm/aby_ge_yby_then_la1.asm similarity index 64% rename from src/main/java/dk/camelot64/kickc/fragment/asm/yby_eq_aby_then_la1.asm rename to src/main/java/dk/camelot64/kickc/fragment/asm/aby_ge_yby_then_la1.asm index 38676c6e0..cb2e061a5 100644 --- a/src/main/java/dk/camelot64/kickc/fragment/asm/yby_eq_aby_then_la1.asm +++ b/src/main/java/dk/camelot64/kickc/fragment/asm/aby_ge_yby_then_la1.asm @@ -1,3 +1,3 @@ sty $ff cmp $ff -beq {la1} \ No newline at end of file +bcs {la1} \ No newline at end of file diff --git a/src/main/java/dk/camelot64/kickc/fragment/asm/aby_lt_yby_then_la1.asm b/src/main/java/dk/camelot64/kickc/fragment/asm/aby_lt_yby_then_la1.asm new file mode 100644 index 000000000..a0e687cab --- /dev/null +++ b/src/main/java/dk/camelot64/kickc/fragment/asm/aby_lt_yby_then_la1.asm @@ -0,0 +1,3 @@ +sty $ff +cmp $ff +bcc {la1} \ No newline at end of file diff --git a/src/main/java/dk/camelot64/kickc/fragment/asm/coby1_lt_aby_then_la1.asm b/src/main/java/dk/camelot64/kickc/fragment/asm/coby1_lt_aby_then_la1.asm deleted file mode 100644 index f3b60d1c6..000000000 --- a/src/main/java/dk/camelot64/kickc/fragment/asm/coby1_lt_aby_then_la1.asm +++ /dev/null @@ -1,2 +0,0 @@ -cmp #{coby1} -bcs {la1} \ No newline at end of file diff --git a/src/main/java/dk/camelot64/kickc/fragment/asm/coby1_lt_xby_then_la1.asm b/src/main/java/dk/camelot64/kickc/fragment/asm/coby1_lt_xby_then_la1.asm deleted file mode 100644 index eee87de96..000000000 --- a/src/main/java/dk/camelot64/kickc/fragment/asm/coby1_lt_xby_then_la1.asm +++ /dev/null @@ -1,2 +0,0 @@ -cpx #{coby1} -bcs {la1} \ No newline at end of file diff --git a/src/main/java/dk/camelot64/kickc/fragment/asm/coby1_lt_yby_then_la1.asm b/src/main/java/dk/camelot64/kickc/fragment/asm/coby1_lt_yby_then_la1.asm deleted file mode 100644 index bd89b4333..000000000 --- a/src/main/java/dk/camelot64/kickc/fragment/asm/coby1_lt_yby_then_la1.asm +++ /dev/null @@ -1,2 +0,0 @@ -cpy #{coby1} -bcs {la1} \ No newline at end of file diff --git a/src/main/java/dk/camelot64/kickc/fragment/asm/xby_ge_aby_then_la1.asm b/src/main/java/dk/camelot64/kickc/fragment/asm/xby_ge_aby_then_la1.asm deleted file mode 100644 index a542d2d69..000000000 --- a/src/main/java/dk/camelot64/kickc/fragment/asm/xby_ge_aby_then_la1.asm +++ /dev/null @@ -1,3 +0,0 @@ -sta $ff -cpx $ff -bcs {la1} \ No newline at end of file diff --git a/src/main/java/dk/camelot64/kickc/fragment/asm/yby_eq_xby_then_la1.asm b/src/main/java/dk/camelot64/kickc/fragment/asm/xby_ge_yby_then_la1.asm similarity index 61% rename from src/main/java/dk/camelot64/kickc/fragment/asm/yby_eq_xby_then_la1.asm rename to src/main/java/dk/camelot64/kickc/fragment/asm/xby_ge_yby_then_la1.asm index 446ed9647..a1ca6c786 100644 --- a/src/main/java/dk/camelot64/kickc/fragment/asm/yby_eq_xby_then_la1.asm +++ b/src/main/java/dk/camelot64/kickc/fragment/asm/xby_ge_yby_then_la1.asm @@ -1,3 +1,3 @@ sty $ff cpx $ff -beq {la1} \ No newline at end of file +bcs {la1} \ No newline at end of file diff --git a/src/main/java/dk/camelot64/kickc/fragment/asm/xby_lt_aby_then_la1.asm b/src/main/java/dk/camelot64/kickc/fragment/asm/xby_lt_aby_then_la1.asm deleted file mode 100644 index 824a5647f..000000000 --- a/src/main/java/dk/camelot64/kickc/fragment/asm/xby_lt_aby_then_la1.asm +++ /dev/null @@ -1,3 +0,0 @@ -sta $ff -cpx $ff -bcc {la1} \ No newline at end of file diff --git a/src/main/java/dk/camelot64/kickc/fragment/asm/yby_ge_aby_then_la1.asm b/src/main/java/dk/camelot64/kickc/fragment/asm/yby_ge_aby_then_la1.asm deleted file mode 100644 index 3a3c534ea..000000000 --- a/src/main/java/dk/camelot64/kickc/fragment/asm/yby_ge_aby_then_la1.asm +++ /dev/null @@ -1,3 +0,0 @@ -sta $ff -cpy $ff -bcs {la1} \ No newline at end of file diff --git a/src/main/java/dk/camelot64/kickc/fragment/asm/yby_lt_aby_then_la1.asm b/src/main/java/dk/camelot64/kickc/fragment/asm/yby_lt_aby_then_la1.asm deleted file mode 100644 index a47202056..000000000 --- a/src/main/java/dk/camelot64/kickc/fragment/asm/yby_lt_aby_then_la1.asm +++ /dev/null @@ -1,3 +0,0 @@ -sta $ff -cpy $ff -bcc {la1} \ No newline at end of file diff --git a/src/main/java/dk/camelot64/kickc/fragment/asm/yby_lt_xby_then_la1.asm b/src/main/java/dk/camelot64/kickc/fragment/asm/yby_lt_xby_then_la1.asm deleted file mode 100644 index 8588a7ef7..000000000 --- a/src/main/java/dk/camelot64/kickc/fragment/asm/yby_lt_xby_then_la1.asm +++ /dev/null @@ -1,3 +0,0 @@ -stx $ff -cpy $ff -bcc {la1} \ No newline at end of file diff --git a/src/main/java/dk/camelot64/kickc/fragment/asm/zpby1_eq_aby_then_la1.asm b/src/main/java/dk/camelot64/kickc/fragment/asm/zpby1_eq_aby_then_la1.asm deleted file mode 100644 index bdfbd75f5..000000000 --- a/src/main/java/dk/camelot64/kickc/fragment/asm/zpby1_eq_aby_then_la1.asm +++ /dev/null @@ -1,2 +0,0 @@ -cmp {zpby1} -beq {la1} \ No newline at end of file diff --git a/src/main/java/dk/camelot64/kickc/fragment/asm/zpby1_eq_xby_then_la1.asm b/src/main/java/dk/camelot64/kickc/fragment/asm/zpby1_eq_xby_then_la1.asm deleted file mode 100644 index 046abcd75..000000000 --- a/src/main/java/dk/camelot64/kickc/fragment/asm/zpby1_eq_xby_then_la1.asm +++ /dev/null @@ -1,2 +0,0 @@ -cpx {zpby1} -beq {la1} \ No newline at end of file diff --git a/src/main/java/dk/camelot64/kickc/fragment/asm/zpby1_eq_yby_then_la1.asm b/src/main/java/dk/camelot64/kickc/fragment/asm/zpby1_eq_yby_then_la1.asm deleted file mode 100644 index 860aa5b56..000000000 --- a/src/main/java/dk/camelot64/kickc/fragment/asm/zpby1_eq_yby_then_la1.asm +++ /dev/null @@ -1,2 +0,0 @@ -cpy {zpby1} -beq {la1} \ No newline at end of file