summaryrefslogtreecommitdiff
path: root/src/gen_lib/sail_string.lem
diff options
context:
space:
mode:
authorJon French2018-05-23 16:51:31 +0100
committerJon French2018-05-23 16:51:31 +0100
commitfd706bc10a21577861d1c909ceeeed523d43dc63 (patch)
tree3c5f752505c3a9377084ec451a343694f98bab12 /src/gen_lib/sail_string.lem
parentac26bb0a957288d2024204046ccf3717c36df870 (diff)
riscv decode now uses mapping-decode and passes tests
Diffstat (limited to 'src/gen_lib/sail_string.lem')
-rw-r--r--src/gen_lib/sail_string.lem15
1 files changed, 13 insertions, 2 deletions
diff --git a/src/gen_lib/sail_string.lem b/src/gen_lib/sail_string.lem
index b1f0fbe3..07b39ddc 100644
--- a/src/gen_lib/sail_string.lem
+++ b/src/gen_lib/sail_string.lem
@@ -66,10 +66,10 @@ let rec n_leading_spaces s =
end
end
-let opt_spaces_matches_prefix s =
+let opt_spc_matches_prefix s =
Just ((), n_leading_spaces s)
-let spaces_matches_prefix s =
+let spc_matches_prefix s =
let n = n_leading_spaces s in
match n with
| 0 -> Nothing
@@ -136,4 +136,15 @@ let hex_bits_21_matches_prefix s =
Nothing
end
+let hex_bits_32_matches_prefix s =
+ match maybe_int_of_prefix s with
+ | Nothing -> Nothing
+ | Just (n, len) ->
+ if 0 <= n && n < 4294967296 then
+ Just ((of_int 2147483648 n, len))
+ else
+ Nothing
+ end
+
+
let string_of_bits = string_of_vec