From 8bf523f8b1567c44ac8c7e424a9e309a50a0f1da Mon Sep 17 00:00:00 2001 From: Iavor Diatchki Date: Wed, 21 Feb 2018 09:47:53 -0800 Subject: [PATCH 1/3] Fill in imitted lemma --- symbolic/src/Data/Macaw/Symbolic/CrucGen.hs | 10 ++++++++-- 1 file changed, 8 insertions(+), 2 deletions(-) diff --git a/symbolic/src/Data/Macaw/Symbolic/CrucGen.hs b/symbolic/src/Data/Macaw/Symbolic/CrucGen.hs index 5fadaab8..df2e44ed 100644 --- a/symbolic/src/Data/Macaw/Symbolic/CrucGen.hs +++ b/symbolic/src/Data/Macaw/Symbolic/CrucGen.hs @@ -586,8 +586,14 @@ appBVAtom :: CrucGen arch ids s (CR.Atom s (MM.LLVMPointerType w)) appBVAtom w app = fromBits w =<< appAtom app -addLemma :: (1 <= x, x + 1 <= y) => p x -> q y -> LeqProof 1 y -addLemma _ _ = undefined +addLemma :: (1 <= x, x + 1 <= y) => NatRepr x -> q y -> LeqProof 1 y +addLemma x y = + leqProof n1 x `leqTrans` + leqAdd (leqRefl x) n1 `leqTrans` + leqProof (addNat x n1) y + where + n1 :: NatRepr 1 + n1 = knownNat -- | Create a crucible value for a bitvector literal. From e3f4e0875ba8c061402b4e2090387089004d4099 Mon Sep 17 00:00:00 2001 From: Iavor Diatchki Date: Wed, 21 Feb 2018 15:06:18 -0800 Subject: [PATCH 2/3] Bugfix and show more info when failing. --- symbolic/src/Data/Macaw/Symbolic/MemOps.hs | 24 ++++++++++++++++------ 1 file changed, 18 insertions(+), 6 deletions(-) diff --git a/symbolic/src/Data/Macaw/Symbolic/MemOps.hs b/symbolic/src/Data/Macaw/Symbolic/MemOps.hs index 605eeb67..45d947be 100644 --- a/symbolic/src/Data/Macaw/Symbolic/MemOps.hs +++ b/symbolic/src/Data/Macaw/Symbolic/MemOps.hs @@ -50,6 +50,7 @@ import Lang.Crucible.LLVM.MemModel.Pointer , pattern LLVMPointer ) import Lang.Crucible.LLVM.MemModel.Type(bitvectorType) +import Lang.Crucible.LLVM.MemModel.Generic(ppPtr) import Lang.Crucible.LLVM.DataLayout(EndianForm(..)) import Lang.Crucible.LLVM.Bytes(toBytes) @@ -71,12 +72,20 @@ type PtrOp sym w a = RegEntry sym (LLVMPointerType w) {- ^ Argument 2 -} -> IO (a, CrucibleState s sym ext rtp blocks r ctx) +binOpLabel :: IsSymInterface sym => + String -> LLVMPtr sym w -> LLVMPtr sym w -> String +binOpLabel lab x y = + unlines [ "{ instruction: " ++ lab + , ", operand 1: " ++ show (ppPtr x) + , ", operand 2: " ++ show (ppPtr y) + , "}" + ] doPtrMux :: Pred sym -> PtrOp sym w (LLVMPtr sym w) doPtrMux c = ptrOp $ \sym _ _ xPtr xBits yPtr yBits x y -> do both_bits <- andPred sym xBits yBits both_ptrs <- andPred sym xPtr yPtr - cases sym "ptr_mux" muxLLVMPtr + cases sym (binOpLabel "ptr_mux" x y) muxLLVMPtr [ both_bits ~> endCase =<< llvmPointer_bv sym =<< bvIte sym c (asBits x) (asBits y) , both_ptrs ~> @@ -89,7 +98,7 @@ doPtrAdd = ptrOp $ \sym mem w xPtr xBits yPtr yBits x y -> ptr_bits <- andPred sym xPtr yBits bits_ptr <- andPred sym xBits yPtr - cases sym "ptr_add" muxLLVMPtr + cases sym (binOpLabel "ptr_add" x y) muxLLVMPtr [ both_bits ~> endCase =<< llvmPointer_bv sym =<< bvAdd sym (asBits x) (asBits y) @@ -111,7 +120,7 @@ doPtrSub = ptrOp $ \sym mem w xPtr xBits yPtr yBits x y -> ptr_bits <- andPred sym xPtr yBits ptr_ptr <- andPred sym xPtr yPtr - cases sym "ptr_sub" muxLLVMPtr + cases sym (binOpLabel "ptr_sub" x y) muxLLVMPtr [ both_bits ~> endCase =<< llvmPointer_bv sym =<< bvSub sym (asBits x) (asBits y) @@ -133,7 +142,8 @@ doPtrLt = ptrOp $ \sym _ _ xPtr xBits yPtr yBits x y -> both_ptrs <- andPred sym xPtr yPtr sameRegion <- natEq sym (ptrBase x) (ptrBase y) ok <- andPred sym sameRegion =<< orPred sym both_bits both_ptrs - addAssertion sym ok (AssertFailureSimError "[ptr_lt] Invalid arguments") + addAssertion sym ok + (AssertFailureSimError (binOpLabel "ptr_lt" x y ++ " Invalid arguments")) bvUlt sym (asBits x) (asBits y) @@ -143,7 +153,9 @@ doPtrLeq = ptrOp $ \sym _ _ xPtr xBits yPtr yBits x y -> both_ptrs <- andPred sym xPtr yPtr sameRegion <- natEq sym (ptrBase x) (ptrBase y) ok <- andPred sym sameRegion =<< orPred sym both_bits both_ptrs - addAssertion sym ok (AssertFailureSimError "[ptr_leq] Invalid arguments") + addAssertion sym ok + (AssertFailureSimError + (binOpLabel "ptr_leq" x y ++ " Invalid arguments")) bvUle sym (asBits x) (asBits y) @@ -151,7 +163,7 @@ doPtrEq :: PtrOp sym w (RegValue sym BoolType) doPtrEq = ptrOp $ \sym _ w xPtr xBits yPtr yBits x y -> do both_bits <- andPred sym xBits yBits both_ptrs <- andPred sym xPtr yPtr - cases sym "ptr_eq" itePred + cases sym (binOpLabel "ptr_eq" x y) itePred [ both_bits ~> endCase =<< bvEq sym (asBits x) (asBits y) , both_ptrs ~> endCase =<< ptrEq sym w x y ] From aac5a3e00f53d00cf8eebd2341f3dd62b5b34b9e Mon Sep 17 00:00:00 2001 From: Iavor Diatchki Date: Wed, 21 Feb 2018 15:24:25 -0800 Subject: [PATCH 3/3] Commit the bug fix. --- symbolic/src/Data/Macaw/Symbolic/MemOps.hs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/symbolic/src/Data/Macaw/Symbolic/MemOps.hs b/symbolic/src/Data/Macaw/Symbolic/MemOps.hs index 45d947be..d348b364 100644 --- a/symbolic/src/Data/Macaw/Symbolic/MemOps.hs +++ b/symbolic/src/Data/Macaw/Symbolic/MemOps.hs @@ -318,7 +318,7 @@ ptrOp k st mvar w x0 y0 = xPtr <- let ?ptrWidth = w in isValidPointer sym x mem yPtr <- let ?ptrWidth = w in isValidPointer sym y mem xBits <- isBitVec sym x - yBits <- isBitVec sym x + yBits <- isBitVec sym y a <- k sym mem w xPtr xBits yPtr yBits x y return (a,st)