From fbaf190269a3ef14f3acbfde1b786c33d2222e59 Mon Sep 17 00:00:00 2001 From: Ivan Gotovchits Date: Fri, 29 May 2020 14:40:48 -0400 Subject: [PATCH] fixes trivial assertions (#1108) If an assertion doesn't contain a symbolic value then we were having an empty set of constraints, which trivially were true. In other words, `assert true` doesn't hold. This PR fixes this by treating non-symbolic values as symbolic constants. --- .../primus_symbolic_executor_main.ml | 17 +++++++++-------- 1 file changed, 9 insertions(+), 8 deletions(-) diff --git a/plugins/primus_symbolic_executor/primus_symbolic_executor_main.ml b/plugins/primus_symbolic_executor/primus_symbolic_executor_main.ml index 9fdeb03df..8878d6a1c 100644 --- a/plugins/primus_symbolic_executor/primus_symbolic_executor_main.ml +++ b/plugins/primus_symbolic_executor/primus_symbolic_executor_main.ml @@ -940,6 +940,12 @@ module SymbolicPrimitives(Machine : Primus.Machine.S) = struct >>= fun () -> Val.b1 + let assertion_of_value x = + Executor.value x >>| (function + | None -> SMT.word (Primus.Value.to_word x) + | Some x -> x) >>| + SMT.formula ~refute:true + (* we can later add operators that manipulate the scopes in which the assertion is checked *) let assert_ name assertions = @@ -948,17 +954,12 @@ module SymbolicPrimitives(Machine : Primus.Machine.S) = struct Constraints.get Context.Scope.path >>= fun path -> let constraints = Set.to_list @@ Set.union user path in Machine.List.fold assertions ~init:constraints - ~f:(fun constraints assertion -> - Executor.value assertion >>| function - | None -> constraints - | Some expr -> - - SMT.formula ~refute:true expr :: constraints) >>| - SMT.check >>= function + ~f:(fun constraints x -> + assertion_of_value x >>| fun assertion -> + assertion :: constraints) >>| SMT.check >>= function | None -> Machine.return () | Some model -> Val.Symbol.of_value name >>= fun name -> - Debug.msg "%s doesn't hold!" name >>= fun () -> Executor.inputs >>| Seq.to_list >>= fun inputs -> report (name,model,inputs)) >>= fun () -> Val.b1