From 2906402d86b1349a10d648a496becbcc601faa2f Mon Sep 17 00:00:00 2001 From: Brian Huffman Date: Thu, 29 Apr 2021 10:53:55 -0700 Subject: [PATCH] saw-core-sbv: Handle zero-width bitvectors properly in counterexamples. Fixes #1182. --- saw-core-sbv/src/Verifier/SAW/Simulator/SBV.hs | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/saw-core-sbv/src/Verifier/SAW/Simulator/SBV.hs b/saw-core-sbv/src/Verifier/SAW/Simulator/SBV.hs index d400089d04..a5e65d7f6f 100644 --- a/saw-core-sbv/src/Verifier/SAW/Simulator/SBV.hs +++ b/saw-core-sbv/src/Verifier/SAW/Simulator/SBV.hs @@ -667,6 +667,7 @@ data Labeler = BoolLabel String | IntegerLabel String | WordLabel String + | ZeroWidthWordLabel | VecLabel (Vector Labeler) | TupleLabel (Vector Labeler) | RecLabel (Map FieldName Labeler) @@ -684,7 +685,7 @@ newVars FOTInt = nextId <&> \s-> (IntegerLabel s, vInteger <$> existsSInteger s) newVars (FOTIntMod n) = nextId <&> \s-> (IntegerLabel s, VIntMod n <$> existsSInteger s) newVars (FOTVec n FOTBit) = if n == 0 - then nextId <&> \s-> (WordLabel s, return (vWord (literalSWord 0 0))) + then pure (ZeroWidthWordLabel, pure (vWord (literalSWord 0 0))) else nextId <&> \s-> (WordLabel s, vWord <$> existsSWord s (fromIntegral n)) newVars (FOTVec n tp) = do (labels, vals) <- V.unzip <$> V.replicateM (fromIntegral n) (newVars tp) @@ -718,6 +719,8 @@ getLabels ls d args getLabel (WordLabel s) = FOVWord (cvKind cv) (cvToInteger cv) where cv = d Map.! s + getLabel ZeroWidthWordLabel = FOVWord 0 0 + getLabel (VecLabel ns) | V.null ns = error "getLabel of empty vector" | otherwise = fovVec t vs