From ac8ce901cc5c8de25f63e3fa0e91fb54a71a5fde Mon Sep 17 00:00:00 2001 From: Ryan Scott Date: Tue, 7 Jan 2025 10:37:25 -0600 Subject: [PATCH] Adapt `cryptol-saw-core` to changes from GaloisInc/cryptol#1751 GaloisInc/cryptol#1751 removed the width field from word values, which requires mechanical changes on the `cryptol-saw-core` side to make it build. This bumps the `cryptol` submodule and makes the corresponding code changes. --- cryptol-saw-core/src/Verifier/SAW/Cryptol.hs | 6 +++--- deps/cryptol | 2 +- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/cryptol-saw-core/src/Verifier/SAW/Cryptol.hs b/cryptol-saw-core/src/Verifier/SAW/Cryptol.hs index 476478193e..a8e32683da 100644 --- a/cryptol-saw-core/src/Verifier/SAW/Cryptol.hs +++ b/cryptol-saw-core/src/Verifier/SAW/Cryptol.hs @@ -1910,7 +1910,7 @@ exportValue ty v = case ty of case v of SC.VWord w -> V.word V.Concrete (toInteger (width w)) (unsigned w) SC.VVector xs - | TV.isTBit e -> V.VWord (toInteger (Vector.length xs)) <$> + | TV.isTBit e -> V.VWord <$> V.bitmapWordVal V.Concrete (toInteger (Vector.length xs)) (V.finiteSeqMap V.Concrete . map (V.ready . SC.toBool . SC.runIdentity . force) $ Fold.toList xs) | otherwise -> pure . V.VSeq (toInteger (Vector.length xs)) $ V.finiteSeqMap V.Concrete $ @@ -1977,7 +1977,7 @@ exportFirstOrderValue fv = FOVIntMod _ i -> pure (V.VInteger i) FOVWord w x -> V.word V.Concrete (toInteger w) x FOVVec t vs - | t == FOTBit -> V.VWord len <$> (V.bitmapWordVal V.Concrete len + | t == FOTBit -> V.VWord <$> (V.bitmapWordVal V.Concrete len (V.finiteSeqMap V.Concrete . map (V.ready . fvAsBool) $ vs)) | otherwise -> pure (V.VSeq len (V.finiteSeqMap V.Concrete (map exportFirstOrderValue vs))) where len = toInteger (length vs) @@ -1994,7 +1994,7 @@ importFirstOrderValue t0 v0 = V.runEval mempty (go t0 v0) go t v = case (t,v) of (FOTBit , V.VBit b) -> return (FOVBit b) (FOTInt , V.VInteger i) -> return (FOVInt i) - (FOTVec _ FOTBit, V.VWord w wv) -> FOVWord (fromIntegral w) . V.bvVal <$> (V.asWordVal V.Concrete wv) + (FOTVec _ FOTBit, V.VWord wv) -> FOVWord (fromIntegral (V.wordValWidth wv)) . V.bvVal <$> (V.asWordVal V.Concrete wv) (FOTVec _ ty , V.VSeq len xs) -> FOVVec ty <$> traverse (go ty =<<) (V.enumerateSeqMap len xs) (FOTTuple tys , V.VTuple xs) -> FOVTuple <$> traverse (\(ty, x) -> go ty =<< x) (zip tys xs) (FOTRec fs , V.VRecord xs) -> diff --git a/deps/cryptol b/deps/cryptol index 0985325118..b1bdfd0e3f 160000 --- a/deps/cryptol +++ b/deps/cryptol @@ -1 +1 @@ -Subproject commit 09853251186d4590f3b093dbdf2b324c9a7e6ca0 +Subproject commit b1bdfd0e3ff0ff8d16e94fd6e6402a3d1fb497f2