diff options
| author | Luc Van Oostenryck <luc.vanoostenryck@gmail.com> | 2021-03-05 17:36:37 +0100 |
|---|---|---|
| committer | Luc Van Oostenryck <luc.vanoostenryck@gmail.com> | 2021-03-05 17:36:37 +0100 |
| commit | e0f904856b3d665a84b4342b79967b97a3739545 (patch) | |
| tree | 6bcf9d5aaed252c9416c867e508942d54b97bb65 /linearize.c | |
| parent | 41222364c4a6ba9e515df5eee96ae6262735fdc6 (diff) | |
| parent | 778de2bf52a2bed588d1653aaebe2cbd25f80eac (diff) | |
| download | sparse-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.c | 6 |
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; } |
