diff options
| author | Alasdair Armstrong | 2019-06-12 17:34:07 +0100 |
|---|---|---|
| committer | Alasdair Armstrong | 2019-06-12 17:34:07 +0100 |
| commit | 22123333fc80bf5d3ee73c6692f3fba44892bcee (patch) | |
| tree | 3c9b2d442f37861cf86e49ae786fe0624f4f4e25 /src | |
| parent | 9a367b2bfed76b0f2ac6db26ea0408227ad93230 (diff) | |
SMT: Fix missing case for append builtin
Diffstat (limited to 'src')
| -rw-r--r-- | src/jib/jib_smt.ml | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/src/jib/jib_smt.ml b/src/jib/jib_smt.ml index 6ace9d96..f9ac05bf 100644 --- a/src/jib/jib_smt.ml +++ b/src/jib/jib_smt.ml @@ -697,6 +697,12 @@ let builtin_append ctx v1 v2 ret_ctyp = Fn ("Bits", [bvadd (bvint ctx.lbits_index (Big_int.of_int n)) (Fn ("len", [smt1])); Extract (lbits_size ctx - 1, 0, Fn ("concat", [Fn ("contents", [smt1]); smt2]))]) + | CT_fbits (n, _), CT_fbits (m, _), CT_lbits _ -> + let smt1 = smt_cval ctx v1 in + let smt2 = smt_cval ctx v2 in + Fn ("Bits", [bvint ctx.lbits_index (Big_int.of_int (n + m)); + unsigned_size ctx (lbits_size ctx) (n + m) (Fn ("concat", [smt1; smt2]))]) + | CT_lbits _, CT_lbits _, CT_lbits _ -> let smt1 = smt_cval ctx v1 in let smt2 = smt_cval ctx v2 in |
