aboutsummaryrefslogtreecommitdiffstatshomepage
diff options
authorLuc Van Oostenryck <luc.vanoostenryck@gmail.com>2017-01-29 11:48:08 +0100
committerChristopher Li <sparse@chrisli.org>2017-02-13 09:34:45 +0800
commitc6bbdaf57222d77d9c64b53b784372f8bfe70eda (patch)
tree027d33becee71c6ee1dc210d092a5995e82d50d4
parent66b1f578780f432367da7d82e245f3fe30bc5b87 (diff)
downloadsparse-dev-c6bbdaf57222d77d9c64b53b784372f8bfe70eda.tar.gz
cleanup kill_instruction()
No functional changes: - factorize out the '->bb = NULL' and '|= REPEAT_CSE'. - fall through the switch cases for ternary/bunary/unary ops. Signed-off-by: Luc Van Oostenryck <luc.vanoostenryck@gmail.com> Signed-off-by: Christopher Li <sparse@chrisli.org>
-rw-r--r--simplify.c47
1 files changed, 21 insertions, 26 deletions
diff --git a/simplify.c b/simplify.c
index 66550fa3..f62fc83a 100644
--- a/simplify.c
+++ b/simplify.c
@@ -188,54 +188,49 @@ void kill_instruction(struct instruction *insn)
return;
switch (insn->opcode) {
+ case OP_SEL:
+ case OP_RANGE:
+ kill_use(&insn->src3);
+ /* fall through */
+
case OP_BINARY ... OP_BINCMP_END:
- insn->bb = NULL;
- kill_use(&insn->src1);
kill_use(&insn->src2);
- repeat_phase |= REPEAT_CSE;
- return;
+ /* fall through */
case OP_CAST:
case OP_SCAST:
case OP_FPCAST:
case OP_PTRCAST:
case OP_NOT: case OP_NEG:
- insn->bb = NULL;
kill_use(&insn->src1);
- repeat_phase |= REPEAT_CSE;
- return;
+ break;
case OP_PHI:
clear_phi(insn);
- insn->bb = NULL;
- repeat_phase |= REPEAT_CSE;
- return;
+ break;
case OP_SYMADDR:
- insn->bb = NULL;
- repeat_phase |= REPEAT_CSE | REPEAT_SYMBOL_CLEANUP;
- return;
+ repeat_phase |= REPEAT_SYMBOL_CLEANUP;
+ break;
- case OP_SEL:
- case OP_RANGE:
- insn->bb = NULL;
- repeat_phase |= REPEAT_CSE;
- kill_use(&insn->src1);
- kill_use(&insn->src2);
- kill_use(&insn->src3);
- return;
case OP_BR:
+ if (!insn->bb_true || !insn->bb_false)
+ break;
+ /* fall through */
+
case OP_COMPUTEDGOTO:
- insn->bb = NULL;
- repeat_phase |= REPEAT_CSE;
- if (insn->bb_true && insn->bb_false)
- kill_use(&insn->cond);
- return;
+ kill_use(&insn->cond);
+ break;
case OP_ENTRY:
+ default:
/* ignore */
return;
}
+
+ insn->bb = NULL;
+ repeat_phase |= REPEAT_CSE;
+ return;
}
/*