Skip to content

Commit

Permalink
CN: Add support for bitwise subtraction
Browse files Browse the repository at this point in the history
Fixes #255

Though the test looks like it is for pointer difference, the actual
issue is that the elaboration has `array_shift( a_533, signed int,   0 -
a_534)`, and it is the `0 - a534` which was causing the error.

In principle we can/should have pure subtraction at integer and real
types as well, but this can be generalised later as and when the need
arises.
  • Loading branch information
dc-mak committed Aug 13, 2024
1 parent bb0008d commit a386b73
Show file tree
Hide file tree
Showing 2 changed files with 16 additions and 1 deletion.
6 changes: 5 additions & 1 deletion backend/cn/lib/check.ml
Original file line number Diff line number Diff line change
Expand Up @@ -623,7 +623,11 @@ let rec check_pexpr (pe : BT.t mu_pexpr) (k : IT.t -> unit m) : unit m =
let@ () = WellTyped.ensure_base_type loc ~expect:Bool (bt_of_pexpr pe2) in
check_pexpr pe1 (fun v1 -> check_pexpr pe2 (fun v2 -> k (or_ [ v1; v2 ] loc)))
| OpAdd -> not_yet "OpAdd"
| OpSub -> not_yet "OpSub"
| OpSub ->
let@ () = WellTyped.ensure_bits_type loc expect in
let@ () = WellTyped.ensure_bits_type loc (bt_of_pexpr pe1) in
let@ () = WellTyped.ensure_bits_type loc (bt_of_pexpr pe2) in
check_pexpr pe1 (fun v1 -> check_pexpr pe2 (fun v2 -> k (sub_ (v1, v2) loc)))
| OpMul -> not_yet "OpMul"
| OpRem_f -> not_yet "OpRem_f"
| OpExp -> not_yet "OpExp")
Expand Down
11 changes: 11 additions & 0 deletions tests/cn/ptr_diff2.c
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
int* f(int *p)
/*@ ensures ptr_eq(return, array_shift(p, -1i32)); @*/
{
return p - 1;
}

int main(void)
{
int arr = 0;
f(&arr + 1);
}

0 comments on commit a386b73

Please sign in to comment.