File: outcome_impl.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 (34 lines) | stat: -rw-r--r-- 691 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
30
31
32
33
34
default Order dec
$include <prelude.sail>

$target_set emulator c ocaml interpreter lem systemverilog

outcome test_ev1 : forall 'n, 'n > 0. ('a, bits('n)) -> unit
with
  'a: Type
= {
    val to_bits : 'a -> bits(64)

    impl emulator(x, y) = {
        match x {
            w: 'a => print_bits("w = ", to_bits(w))
        };
        print_bits("x = ", to_bits(x : 'a));
        let z: bits('n + 8) = 0xFF @ y;
        print_bits("z = ", z)
    }
}

function instance_to_bits(x: bits(32)) -> bits(64) = {
    sail_zero_extend(x, 64)
}

instantiation test_ev1 with
  'a = bits(32),
  to_bits = instance_to_bits

val main : unit -> unit

function main() = {
    test_ev1(0xABCD_0000, 0xFF)
}