codeb: (opt) unneotige test instrutkionen wegoptimiert
authorBernhard Urban <lewurm@gmail.com>
Sun, 30 May 2010 13:10:00 +0000 (15:10 +0200)
committerBernhard Urban <lewurm@gmail.com>
Sun, 30 May 2010 13:10:00 +0000 (15:10 +0200)
codeb/code.bfe
codeb/parser.y
codeb/tree.h

index e36c0d2303f40f72cf3e4c9ded52dd31d9e85734..4b74b122f07d5e06b085d385034465f1335eea58 100644 (file)
@@ -175,7 +175,7 @@ void gen_subspecial(struct treenode *bnode, short e)
 %}
 
 %start begin
-%term O_RET=1 O_NULL=2 O_SUB=3 O_MUL=4 O_OR=5 O_LESS=6 O_EQ=7 O_ID=8 O_ADD=9 O_NUM=10 O_FIELD=11 O_MTWO=12 O_MFOUR=13 O_MEIGHT=14 O_MONE=15 O_ASSIGN=16 O_IF=17
+%term O_RET=1 O_NULL=2 O_SUB=3 O_MUL=4 O_OR=5 O_LESS=6 O_EQ=7 O_ID=8 O_ADD=9 O_NUM=10 O_FIELD=11 O_MTWO=12 O_MFOUR=13 O_MEIGHT=14 O_MONE=15 O_ASSIGN=16 O_IF=17 O_BOOL=18
 
 %%
 
@@ -197,9 +197,11 @@ retexpr: expr
 
 ifstat: O_IF(O_ID) # 1 # /* fuer faelle wie "if bla then" noetig */ KIDREG2PARM(0); printf("\ttest $-1, %%%s\n", KID_REG(0));
 ifstat: O_IF(expr) # 2 # /* iburg beschummeln :/ */ printf("\ttest $-1, %%rax\n");
+ifstat: O_IF(O_BOOL(expr)) # 1 # /* dann braucht man kein test */
 
 expr: O_ID # 0 #
 expr: imm # 1 # moveimm(BN_VAL, BN_REG);
+expr: O_BOOL(expr) # 0 #
 
 
 expr: O_SUB(expr,expr)          # 2 # gen_e_eno(bnode, "subq");
index 62f4a4c5d2690cca64ce025d8511a260cc2c0241..39cc35dbe86ea521fc84c18bcccc679ba47ae200 100644 (file)
@@ -320,9 +320,9 @@ Expr:
 
        | NOT Term
          @{
-               @i @Expr.node@ = new_node(O_EQ, @Term.node@, new_node(O_NULL, TREENULL, TREENULL));
+               @i @Expr.node@ = new_node(O_BOOL, new_node(O_EQ, @Term.node@, new_node(O_NULL, TREENULL, TREENULL)), TREENULL);
 
-               @reg @Term.node@->reg = @Expr.node@->reg;
+               @reg @Term.node@->reg = @Expr.node@->kids[0]->reg = @Expr.node@->reg;
          @}
 
        | Term Minusterm
@@ -370,22 +370,22 @@ Expr:
 
        | Term '<' Term
          @{
-           @i @Expr.node@ = new_node(O_LESS, @Term.0.node@, @Term.1.node@);
+           @i @Expr.node@ = new_node(O_BOOL, new_node(O_LESS, @Term.0.node@, @Term.1.node@), TREENULL);
                @i @Expr.imm@ = @Term.0.imm@ && @Term.0.imm@;
 
                @reg {
-                       @Term.0.node@->reg = @Expr.node@->reg;
+                       @Term.0.node@->reg = @Expr.node@->kids[0]->reg = @Expr.node@->reg;
                        @Term.1.node@->reg = next_reg(@Term.0.node@->reg, @Expr.gparamges@);
                }
          @}
 
        | Term '=' Term
          @{
-           @i @Expr.node@ = new_node(O_EQ, @Term.0.node@, @Term.1.node@);
+           @i @Expr.node@ = new_node(O_BOOL, new_node(O_EQ, @Term.0.node@, @Term.1.node@), TREENULL);
                @i @Expr.imm@ = @Term.0.imm@ && @Term.0.imm@;
 
                @reg {
-                       @Term.0.node@->reg = @Expr.node@->reg;
+                       @Term.0.node@->reg = @Expr.node@->kids[0]->reg = @Expr.node@->reg;
                        @Term.1.node@->reg = next_reg(@Term.0.node@->reg, @Expr.gparamges@);
                }
          @}
index a4cfd60a69c46f15732f87d396418827bfc4a497..8e39fe30a807bc3b27c91da4fecd6c14702e4cd2 100644 (file)
@@ -13,14 +13,14 @@ enum {
        O_RET=1, O_NULL, O_SUB, O_MUL,
        O_OR=5, O_LESS, O_EQ, O_ID, O_ADD,
        O_NUM=10, O_FIELD, O_MTWO, O_MFOUR, O_MEIGHT,
-       O_MONE=15, O_ASSIGN, O_IF
+       O_MONE=15, O_ASSIGN, O_IF, O_BOOL
 };
 
 static char *o_names[] = {
        "", "O_RET", "O_NULL", "O_SUB", "O_MUL",
        "O_OR", "O_LESS", "O_EQ", "O_ID", "O_ADD",
        "O_NUM", "O_FIELD", "O_MTWO", "O_MFOUR", "O_MEIGHT",
-       "O_MONE", "O_ASSIGN", "O_IF"
+       "O_MONE", "O_ASSIGN", "O_IF", "O_BOOL"
 };
 
 struct treenode {