* src/pic/ralloc.c (debugLogRegType): Removed some old types to get it to compile.
[fw/sdcc] / src / z80 / peeph.def
index 63f57e357cd76a1e34285e8cab01aff747d8d40c..a743e5576ecd8a6bc90134d40554583f673c272b 100644 (file)
@@ -1,7 +1,12 @@
+replace restart {
+       ld (hl),(hl)
+} by {
+       ERROR - peephole - caught (hl),(hl)
+}
 replace restart {
        ld %1,%1
 } by {
-       ; Removed redundent load
+       ; Rule 1: Removed redundent load
 }
 replace restart {
        xor a,a
@@ -9,7 +14,6 @@ replace restart {
        or a,a
        jp %2,%3
 } by {
-       ; Removed redundent or a,a
        xor     a,a
        or      a,%1
        jp      %2,%3
@@ -18,7 +22,7 @@ replace restart {
        cp a,#0x00
        jp nz,%1
 } by {
-       ; Rule 3
+        ; Rule 3: Changed cp #0 to or
        or      a,a
        jp      nz,%1
 }
@@ -29,7 +33,7 @@ replace restart {
        jp      %3
 %2:
 } by {
-       ; Rule 4
+       ; Rule 4: Changed jp order
        jp      z,%2
 %1:
        jp      %3
@@ -40,7 +44,7 @@ replace restart {
        jp      %2
 %1:
 } by {
-       ; Rule 5
+       ; Rule 5: Changed jump logic
        jp      z,%2
 %1:
 }
@@ -49,16 +53,64 @@ replace restart {
        jp      %2
 %1:
 } by {
-       ; Rule 6
+       ; Rule 6: Changed jump logic
        jp      nz,%2
 %1:
 }
 replace restart {
+       or      a,%1
+       or      a,a
+} by {
+       ; Rule 7: Removed redundent or
+       or      a,%1
+}
+replace restart {
+       or      a,%1)
+        or      a,a
+} by {
+       ; Rule 8: Removed redundent or for (ix)
+       or      a,%1)
+}
+replace restart {
+       xor     a,a
+       or      a,%1
+       jp      nz,%2
+       xor     a,a
+       or      a,%3
+       jp      z,%2
+} by {
+       xor     a,a
+       or      a,%1
+       jp      nz,%2
+       or      a,%3
+       jp      z,%2
+}
+replace restart {
+       jp      nz,%1
+       inc     %3)
 %1:
        jp      %2
-       jp      %3
 } by {
-       ; Weird Rule 7
+       jp      nz,%2
+       inc     %3)
 %1:
        jp      %2
 }
+replace restart {
+       xor     a,a
+       ld      a,#0x00
+} by {
+        xor     a,a
+}
+replace restart {
+        ld      e,#0x00
+        ld      d,#0x00
+} by {
+        ld      de,#0x0000
+}
+replace restart {
+       ld      %1,a
+       ld      a,%1
+} by {
+        ld     %1,a
+}