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 35 36 37 38 39 40 41 42 43 44 45
|
default Order dec
$include <prelude.sail>
val EXTZ : forall 'n 'm, 0 <= 'n <= 'm. (implicit('m), bits('n)) -> bits('m)
function EXTZ(m, x) = sail_zero_extend(x, m)
val EXTS : forall 'n 'm, 0 <= 'n <= 'm. (implicit('m), bits('n)) -> bits('m)
function EXTS(m, x) = sail_sign_extend(x, m)
val zeros : forall 'n, 'n >= 0. implicit('n) -> bits('n)
function zeros(n) = replicate_bits(0b0, n)
val dzeros : forall 'n 'm, 'n >= 0 & 'm >= 0. (implicit('n), implicit('m)) -> (bits('n), bits('m))
function dzeros(n, m) = (zeros(n), zeros(m))
val dzeros2 : forall 'n 'm, 'n >= 0 & 'm >= 0. (implicit('n), implicit('m), unit) -> (bits('n), bits('m))
function dzeros2(n, m, _) = (zeros(n), zeros(m))
function main((): unit) -> unit = {
let a: bits(64) = EXTZ(0xFF);
let b: bits(64) = EXTS(0xFF);
let c: bits(64) = EXTS(64, 0xFF);
let d: bits(64) = zeros();
let e: bits(64) = zeros(64);
let (f, g): (bits(64), bits(32)) = dzeros();
let (h, i) = dzeros(16, 8);
let (j, k): (bits(4), bits(2)) = dzeros2();
print_bits("a = ", a);
print_bits("b = ", b);
print_bits("c = ", c);
print_bits("d = ", d);
print_bits("e = ", e);
print_bits("f = ", f);
print_bits("g = ", g);
print_bits("h = ", h);
print_bits("i = ", i);
print_bits("j = ", j);
print_bits("k = ", k)
}
|