File: parameterchoice.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 (20 lines) | stat: -rw-r--r-- 470 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
default Order dec

$include <prelude.sail>

val f : forall 'm 'n, 4 < 'm <= 32 & 4 <= 'n <= 32. (int('m), int('n), bool) -> bits(32)

function f(m,n,b) = {
  let 'p = if b then n else m;
  let x : bits('p) = sail_sign_extend(0b1010, p);
  sail_zero_extend(x, 32)
}

val run : unit -> unit

function run () = {
  assert(f(8,16,false) == 0x000000fa);
  assert(f(8,16,true)  == 0x0000fffa);
  assert(f(16,32,false) == 0x0000fffa);
  assert(f(16,32,true)  == 0xfffffffa);
}