From 19ce4d4c4876a925a2e4aa7098b232bb49d00329 Mon Sep 17 00:00:00 2001 From: "Adam C. Foltzer" Date: Mon, 1 Jun 2015 12:33:07 -0700 Subject: [PATCH] fixed replicateV during symbolic simulation Previously this function would always produce a sequence with the "isWord" bit set to False. It now takes a type argument so that it can properly set it to True when the elements are Bits. --- src/Cryptol/Symbolic/Prims.hs | 20 ++++++++++++-------- 1 file changed, 12 insertions(+), 8 deletions(-) diff --git a/src/Cryptol/Symbolic/Prims.hs b/src/Cryptol/Symbolic/Prims.hs index 16625aba2..e653e6ad1 100644 --- a/src/Cryptol/Symbolic/Prims.hs +++ b/src/Cryptol/Symbolic/Prims.hs @@ -11,7 +11,7 @@ {-# LANGUAGE FlexibleContexts #-} module Cryptol.Symbolic.Prims where -import Data.Bits +import Data.Bits () import Data.List (genericDrop, genericReplicate, genericSplitAt, genericTake, sortBy, transpose) import Data.Ord (comparing) @@ -107,8 +107,8 @@ evalECon econ = shl i = case numTValue m of Inf -> dropV i xs - Nat j | i >= j -> replicateV j (zeroV a) - | otherwise -> catV (dropV i xs) (replicateV i (zeroV a)) + Nat j | i >= j -> replicateV j a (zeroV a) + | otherwise -> catV (dropV i xs) (replicateV i a (zeroV a)) ECShiftR -> -- {m,n,a} (fin n) => [m] a -> [n] -> [m] a tlam $ \m -> @@ -123,9 +123,9 @@ evalECon econ = shr :: Integer -> Value shr i = case numTValue m of - Inf -> catV (replicateV i (zeroV a)) xs - Nat j | i >= j -> replicateV j (zeroV a) - | otherwise -> catV (replicateV i (zeroV a)) (takeV (j - i) xs) + Inf -> catV (replicateV i a (zeroV a)) xs + Nat j | i >= j -> replicateV j a (zeroV a) + | otherwise -> catV (replicateV i a (zeroV a)) (takeV (j - i) xs) ECRotL -> -- {m,n,a} (fin m, fin n) => [m] a -> [n] -> [m] a tlam $ \m -> @@ -299,8 +299,12 @@ selectV f v = sel 0 bits where m1 = sel (offset + 2 ^ length bs) bs m2 = sel offset bs -replicateV :: Integer -> Value -> Value -replicateV n x = VSeq False (genericReplicate n x) +replicateV :: Integer -- ^ number of elements + -> TValue -- ^ type of element + -> Value -- ^ element + -> Value +replicateV n (toTypeVal -> TVBit) x = VSeq True (genericReplicate n x) +replicateV n _ x = VSeq False (genericReplicate n x) nth :: a -> [a] -> Int -> a nth def [] _ = def