@fluffylabs/anan-as 1.2.0-c2b7f5a → 1.2.0-d2b00f9
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/bin/src/trace-replay.js +3 -1
- package/dist/build/compiler-inline.js +1 -1
- package/dist/build/compiler.d.ts +2 -13
- package/dist/build/compiler.js +1 -25
- package/dist/build/compiler.wasm +0 -0
- package/dist/build/debug-inline.js +1 -1
- package/dist/build/debug-raw-inline.js +1 -1
- package/dist/build/debug-raw.wasm +0 -0
- package/dist/build/debug.wasm +0 -0
- package/dist/build/js/assembly/arguments.js +4 -4
- package/dist/build/js/assembly/instructions/bit.js +22 -22
- package/dist/build/js/assembly/instructions/branch.js +56 -56
- package/dist/build/js/assembly/instructions/jump.js +10 -10
- package/dist/build/js/assembly/instructions/load.js +41 -41
- package/dist/build/js/assembly/instructions/logic.js +20 -20
- package/dist/build/js/assembly/instructions/math.js +105 -105
- package/dist/build/js/assembly/instructions/misc.js +10 -10
- package/dist/build/js/assembly/instructions/mov.js +16 -16
- package/dist/build/js/assembly/instructions/outcome.d.ts +7 -7
- package/dist/build/js/assembly/instructions/outcome.js +63 -36
- package/dist/build/js/assembly/instructions/rot.js +18 -18
- package/dist/build/js/assembly/instructions/set.js +18 -18
- package/dist/build/js/assembly/instructions/shift.js +59 -59
- package/dist/build/js/assembly/instructions/store.js +29 -29
- package/dist/build/js/assembly/instructions/utils.d.ts +6 -4
- package/dist/build/js/assembly/instructions/utils.js +32 -16
- package/dist/build/js/assembly/math.d.ts +6 -8
- package/dist/build/js/assembly/math.js +21 -13
- package/dist/build/js/assembly/memory.js +9 -7
- package/dist/build/js/assembly/program-build.js +4 -4
- package/dist/build/js/assembly/program.js +29 -29
- package/dist/build/js/portable-bundle.js +547 -482
- package/dist/build/release-inline.js +1 -1
- package/dist/build/release-mini-inline.js +1 -1
- package/dist/build/release-mini.wasm +0 -0
- package/dist/build/release-stub-inline.js +1 -1
- package/dist/build/release-stub.wasm +0 -0
- package/dist/build/release.wasm +0 -0
- package/dist/build/test-inline.js +1 -1
- package/dist/build/test.wasm +0 -0
- package/package.json +7 -7
|
Binary file
|
package/dist/build/debug.wasm
CHANGED
|
Binary file
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { IntMath } from "./math";
|
|
2
2
|
import { portable } from "./portable";
|
|
3
3
|
export var Arguments;
|
|
4
4
|
(function (Arguments) {
|
|
@@ -51,7 +51,7 @@ export class Args {
|
|
|
51
51
|
}
|
|
52
52
|
function twoImm(args, code, offset, end) {
|
|
53
53
|
const low = lowNibble(portable.staticArrayAt(code, offset));
|
|
54
|
-
const split = minI32(4, low) + 1;
|
|
54
|
+
const split = IntMath.minI32(4, low) + 1;
|
|
55
55
|
const first = decodeI32(code, offset + 1, offset + split);
|
|
56
56
|
const second = decodeI32(code, offset + split, end);
|
|
57
57
|
return args.fill(first, second, 0, 0);
|
|
@@ -86,7 +86,7 @@ export const DECODERS = StaticArray.fromArray([
|
|
|
86
86
|
(args, data, o, lim) => {
|
|
87
87
|
const h = higNibble(data[o]);
|
|
88
88
|
const l = lowNibble(data[o]);
|
|
89
|
-
const split = minI32(4, h) + 1;
|
|
89
|
+
const split = IntMath.minI32(4, h) + 1;
|
|
90
90
|
const immA = decodeI32(data, o + 1, o + split);
|
|
91
91
|
const immB = decodeI32(data, o + split, lim);
|
|
92
92
|
return args.fill(l, immA, immB, 0);
|
|
@@ -95,7 +95,7 @@ export const DECODERS = StaticArray.fromArray([
|
|
|
95
95
|
(args, data, o, lim) => {
|
|
96
96
|
const h = higNibble(data[o]);
|
|
97
97
|
const l = lowNibble(data[o]);
|
|
98
|
-
const split = minI32(4, h) + 1;
|
|
98
|
+
const split = IntMath.minI32(4, h) + 1;
|
|
99
99
|
const immA = decodeI32(data, o + 1, o + split);
|
|
100
100
|
const offs = decodeI32(data, o + split, lim);
|
|
101
101
|
return args.fill(l, immA, offs, 0);
|
|
@@ -1,53 +1,53 @@
|
|
|
1
1
|
import { portable } from "../portable";
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
2
|
+
import { OutcomeData } from "./outcome";
|
|
3
|
+
import { Inst } from "./utils";
|
|
4
4
|
// COUNT_SET_BITS_64
|
|
5
5
|
export const count_set_bits_64 = (r, args, regs) => {
|
|
6
|
-
regs[reg(args.b)] = portable.popcnt_u64(regs[reg(args.a)]);
|
|
7
|
-
return ok(r);
|
|
6
|
+
regs[Inst.reg(args.b)] = portable.popcnt_u64(regs[Inst.reg(args.a)]);
|
|
7
|
+
return OutcomeData.ok(r);
|
|
8
8
|
};
|
|
9
9
|
// COUNT_SET_BITS_32
|
|
10
10
|
export const count_set_bits_32 = (r, args, regs) => {
|
|
11
|
-
regs[reg(args.b)] = u64(portable.popcnt_u32(u32(regs[reg(args.a)])));
|
|
12
|
-
return ok(r);
|
|
11
|
+
regs[Inst.reg(args.b)] = u64(portable.popcnt_u32(u32(regs[Inst.reg(args.a)])));
|
|
12
|
+
return OutcomeData.ok(r);
|
|
13
13
|
};
|
|
14
14
|
// LEADING_ZERO_BITS_64
|
|
15
15
|
export const leading_zero_bits_64 = (r, args, regs) => {
|
|
16
|
-
regs[reg(args.b)] = portable.clz_u64(regs[reg(args.a)]);
|
|
17
|
-
return ok(r);
|
|
16
|
+
regs[Inst.reg(args.b)] = portable.clz_u64(regs[Inst.reg(args.a)]);
|
|
17
|
+
return OutcomeData.ok(r);
|
|
18
18
|
};
|
|
19
19
|
// LEADING_ZERO_BITS_32
|
|
20
20
|
export const leading_zero_bits_32 = (r, args, regs) => {
|
|
21
|
-
regs[reg(args.b)] = u64(portable.clz_u32(u32(regs[reg(args.a)])));
|
|
22
|
-
return ok(r);
|
|
21
|
+
regs[Inst.reg(args.b)] = u64(portable.clz_u32(u32(regs[Inst.reg(args.a)])));
|
|
22
|
+
return OutcomeData.ok(r);
|
|
23
23
|
};
|
|
24
24
|
// TRAILING_ZERO_BITS_64
|
|
25
25
|
export const trailing_zero_bits_64 = (r, args, regs) => {
|
|
26
|
-
regs[reg(args.b)] = portable.ctz_u64(regs[reg(args.a)]);
|
|
27
|
-
return ok(r);
|
|
26
|
+
regs[Inst.reg(args.b)] = portable.ctz_u64(regs[Inst.reg(args.a)]);
|
|
27
|
+
return OutcomeData.ok(r);
|
|
28
28
|
};
|
|
29
29
|
// TRAILING_ZERO_BITS_32
|
|
30
30
|
export const trailing_zero_bits_32 = (r, args, regs) => {
|
|
31
|
-
regs[reg(args.b)] = u64(portable.ctz_u32(u32(regs[reg(args.a)])));
|
|
32
|
-
return ok(r);
|
|
31
|
+
regs[Inst.reg(args.b)] = u64(portable.ctz_u32(u32(regs[Inst.reg(args.a)])));
|
|
32
|
+
return OutcomeData.ok(r);
|
|
33
33
|
};
|
|
34
34
|
// SIGN_EXTEND_8
|
|
35
35
|
export const sign_extend_8 = (r, args, regs) => {
|
|
36
|
-
regs[reg(args.b)] = u8SignExtend(u8(regs[reg(args.a)]));
|
|
37
|
-
return ok(r);
|
|
36
|
+
regs[Inst.reg(args.b)] = Inst.u8SignExtend(u8(regs[Inst.reg(args.a)]));
|
|
37
|
+
return OutcomeData.ok(r);
|
|
38
38
|
};
|
|
39
39
|
// SIGN_EXTEND_16
|
|
40
40
|
export const sign_extend_16 = (r, args, regs) => {
|
|
41
|
-
regs[reg(args.b)] = u16SignExtend(u16(regs[reg(args.a)]));
|
|
42
|
-
return ok(r);
|
|
41
|
+
regs[Inst.reg(args.b)] = Inst.u16SignExtend(u16(regs[Inst.reg(args.a)]));
|
|
42
|
+
return OutcomeData.ok(r);
|
|
43
43
|
};
|
|
44
44
|
// ZERO_EXTEND_16
|
|
45
45
|
export const zero_extend_16 = (r, args, regs) => {
|
|
46
|
-
regs[reg(args.b)] = u64(u16(regs[reg(args.a)]));
|
|
47
|
-
return ok(r);
|
|
46
|
+
regs[Inst.reg(args.b)] = u64(u16(regs[Inst.reg(args.a)]));
|
|
47
|
+
return OutcomeData.ok(r);
|
|
48
48
|
};
|
|
49
49
|
// REVERSE_BYTES
|
|
50
50
|
export const reverse_bytes = (r, args, regs) => {
|
|
51
|
-
regs[reg(args.b)] = portable.bswap_u64(regs[reg(args.a)]);
|
|
52
|
-
return ok(r);
|
|
51
|
+
regs[Inst.reg(args.b)] = portable.bswap_u64(regs[Inst.reg(args.a)]);
|
|
52
|
+
return OutcomeData.ok(r);
|
|
53
53
|
};
|
|
@@ -1,120 +1,120 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
1
|
+
import { OutcomeData } from "./outcome";
|
|
2
|
+
import { Inst } from "./utils";
|
|
3
3
|
// BRANCH_EQ_IMM
|
|
4
4
|
export const branch_eq_imm = (r, args, registers) => {
|
|
5
|
-
const b = u64(u32SignExtend(args.b));
|
|
6
|
-
if (registers[reg(args.a)] === b) {
|
|
7
|
-
return staticJump(r, args.c);
|
|
5
|
+
const b = u64(Inst.u32SignExtend(args.b));
|
|
6
|
+
if (registers[Inst.reg(args.a)] === b) {
|
|
7
|
+
return OutcomeData.staticJump(r, args.c);
|
|
8
8
|
}
|
|
9
|
-
return ok(r);
|
|
9
|
+
return OutcomeData.ok(r);
|
|
10
10
|
};
|
|
11
11
|
// BRANCH_NE_IMM
|
|
12
12
|
export const branch_ne_imm = (r, args, registers) => {
|
|
13
|
-
const b = u64(u32SignExtend(args.b));
|
|
14
|
-
if (registers[reg(args.a)] !== b) {
|
|
15
|
-
return staticJump(r, args.c);
|
|
13
|
+
const b = u64(Inst.u32SignExtend(args.b));
|
|
14
|
+
if (registers[Inst.reg(args.a)] !== b) {
|
|
15
|
+
return OutcomeData.staticJump(r, args.c);
|
|
16
16
|
}
|
|
17
|
-
return ok(r);
|
|
17
|
+
return OutcomeData.ok(r);
|
|
18
18
|
};
|
|
19
19
|
// BRANCH_LT_U_IMM
|
|
20
20
|
export const branch_lt_u_imm = (r, args, registers) => {
|
|
21
|
-
const b = u64(u32SignExtend(args.b));
|
|
22
|
-
if (registers[reg(args.a)] < b) {
|
|
23
|
-
return staticJump(r, args.c);
|
|
21
|
+
const b = u64(Inst.u32SignExtend(args.b));
|
|
22
|
+
if (registers[Inst.reg(args.a)] < b) {
|
|
23
|
+
return OutcomeData.staticJump(r, args.c);
|
|
24
24
|
}
|
|
25
|
-
return ok(r);
|
|
25
|
+
return OutcomeData.ok(r);
|
|
26
26
|
};
|
|
27
27
|
// BRANCH_LE_U_IMM
|
|
28
28
|
export const branch_le_u_imm = (r, args, registers) => {
|
|
29
|
-
const b = u64(u32SignExtend(args.b));
|
|
30
|
-
if (registers[reg(args.a)] <= b) {
|
|
31
|
-
return staticJump(r, args.c);
|
|
29
|
+
const b = u64(Inst.u32SignExtend(args.b));
|
|
30
|
+
if (registers[Inst.reg(args.a)] <= b) {
|
|
31
|
+
return OutcomeData.staticJump(r, args.c);
|
|
32
32
|
}
|
|
33
|
-
return ok(r);
|
|
33
|
+
return OutcomeData.ok(r);
|
|
34
34
|
};
|
|
35
35
|
// BRANCH_GE_U_IMM
|
|
36
36
|
export const branch_ge_u_imm = (r, args, registers) => {
|
|
37
|
-
const b = u64(u32SignExtend(args.b));
|
|
38
|
-
if (registers[reg(args.a)] >= b) {
|
|
39
|
-
return staticJump(r, args.c);
|
|
37
|
+
const b = u64(Inst.u32SignExtend(args.b));
|
|
38
|
+
if (registers[Inst.reg(args.a)] >= b) {
|
|
39
|
+
return OutcomeData.staticJump(r, args.c);
|
|
40
40
|
}
|
|
41
|
-
return ok(r);
|
|
41
|
+
return OutcomeData.ok(r);
|
|
42
42
|
};
|
|
43
43
|
// BRANCH_GT_U_IMM
|
|
44
44
|
export const branch_gt_u_imm = (r, args, registers) => {
|
|
45
|
-
const b = u64(u32SignExtend(args.b));
|
|
46
|
-
if (registers[reg(args.a)] > b) {
|
|
47
|
-
return staticJump(r, args.c);
|
|
45
|
+
const b = u64(Inst.u32SignExtend(args.b));
|
|
46
|
+
if (registers[Inst.reg(args.a)] > b) {
|
|
47
|
+
return OutcomeData.staticJump(r, args.c);
|
|
48
48
|
}
|
|
49
|
-
return ok(r);
|
|
49
|
+
return OutcomeData.ok(r);
|
|
50
50
|
};
|
|
51
51
|
// BRANCH_LT_S_IMM
|
|
52
52
|
export const branch_lt_s_imm = (r, args, registers) => {
|
|
53
|
-
if (i64(registers[reg(args.a)]) < i64(u32SignExtend(args.b))) {
|
|
54
|
-
return staticJump(r, args.c);
|
|
53
|
+
if (i64(registers[Inst.reg(args.a)]) < i64(Inst.u32SignExtend(args.b))) {
|
|
54
|
+
return OutcomeData.staticJump(r, args.c);
|
|
55
55
|
}
|
|
56
|
-
return ok(r);
|
|
56
|
+
return OutcomeData.ok(r);
|
|
57
57
|
};
|
|
58
58
|
// BRANCH_LE_S_IMM
|
|
59
59
|
export const branch_le_s_imm = (r, args, registers) => {
|
|
60
|
-
if (i64(registers[reg(args.a)]) <= i64(u32SignExtend(args.b))) {
|
|
61
|
-
return staticJump(r, args.c);
|
|
60
|
+
if (i64(registers[Inst.reg(args.a)]) <= i64(Inst.u32SignExtend(args.b))) {
|
|
61
|
+
return OutcomeData.staticJump(r, args.c);
|
|
62
62
|
}
|
|
63
|
-
return ok(r);
|
|
63
|
+
return OutcomeData.ok(r);
|
|
64
64
|
};
|
|
65
65
|
// BRANCH_GE_S_IMM
|
|
66
66
|
export const branch_ge_s_imm = (r, args, registers) => {
|
|
67
|
-
if (i64(registers[reg(args.a)]) >= i64(u32SignExtend(args.b))) {
|
|
68
|
-
return staticJump(r, args.c);
|
|
67
|
+
if (i64(registers[Inst.reg(args.a)]) >= i64(Inst.u32SignExtend(args.b))) {
|
|
68
|
+
return OutcomeData.staticJump(r, args.c);
|
|
69
69
|
}
|
|
70
|
-
return ok(r);
|
|
70
|
+
return OutcomeData.ok(r);
|
|
71
71
|
};
|
|
72
72
|
// BRANCH_GT_S_IMM
|
|
73
73
|
export const branch_gt_s_imm = (r, args, registers) => {
|
|
74
|
-
if (i64(registers[reg(args.a)]) > i64(u32SignExtend(args.b))) {
|
|
75
|
-
return staticJump(r, args.c);
|
|
74
|
+
if (i64(registers[Inst.reg(args.a)]) > i64(Inst.u32SignExtend(args.b))) {
|
|
75
|
+
return OutcomeData.staticJump(r, args.c);
|
|
76
76
|
}
|
|
77
|
-
return ok(r);
|
|
77
|
+
return OutcomeData.ok(r);
|
|
78
78
|
};
|
|
79
79
|
// BRANCH_EQ
|
|
80
80
|
export const branch_eq = (r, args, registers) => {
|
|
81
|
-
if (registers[reg(args.a)] === registers[reg(args.b)]) {
|
|
82
|
-
return staticJump(r, args.c);
|
|
81
|
+
if (registers[Inst.reg(args.a)] === registers[Inst.reg(args.b)]) {
|
|
82
|
+
return OutcomeData.staticJump(r, args.c);
|
|
83
83
|
}
|
|
84
|
-
return ok(r);
|
|
84
|
+
return OutcomeData.ok(r);
|
|
85
85
|
};
|
|
86
86
|
// BRANCH_NE
|
|
87
87
|
export const branch_ne = (r, args, registers) => {
|
|
88
|
-
if (registers[reg(args.a)] !== registers[reg(args.b)]) {
|
|
89
|
-
return staticJump(r, args.c);
|
|
88
|
+
if (registers[Inst.reg(args.a)] !== registers[Inst.reg(args.b)]) {
|
|
89
|
+
return OutcomeData.staticJump(r, args.c);
|
|
90
90
|
}
|
|
91
|
-
return ok(r);
|
|
91
|
+
return OutcomeData.ok(r);
|
|
92
92
|
};
|
|
93
93
|
// BRANCH_LT_U
|
|
94
94
|
export const branch_lt_u = (r, args, registers) => {
|
|
95
|
-
if (registers[reg(args.b)] < registers[reg(args.a)]) {
|
|
96
|
-
return staticJump(r, args.c);
|
|
95
|
+
if (registers[Inst.reg(args.b)] < registers[Inst.reg(args.a)]) {
|
|
96
|
+
return OutcomeData.staticJump(r, args.c);
|
|
97
97
|
}
|
|
98
|
-
return ok(r);
|
|
98
|
+
return OutcomeData.ok(r);
|
|
99
99
|
};
|
|
100
100
|
// BRANCH_LT_S
|
|
101
101
|
export const branch_lt_s = (r, args, registers) => {
|
|
102
|
-
if (i64(registers[reg(args.b)]) < i64(registers[reg(args.a)])) {
|
|
103
|
-
return staticJump(r, args.c);
|
|
102
|
+
if (i64(registers[Inst.reg(args.b)]) < i64(registers[Inst.reg(args.a)])) {
|
|
103
|
+
return OutcomeData.staticJump(r, args.c);
|
|
104
104
|
}
|
|
105
|
-
return ok(r);
|
|
105
|
+
return OutcomeData.ok(r);
|
|
106
106
|
};
|
|
107
107
|
// BRANCH_GE_U
|
|
108
108
|
export const branch_ge_u = (r, args, registers) => {
|
|
109
|
-
if (registers[reg(args.b)] >= registers[reg(args.a)]) {
|
|
110
|
-
return staticJump(r, args.c);
|
|
109
|
+
if (registers[Inst.reg(args.b)] >= registers[Inst.reg(args.a)]) {
|
|
110
|
+
return OutcomeData.staticJump(r, args.c);
|
|
111
111
|
}
|
|
112
|
-
return ok(r);
|
|
112
|
+
return OutcomeData.ok(r);
|
|
113
113
|
};
|
|
114
114
|
// BRANCH_GE_S
|
|
115
115
|
export const branch_ge_s = (r, args, registers) => {
|
|
116
|
-
if (i64(registers[reg(args.b)]) >= i64(registers[reg(args.a)])) {
|
|
117
|
-
return staticJump(r, args.c);
|
|
116
|
+
if (i64(registers[Inst.reg(args.b)]) >= i64(registers[Inst.reg(args.a)])) {
|
|
117
|
+
return OutcomeData.staticJump(r, args.c);
|
|
118
118
|
}
|
|
119
|
-
return ok(r);
|
|
119
|
+
return OutcomeData.ok(r);
|
|
120
120
|
};
|
|
@@ -1,21 +1,21 @@
|
|
|
1
1
|
import { portable } from "../portable";
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
2
|
+
import { OutcomeData } from "./outcome";
|
|
3
|
+
import { Inst } from "./utils";
|
|
4
4
|
// JUMP
|
|
5
|
-
export const jump = (r, args) => staticJump(r, args.a);
|
|
5
|
+
export const jump = (r, args) => OutcomeData.staticJump(r, args.a);
|
|
6
6
|
// JUMP_IND
|
|
7
7
|
export const jump_ind = (r, args, registers) => {
|
|
8
|
-
const address = u32(portable.u64_add(registers[reg(args.a)], u32SignExtend(args.b)));
|
|
9
|
-
return dJump(r, address);
|
|
8
|
+
const address = u32(portable.u64_add(registers[Inst.reg(args.a)], Inst.u32SignExtend(args.b)));
|
|
9
|
+
return OutcomeData.dJump(r, address);
|
|
10
10
|
};
|
|
11
11
|
// LOAD_IMM_JUMP
|
|
12
12
|
export const load_imm_jump = (r, args, registers) => {
|
|
13
|
-
registers[reg(args.a)] = u32SignExtend(args.b);
|
|
14
|
-
return staticJump(r, args.c);
|
|
13
|
+
registers[Inst.reg(args.a)] = Inst.u32SignExtend(args.b);
|
|
14
|
+
return OutcomeData.staticJump(r, args.c);
|
|
15
15
|
};
|
|
16
16
|
// LOAD_IMM_JUMP_IND
|
|
17
17
|
export const load_imm_jump_ind = (r, args, registers) => {
|
|
18
|
-
const address = u32(portable.u64_add(registers[reg(args.a)], u32SignExtend(args.d)));
|
|
19
|
-
registers[reg(args.b)] = u32SignExtend(args.c);
|
|
20
|
-
return dJump(r, address);
|
|
18
|
+
const address = u32(portable.u64_add(registers[Inst.reg(args.a)], Inst.u32SignExtend(args.d)));
|
|
19
|
+
registers[Inst.reg(args.b)] = Inst.u32SignExtend(args.c);
|
|
20
|
+
return OutcomeData.dJump(r, address);
|
|
21
21
|
};
|
|
@@ -1,134 +1,134 @@
|
|
|
1
1
|
import { MaybePageFault } from "../memory";
|
|
2
2
|
import { portable } from "../portable";
|
|
3
|
-
import {
|
|
4
|
-
import {
|
|
3
|
+
import { OutcomeData } from "./outcome";
|
|
4
|
+
import { Inst } from "./utils";
|
|
5
5
|
const faultRes = new MaybePageFault();
|
|
6
6
|
// LOAD_IMM_64
|
|
7
7
|
export const load_imm_64 = (r, args, registers) => {
|
|
8
|
-
registers[reg(args.a)] = portable.u64_add(u64(args.b), u64(args.c) << u64(32));
|
|
9
|
-
return ok(r);
|
|
8
|
+
registers[Inst.reg(args.a)] = portable.u64_add(u64(args.b), u64(args.c) << u64(32));
|
|
9
|
+
return OutcomeData.ok(r);
|
|
10
10
|
};
|
|
11
11
|
// LOAD_IMM
|
|
12
12
|
export const load_imm = (r, args, registers) => {
|
|
13
|
-
registers[reg(args.a)] = u32SignExtend(args.b);
|
|
14
|
-
return ok(r);
|
|
13
|
+
registers[Inst.reg(args.a)] = Inst.u32SignExtend(args.b);
|
|
14
|
+
return OutcomeData.ok(r);
|
|
15
15
|
};
|
|
16
16
|
// LOAD_U8
|
|
17
17
|
export const load_u8 = (r, args, registers, memory) => {
|
|
18
18
|
const result = memory.getU8(faultRes, args.b);
|
|
19
19
|
if (!faultRes.isFault) {
|
|
20
|
-
registers[reg(args.a)] = result;
|
|
20
|
+
registers[Inst.reg(args.a)] = result;
|
|
21
21
|
}
|
|
22
|
-
return okOrFault(r, faultRes);
|
|
22
|
+
return OutcomeData.okOrFault(r, faultRes);
|
|
23
23
|
};
|
|
24
24
|
// LOAD_I8
|
|
25
25
|
export const load_i8 = (r, args, registers, memory) => {
|
|
26
26
|
const result = memory.getI8(faultRes, args.b);
|
|
27
27
|
if (!faultRes.isFault) {
|
|
28
|
-
registers[reg(args.a)] = result;
|
|
28
|
+
registers[Inst.reg(args.a)] = result;
|
|
29
29
|
}
|
|
30
|
-
return okOrFault(r, faultRes);
|
|
30
|
+
return OutcomeData.okOrFault(r, faultRes);
|
|
31
31
|
};
|
|
32
32
|
// LOAD_U16
|
|
33
33
|
export const load_u16 = (r, args, registers, memory) => {
|
|
34
34
|
const result = memory.getU16(faultRes, args.b);
|
|
35
35
|
if (!faultRes.isFault) {
|
|
36
|
-
registers[reg(args.a)] = result;
|
|
36
|
+
registers[Inst.reg(args.a)] = result;
|
|
37
37
|
}
|
|
38
|
-
return okOrFault(r, faultRes);
|
|
38
|
+
return OutcomeData.okOrFault(r, faultRes);
|
|
39
39
|
};
|
|
40
40
|
// LOAD_I16
|
|
41
41
|
export const load_i16 = (r, args, registers, memory) => {
|
|
42
42
|
const result = memory.getI16(faultRes, args.b);
|
|
43
43
|
if (!faultRes.isFault) {
|
|
44
|
-
registers[reg(args.a)] = result;
|
|
44
|
+
registers[Inst.reg(args.a)] = result;
|
|
45
45
|
}
|
|
46
|
-
return okOrFault(r, faultRes);
|
|
46
|
+
return OutcomeData.okOrFault(r, faultRes);
|
|
47
47
|
};
|
|
48
48
|
// LOAD_U32
|
|
49
49
|
export const load_u32 = (r, args, registers, memory) => {
|
|
50
50
|
const result = memory.getU32(faultRes, args.b);
|
|
51
51
|
if (!faultRes.isFault) {
|
|
52
|
-
registers[reg(args.a)] = result;
|
|
52
|
+
registers[Inst.reg(args.a)] = result;
|
|
53
53
|
}
|
|
54
|
-
return okOrFault(r, faultRes);
|
|
54
|
+
return OutcomeData.okOrFault(r, faultRes);
|
|
55
55
|
};
|
|
56
56
|
// LOAD_I32
|
|
57
57
|
export const load_i32 = (r, args, registers, memory) => {
|
|
58
58
|
const result = memory.getI32(faultRes, args.b);
|
|
59
59
|
if (!faultRes.isFault) {
|
|
60
|
-
registers[reg(args.a)] = result;
|
|
60
|
+
registers[Inst.reg(args.a)] = result;
|
|
61
61
|
}
|
|
62
|
-
return okOrFault(r, faultRes);
|
|
62
|
+
return OutcomeData.okOrFault(r, faultRes);
|
|
63
63
|
};
|
|
64
64
|
// LOAD_U64
|
|
65
65
|
export const load_u64 = (r, args, registers, memory) => {
|
|
66
66
|
const result = memory.getU64(faultRes, args.b);
|
|
67
67
|
if (!faultRes.isFault) {
|
|
68
|
-
registers[reg(args.a)] = result;
|
|
68
|
+
registers[Inst.reg(args.a)] = result;
|
|
69
69
|
}
|
|
70
|
-
return okOrFault(r, faultRes);
|
|
70
|
+
return OutcomeData.okOrFault(r, faultRes);
|
|
71
71
|
};
|
|
72
72
|
// LOAD_IND_U8
|
|
73
73
|
export const load_ind_u8 = (r, args, registers, memory) => {
|
|
74
|
-
const address = u32(portable.u64_add(registers[reg(args.a)], u32SignExtend(args.c)));
|
|
74
|
+
const address = u32(portable.u64_add(registers[Inst.reg(args.a)], Inst.u32SignExtend(args.c)));
|
|
75
75
|
const result = memory.getU8(faultRes, address);
|
|
76
76
|
if (!faultRes.isFault) {
|
|
77
|
-
registers[reg(args.b)] = result;
|
|
77
|
+
registers[Inst.reg(args.b)] = result;
|
|
78
78
|
}
|
|
79
|
-
return okOrFault(r, faultRes);
|
|
79
|
+
return OutcomeData.okOrFault(r, faultRes);
|
|
80
80
|
};
|
|
81
81
|
// LOAD_IND_I8
|
|
82
82
|
export const load_ind_i8 = (r, args, registers, memory) => {
|
|
83
|
-
const address = u32(portable.u64_add(registers[reg(args.a)], u32SignExtend(args.c)));
|
|
83
|
+
const address = u32(portable.u64_add(registers[Inst.reg(args.a)], Inst.u32SignExtend(args.c)));
|
|
84
84
|
const result = memory.getI8(faultRes, address);
|
|
85
85
|
if (!faultRes.isFault) {
|
|
86
|
-
registers[reg(args.b)] = result;
|
|
86
|
+
registers[Inst.reg(args.b)] = result;
|
|
87
87
|
}
|
|
88
|
-
return okOrFault(r, faultRes);
|
|
88
|
+
return OutcomeData.okOrFault(r, faultRes);
|
|
89
89
|
};
|
|
90
90
|
// LOAD_IND_U16
|
|
91
91
|
export const load_ind_u16 = (r, args, registers, memory) => {
|
|
92
|
-
const address = u32(portable.u64_add(registers[reg(args.a)], u32SignExtend(args.c)));
|
|
92
|
+
const address = u32(portable.u64_add(registers[Inst.reg(args.a)], Inst.u32SignExtend(args.c)));
|
|
93
93
|
const result = memory.getU16(faultRes, address);
|
|
94
94
|
if (!faultRes.isFault) {
|
|
95
|
-
registers[reg(args.b)] = result;
|
|
95
|
+
registers[Inst.reg(args.b)] = result;
|
|
96
96
|
}
|
|
97
|
-
return okOrFault(r, faultRes);
|
|
97
|
+
return OutcomeData.okOrFault(r, faultRes);
|
|
98
98
|
};
|
|
99
99
|
// LOAD_IND_I16
|
|
100
100
|
export const load_ind_i16 = (r, args, registers, memory) => {
|
|
101
|
-
const address = u32(portable.u64_add(registers[reg(args.a)], u32SignExtend(args.c)));
|
|
101
|
+
const address = u32(portable.u64_add(registers[Inst.reg(args.a)], Inst.u32SignExtend(args.c)));
|
|
102
102
|
const result = memory.getI16(faultRes, address);
|
|
103
103
|
if (!faultRes.isFault) {
|
|
104
|
-
registers[reg(args.b)] = result;
|
|
104
|
+
registers[Inst.reg(args.b)] = result;
|
|
105
105
|
}
|
|
106
|
-
return okOrFault(r, faultRes);
|
|
106
|
+
return OutcomeData.okOrFault(r, faultRes);
|
|
107
107
|
};
|
|
108
108
|
// LOAD_IND_U32
|
|
109
109
|
export const load_ind_u32 = (r, args, registers, memory) => {
|
|
110
|
-
const address = u32(portable.u64_add(registers[reg(args.a)], u32SignExtend(args.c)));
|
|
110
|
+
const address = u32(portable.u64_add(registers[Inst.reg(args.a)], Inst.u32SignExtend(args.c)));
|
|
111
111
|
const result = memory.getU32(faultRes, address);
|
|
112
112
|
if (!faultRes.isFault) {
|
|
113
|
-
registers[reg(args.b)] = result;
|
|
113
|
+
registers[Inst.reg(args.b)] = result;
|
|
114
114
|
}
|
|
115
|
-
return okOrFault(r, faultRes);
|
|
115
|
+
return OutcomeData.okOrFault(r, faultRes);
|
|
116
116
|
};
|
|
117
117
|
// LOAD_IND_I32
|
|
118
118
|
export const load_ind_i32 = (r, args, registers, memory) => {
|
|
119
|
-
const address = u32(portable.u64_add(registers[reg(args.a)], u32SignExtend(args.c)));
|
|
119
|
+
const address = u32(portable.u64_add(registers[Inst.reg(args.a)], Inst.u32SignExtend(args.c)));
|
|
120
120
|
const result = memory.getI32(faultRes, address);
|
|
121
121
|
if (!faultRes.isFault) {
|
|
122
|
-
registers[reg(args.b)] = result;
|
|
122
|
+
registers[Inst.reg(args.b)] = result;
|
|
123
123
|
}
|
|
124
|
-
return okOrFault(r, faultRes);
|
|
124
|
+
return OutcomeData.okOrFault(r, faultRes);
|
|
125
125
|
};
|
|
126
126
|
// LOAD_IND_U64
|
|
127
127
|
export const load_ind_u64 = (r, args, registers, memory) => {
|
|
128
|
-
const address = u32(portable.u64_add(registers[reg(args.a)], u32SignExtend(args.c)));
|
|
128
|
+
const address = u32(portable.u64_add(registers[Inst.reg(args.a)], Inst.u32SignExtend(args.c)));
|
|
129
129
|
const result = memory.getU64(faultRes, u32(address));
|
|
130
130
|
if (!faultRes.isFault) {
|
|
131
|
-
registers[reg(args.b)] = result;
|
|
131
|
+
registers[Inst.reg(args.b)] = result;
|
|
132
132
|
}
|
|
133
|
-
return okOrFault(r, faultRes);
|
|
133
|
+
return OutcomeData.okOrFault(r, faultRes);
|
|
134
134
|
};
|
|
@@ -1,47 +1,47 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
1
|
+
import { OutcomeData } from "./outcome";
|
|
2
|
+
import { Inst } from "./utils";
|
|
3
3
|
// AND_IMM
|
|
4
4
|
export const and_imm = (r, args, registers) => {
|
|
5
|
-
registers[reg(args.b)] = registers[reg(args.a)] & u32SignExtend(args.c);
|
|
6
|
-
return ok(r);
|
|
5
|
+
registers[Inst.reg(args.b)] = registers[Inst.reg(args.a)] & Inst.u32SignExtend(args.c);
|
|
6
|
+
return OutcomeData.ok(r);
|
|
7
7
|
};
|
|
8
8
|
// XOR_IMM
|
|
9
9
|
export const xor_imm = (r, args, registers) => {
|
|
10
|
-
registers[reg(args.b)] = registers[reg(args.a)] ^ u32SignExtend(args.c);
|
|
11
|
-
return ok(r);
|
|
10
|
+
registers[Inst.reg(args.b)] = registers[Inst.reg(args.a)] ^ Inst.u32SignExtend(args.c);
|
|
11
|
+
return OutcomeData.ok(r);
|
|
12
12
|
};
|
|
13
13
|
// OR_IMM
|
|
14
14
|
export const or_imm = (r, args, registers) => {
|
|
15
|
-
registers[reg(args.b)] = registers[reg(args.a)] | u32SignExtend(args.c);
|
|
16
|
-
return ok(r);
|
|
15
|
+
registers[Inst.reg(args.b)] = registers[Inst.reg(args.a)] | Inst.u32SignExtend(args.c);
|
|
16
|
+
return OutcomeData.ok(r);
|
|
17
17
|
};
|
|
18
18
|
// AND
|
|
19
19
|
export const and = (r, args, registers) => {
|
|
20
|
-
registers[reg(args.c)] = registers[reg(args.b)] & registers[reg(args.a)];
|
|
21
|
-
return ok(r);
|
|
20
|
+
registers[Inst.reg(args.c)] = registers[Inst.reg(args.b)] & registers[Inst.reg(args.a)];
|
|
21
|
+
return OutcomeData.ok(r);
|
|
22
22
|
};
|
|
23
23
|
// XOR
|
|
24
24
|
export const xor = (r, args, registers) => {
|
|
25
|
-
registers[reg(args.c)] = registers[reg(args.b)] ^ registers[reg(args.a)];
|
|
26
|
-
return ok(r);
|
|
25
|
+
registers[Inst.reg(args.c)] = registers[Inst.reg(args.b)] ^ registers[Inst.reg(args.a)];
|
|
26
|
+
return OutcomeData.ok(r);
|
|
27
27
|
};
|
|
28
28
|
// OR
|
|
29
29
|
export const or = (r, args, registers) => {
|
|
30
|
-
registers[reg(args.c)] = registers[reg(args.b)] | registers[reg(args.a)];
|
|
31
|
-
return ok(r);
|
|
30
|
+
registers[Inst.reg(args.c)] = registers[Inst.reg(args.b)] | registers[Inst.reg(args.a)];
|
|
31
|
+
return OutcomeData.ok(r);
|
|
32
32
|
};
|
|
33
33
|
// AND_INV
|
|
34
34
|
export const and_inv = (r, args, registers) => {
|
|
35
|
-
registers[reg(args.c)] = registers[reg(args.b)] & ~registers[reg(args.a)];
|
|
36
|
-
return ok(r);
|
|
35
|
+
registers[Inst.reg(args.c)] = registers[Inst.reg(args.b)] & ~registers[Inst.reg(args.a)];
|
|
36
|
+
return OutcomeData.ok(r);
|
|
37
37
|
};
|
|
38
38
|
// OR_INV
|
|
39
39
|
export const or_inv = (r, args, registers) => {
|
|
40
|
-
registers[reg(args.c)] = u64(registers[reg(args.b)] | ~registers[reg(args.a)]);
|
|
41
|
-
return ok(r);
|
|
40
|
+
registers[Inst.reg(args.c)] = u64(registers[Inst.reg(args.b)] | ~registers[Inst.reg(args.a)]);
|
|
41
|
+
return OutcomeData.ok(r);
|
|
42
42
|
};
|
|
43
43
|
// XNOR
|
|
44
44
|
export const xnor = (r, args, registers) => {
|
|
45
|
-
registers[reg(args.c)] = u64(~(registers[reg(args.b)] ^ registers[reg(args.a)]));
|
|
46
|
-
return ok(r);
|
|
45
|
+
registers[Inst.reg(args.c)] = u64(~(registers[Inst.reg(args.b)] ^ registers[Inst.reg(args.a)]));
|
|
46
|
+
return OutcomeData.ok(r);
|
|
47
47
|
};
|