diff options
| author | Jon French | 2018-05-23 16:51:31 +0100 |
|---|---|---|
| committer | Jon French | 2018-05-23 16:51:31 +0100 |
| commit | fd706bc10a21577861d1c909ceeeed523d43dc63 (patch) | |
| tree | 3c5f752505c3a9377084ec451a343694f98bab12 /src/gen_lib/sail_string.lem | |
| parent | ac26bb0a957288d2024204046ccf3717c36df870 (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.lem | 15 |
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 |
