aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/simplify.c
diff options
authorLuc Van Oostenryck <luc.vanoostenryck@gmail.com>2021-01-25 00:37:55 +0100
committerLuc Van Oostenryck <luc.vanoostenryck@gmail.com>2021-01-25 00:37:55 +0100
commit0fb77bb6e5429575f52b5e26f06db031f93de057 (patch)
treec568324597affc04c1d12dd7013d647e7e9e9fdf /simplify.c
parent879b11da4ef9a675216eb1f3458cff1e53904c03 (diff)
parent36df56f0a4f87da3add3347061544f53a1865317 (diff)
downloadsparse-dev-0fb77bb6e5429575f52b5e26f06db031f93de057.tar.gz
Merge branches 'fix-can-move-to' and 'asr-synth' into next
Diffstat (limited to 'simplify.c')
-rw-r--r--simplify.c13
1 files changed, 12 insertions, 1 deletions
diff --git a/simplify.c b/simplify.c
index 0bb66bed..bf6397df 100644
--- a/simplify.c
+++ b/simplify.c
@@ -2068,7 +2068,7 @@ static int simplify_memop(struct instruction *insn)
static int simplify_cast(struct instruction *insn)
{
unsigned long long mask;
- struct instruction *def;
+ struct instruction *def, *def2;
pseudo_t src = insn->src;
pseudo_t val;
int osize;
@@ -2165,6 +2165,17 @@ static int simplify_cast(struct instruction *insn)
case OP_TRUNC:
insn->orig_type = def->orig_type;
return replace_pseudo(insn, &insn->src1, def->src);
+ case OP_SEXT:
+ if (size != def->orig_type->bit_size)
+ break;
+ if (DEF_OPCODE(def2, def->src) != OP_LSR)
+ break;
+ if (def2->src2 != value_pseudo(size - def->size))
+ break;
+ // SEXT(TRUNC(LSR(x, N))) --> ASR(x, N)
+ insn->opcode = OP_ASR;
+ insn->src2 = def2->src2;
+ return replace_pseudo(insn, &insn->src1, def2->src1);
case OP_ZEXT:
if (size != def->orig_type->bit_size)
break;