File: constraint_syn.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 (29 lines) | stat: -rw-r--r-- 446 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
26
27
28
29
default Order dec
$include <prelude.sail>

$option --instantiate xlen=32

type xlen : Int

constraint xlen in {32, 64}

type is_32 : Bool = xlen == 32

type s_xlen : Int = xlen

val test : (bool(is_32), bits(s_xlen)) -> unit

function test(b: bool(is_32), xs: bits(s_xlen)) -> unit = {
  ()
}

val main : unit -> unit

function main() = {
  if sizeof(xlen) == 32 then {
    test(true, 0xFFFF_FFFF)
  };
  if constraint(is_32) then {
    ()
  }
}