File: revrev_endianness.unsat.sail

package info (click to toggle)
sail-ocaml 0.19.1%2Bdfsg5-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 18,008 kB
  • sloc: ml: 75,941; ansic: 8,848; python: 1,342; exp: 560; sh: 474; makefile: 218; cpp: 36
file content (25 lines) | stat: -rw-r--r-- 756 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
default Order dec

$include <reverse_endianness.sail>

$property
function prop forall 'n, 'n in {8, 16, 32, 64, 128}. (n: int('n), xs: bits('n)) -> bool = {
  if length(xs) == 8 then {
    let ys: bits(8) = xs;
    reverse_endianness(reverse_endianness(ys)) == ys
  } else if length(xs) == 16 then {
    let ys: bits(16) = xs;
    reverse_endianness(reverse_endianness(ys)) == ys
  } else if length(xs) == 32 then {
    let ys: bits(32) = xs;
    reverse_endianness(reverse_endianness(ys)) == ys
  } else if length(xs) == 64 then {
    let ys: bits(64) = xs;
    reverse_endianness(reverse_endianness(ys)) == ys
  } else if length(xs) == 128 then {
    let ys: bits(128) = xs;
    reverse_endianness(reverse_endianness(ys)) == ys
  } else {
    true
  }
}