File: zeros_mapping.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 (30 lines) | stat: -rw-r--r-- 622 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
default Order dec

$include <prelude.sail>

type regbits = bits(5)

mapping zeros_16 : unit <-> bits(16) = { () <-> 0x0000 }

scattered union ast

val encdec : ast <-> bits(32)

scattered mapping encdec

union clause ast = Add : (regbits, regbits, regbits)

mapping clause encdec = Add(dest, src1, src2) <-> zeros_16() @ dest @ src1 @ src2 @ 0b1

val main : unit -> unit

function main() = {
    let instr = encdec(0x0000FFFF);
    match instr {
        Add(dest, src1, src2) => {
            print_bits("dest = ", dest);
            print_bits("src1 = ", dest);
            print_bits("src2 = ", dest);
        }
    }
}