aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linearize.c
diff options
authorLuc Van Oostenryck <luc.vanoostenryck@gmail.com>2021-03-05 17:36:37 +0100
committerLuc Van Oostenryck <luc.vanoostenryck@gmail.com>2021-03-05 17:36:37 +0100
commite0f904856b3d665a84b4342b79967b97a3739545 (patch)
tree6bcf9d5aaed252c9416c867e508942d54b97bb65 /linearize.c
parent41222364c4a6ba9e515df5eee96ae6262735fdc6 (diff)
parent778de2bf52a2bed588d1653aaebe2cbd25f80eac (diff)
downloadsparse-dev-e0f904856b3d665a84b4342b79967b97a3739545.tar.gz
Merge branch 'slice'
* slice: small reorg of OP_SLICE in preparation for some incoming changes
Diffstat (limited to 'linearize.c')
-rw-r--r--linearize.c6
1 files changed, 3 insertions, 3 deletions
diff --git a/linearize.c b/linearize.c
index 0c9b0e59..b06c0625 100644
--- a/linearize.c
+++ b/linearize.c
@@ -470,7 +470,7 @@ const char *show_instruction(struct instruction *insn)
break;
case OP_SLICE:
- buf += sprintf(buf, "%s <- %s, %d, %d", show_pseudo(insn->target), show_pseudo(insn->base), insn->from, insn->len);
+ buf += sprintf(buf, "%s <- (%d) %s, %d", show_pseudo(insn->target), type_size(insn->orig_type), show_pseudo(insn->src), insn->from);
break;
case OP_NOT: case OP_NEG:
@@ -1239,8 +1239,8 @@ static pseudo_t linearize_slice(struct entrypoint *ep, struct expression *expr)
insn->target = new;
insn->from = expr->r_bitpos;
- insn->len = expr->r_nrbits;
- use_pseudo(insn, pre, &insn->base);
+ insn->orig_type = expr->base->ctype;
+ use_pseudo(insn, pre, &insn->src);
add_one_insn(ep, insn);
return new;
}