diff options
author | Luc Van Oostenryck <luc.vanoostenryck@gmail.com> | 2021-07-09 22:09:07 +0200 |
---|---|---|
committer | Luc Van Oostenryck <luc.vanoostenryck@gmail.com> | 2021-07-27 00:52:20 +0200 |
commit | 732bc04e6123bd742cc569c2b06ba23fbcae3898 (patch) | |
tree | e9b730abc3f01560915aa9125246c3b74fdb1a65 | |
parent | 918e9a4cface92c0a2ccec9479ef1ff77d75f18d (diff) | |
download | sparse-732bc04e6123bd742cc569c2b06ba23fbcae3898.tar.gz |
scheck: mkvar() with target or input type
Most instructions have one associated type, the 'target type'.
Some, like compares, have another one too, the 'input type'.
So, when creating a bitvector from an instruction, we need to specify
the type in some way.
So, create an helper for both cases: mktvar() and mkivar().
Signed-off-by: Luc Van Oostenryck <luc.vanoostenryck@gmail.com>
-rw-r--r-- | scheck.c | 12 |
1 files changed, 12 insertions, 0 deletions
@@ -70,6 +70,18 @@ static BoolectorNode *mkvar(Btor *btor, BoolectorSort s, pseudo_t pseudo) return pseudo->priv = n; } +static BoolectorNode *mktvar(Btor *btor, struct instruction *insn, pseudo_t src) +{ + BoolectorSort s = get_sort(btor, insn->type, insn->pos); + return mkvar(btor, s, src); +} + +static BoolectorNode *mkivar(Btor *btor, struct instruction *insn, pseudo_t src) +{ + BoolectorSort s = get_sort(btor, insn->itype, insn->pos); + return mkvar(btor, s, src); +} + static BoolectorNode *get_arg(Btor *btor, struct instruction *insn, int idx) { pseudo_t arg = ptr_list_nth(insn->arguments, idx); |