mirror of
https://github.com/kmc7468/cs420.git
synced 2025-12-14 22:38:46 +00:00
Update grader
This commit is contained in:
1
Cargo.lock
generated
1
Cargo.lock
generated
@@ -160,6 +160,7 @@ dependencies = [
|
|||||||
"lang-c 0.8.1 (registry+https://github.com/rust-lang/crates.io-index)",
|
"lang-c 0.8.1 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"ordered-float 1.0.2 (registry+https://github.com/rust-lang/crates.io-index)",
|
"ordered-float 1.0.2 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"peg 0.6.2 (registry+https://github.com/rust-lang/crates.io-index)",
|
"peg 0.6.2 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
|
"rand 0.7.3 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"tempfile 3.1.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
"tempfile 3.1.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
"wait-timeout 0.2.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
"wait-timeout 0.2.0 (registry+https://github.com/rust-lang/crates.io-index)",
|
||||||
]
|
]
|
||||||
|
|||||||
@@ -33,3 +33,4 @@ ordered-float = "1.0"
|
|||||||
hexf = "0.1.0"
|
hexf = "0.1.0"
|
||||||
wait-timeout = "0.2.0"
|
wait-timeout = "0.2.0"
|
||||||
peg = "0.6.2"
|
peg = "0.6.2"
|
||||||
|
rand = "0.7"
|
||||||
|
|||||||
@@ -1,13 +1,16 @@
|
|||||||
|
int nonce; // For random input
|
||||||
|
|
||||||
int main() {
|
int main() {
|
||||||
int i;
|
int i;
|
||||||
int p = 2;
|
int p = 2;
|
||||||
int q = 5;
|
int q = 5;
|
||||||
int r = (0 ? ((p > q) ? (p -= 2) : (p += 2)) : (p + q));
|
int r = (0 ? ((p > q) ? (p -= 2) : (p += 2)) : (p + q));
|
||||||
|
int loop_num = nonce % 100;
|
||||||
|
|
||||||
for (i = 0; i < 11; ((i % 2) ? (i += 2) : ++i)) {
|
for (i = 0; i < loop_num; ((i % 2) ? (i += 2) : ++i)) {
|
||||||
if (i % 2) { p += q; }
|
if (i % 2) { p += q; }
|
||||||
else { p += r; }
|
else { p += r; }
|
||||||
}
|
}
|
||||||
|
|
||||||
return p == 34;
|
return p;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,3 +1,5 @@
|
|||||||
|
int nonce; // For random input
|
||||||
|
|
||||||
int fibonacci(int n) {
|
int fibonacci(int n) {
|
||||||
if (n < 2) {
|
if (n < 2) {
|
||||||
return n;
|
return n;
|
||||||
@@ -7,5 +9,6 @@ int fibonacci(int n) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
int main() {
|
int main() {
|
||||||
return fibonacci(9) == 34;
|
int number = nonce % 20;
|
||||||
|
return fibonacci(number);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,3 +1,4 @@
|
|||||||
|
int nonce; // For random input
|
||||||
int g = 10;
|
int g = 10;
|
||||||
|
|
||||||
int foo(int, int k);
|
int foo(int, int k);
|
||||||
@@ -5,9 +6,9 @@ int foo(int, int k);
|
|||||||
int main() {
|
int main() {
|
||||||
int i = g;
|
int i = g;
|
||||||
|
|
||||||
return foo(i, i) == 30;
|
return foo(i, i);
|
||||||
}
|
}
|
||||||
|
|
||||||
int foo(int i, int j) {
|
int foo(int i, int j) {
|
||||||
return i + j + g;
|
return i + j + nonce;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,5 +1,7 @@
|
|||||||
|
int nonce; // For random input
|
||||||
|
|
||||||
int main()
|
int main()
|
||||||
{
|
{
|
||||||
int x = 1;
|
int x = nonce;
|
||||||
return 1;
|
return x;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,21 +1,24 @@
|
|||||||
|
int nonce; // For random input
|
||||||
|
|
||||||
int foo() {
|
int foo() {
|
||||||
int sum = 0;
|
int sum = 0;
|
||||||
int i = 0;
|
int i = 0;
|
||||||
|
int continue_num = nonce % 98;
|
||||||
|
|
||||||
while(i < 10) {
|
while(i < 100) {
|
||||||
if(i == 3) {
|
if(i == continue_num) {
|
||||||
i++;
|
i++;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
sum += i;
|
sum += i;
|
||||||
i++;
|
i++;
|
||||||
|
|
||||||
if(i == 5) break;
|
if(i == continue_num + 2) break;
|
||||||
}
|
}
|
||||||
|
|
||||||
return sum;
|
return sum;
|
||||||
}
|
}
|
||||||
|
|
||||||
int main() {
|
int main() {
|
||||||
return foo() == 7;
|
return foo();
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,3 +1,4 @@
|
|||||||
|
var i32 @nonce = default
|
||||||
|
|
||||||
fun i32 @main () {
|
fun i32 @main () {
|
||||||
init:
|
init:
|
||||||
@@ -9,7 +10,8 @@ init:
|
|||||||
%l3:i32:r
|
%l3:i32:r
|
||||||
%l4:i32:t0
|
%l4:i32:t0
|
||||||
%l5:i32:t1
|
%l5:i32:t1
|
||||||
%l6:i32:t2
|
%l6:i32:loop_num
|
||||||
|
%l7:i32:t2
|
||||||
|
|
||||||
block b0:
|
block b0:
|
||||||
%b0:i0:unit = store 2:i32 %l1:i32*
|
%b0:i0:unit = store 2:i32 %l1:i32*
|
||||||
@@ -33,6 +35,9 @@ block b2:
|
|||||||
block b3:
|
block b3:
|
||||||
%b3:i0:i32 = load %l5:i32*
|
%b3:i0:i32 = load %l5:i32*
|
||||||
%b3:i1:unit = store %b3:i0:i32 %l3:i32*
|
%b3:i1:unit = store %b3:i0:i32 %l3:i32*
|
||||||
|
%b3:i2:i32 = load @nonce:i32*
|
||||||
|
%b3:i3:i32 = mod %b3:i2:i32 100:i32
|
||||||
|
%b3:i4:unit = store %b3:i3:i32 %l6:i32*
|
||||||
j b7()
|
j b7()
|
||||||
|
|
||||||
block b4:
|
block b4:
|
||||||
@@ -60,8 +65,9 @@ block b7:
|
|||||||
|
|
||||||
block b8:
|
block b8:
|
||||||
%b8:i0:i32 = load %l0:i32*
|
%b8:i0:i32 = load %l0:i32*
|
||||||
%b8:i1:u1 = cmp lt %b8:i0:i32 11:i32
|
%b8:i1:i32 = load %l6:i32*
|
||||||
br %b8:i1:u1, b9(), b11()
|
%b8:i2:u1 = cmp lt %b8:i0:i32 %b8:i1:i32
|
||||||
|
br %b8:i2:u1, b9(), b11()
|
||||||
|
|
||||||
block b9:
|
block b9:
|
||||||
%b9:i0:i32 = load %l0:i32*
|
%b9:i0:i32 = load %l0:i32*
|
||||||
@@ -77,9 +83,7 @@ block b10:
|
|||||||
|
|
||||||
block b11:
|
block b11:
|
||||||
%b11:i0:i32 = load %l1:i32*
|
%b11:i0:i32 = load %l1:i32*
|
||||||
%b11:i1:u1 = cmp eq %b11:i0:i32 34:i32
|
ret %b11:i0:i32
|
||||||
%b11:i2:i32 = typecast %b11:i1:u1 to i32
|
|
||||||
ret %b11:i2:i32
|
|
||||||
|
|
||||||
block b12:
|
block b12:
|
||||||
%b12:i0:i32 = load %l1:i32*
|
%b12:i0:i32 = load %l1:i32*
|
||||||
@@ -102,18 +106,18 @@ block b15:
|
|||||||
%b15:i0:i32 = load %l0:i32*
|
%b15:i0:i32 = load %l0:i32*
|
||||||
%b15:i1:i32 = add %b15:i0:i32 2:i32
|
%b15:i1:i32 = add %b15:i0:i32 2:i32
|
||||||
%b15:i2:unit = store %b15:i1:i32 %l0:i32*
|
%b15:i2:unit = store %b15:i1:i32 %l0:i32*
|
||||||
%b15:i3:unit = store %b15:i1:i32 %l6:i32*
|
%b15:i3:unit = store %b15:i1:i32 %l7:i32*
|
||||||
j b17()
|
j b17()
|
||||||
|
|
||||||
block b16:
|
block b16:
|
||||||
%b16:i0:i32 = load %l0:i32*
|
%b16:i0:i32 = load %l0:i32*
|
||||||
%b16:i1:i32 = add %b16:i0:i32 1:i32
|
%b16:i1:i32 = add %b16:i0:i32 1:i32
|
||||||
%b16:i2:unit = store %b16:i1:i32 %l0:i32*
|
%b16:i2:unit = store %b16:i1:i32 %l0:i32*
|
||||||
%b16:i3:unit = store %b16:i1:i32 %l6:i32*
|
%b16:i3:unit = store %b16:i1:i32 %l7:i32*
|
||||||
j b17()
|
j b17()
|
||||||
|
|
||||||
block b17:
|
block b17:
|
||||||
%b17:i0:i32 = load %l6:i32*
|
%b17:i0:i32 = load %l7:i32*
|
||||||
j b8()
|
j b8()
|
||||||
|
|
||||||
block b18:
|
block b18:
|
||||||
|
|||||||
@@ -1,3 +1,4 @@
|
|||||||
|
var i32 @nonce = default
|
||||||
|
|
||||||
fun i32 @fibonacci (i32) {
|
fun i32 @fibonacci (i32) {
|
||||||
init:
|
init:
|
||||||
@@ -40,13 +41,15 @@ fun i32 @main () {
|
|||||||
init:
|
init:
|
||||||
bid: b0
|
bid: b0
|
||||||
allocations:
|
allocations:
|
||||||
|
%l0:i32:number
|
||||||
|
|
||||||
block b0:
|
block b0:
|
||||||
%b0:i0:i32 = call @fibonacci:[ret:i32 params:(i32)]*(9:i32)
|
%b0:i0:i32 = load @nonce:i32*
|
||||||
%b0:i1:u1 = cmp eq %b0:i0:i32 34:i32
|
%b0:i1:i32 = mod %b0:i0:i32 20:i32
|
||||||
%b0:i2:i32 = typecast %b0:i1:u1 to i32
|
%b0:i2:unit = store %b0:i1:i32 %l0:i32*
|
||||||
ret %b0:i2:i32
|
%b0:i3:i32 = load %l0:i32*
|
||||||
|
%b0:i4:i32 = call @fibonacci:[ret:i32 params:(i32)]*(%b0:i3:i32)
|
||||||
|
ret %b0:i4:i32
|
||||||
|
|
||||||
block b1:
|
block b1:
|
||||||
ret 0:i32
|
ret 0:i32
|
||||||
|
|||||||
@@ -1,4 +1,5 @@
|
|||||||
var i32 @g = 10
|
var i32 @g = 10
|
||||||
|
var i32 @nonce = default
|
||||||
|
|
||||||
fun i32 @foo (i32, i32) {
|
fun i32 @foo (i32, i32) {
|
||||||
init:
|
init:
|
||||||
@@ -15,7 +16,7 @@ block b0:
|
|||||||
%b0:i2:i32 = load %l0:i32*
|
%b0:i2:i32 = load %l0:i32*
|
||||||
%b0:i3:i32 = load %l1:i32*
|
%b0:i3:i32 = load %l1:i32*
|
||||||
%b0:i4:i32 = add %b0:i2:i32 %b0:i3:i32
|
%b0:i4:i32 = add %b0:i2:i32 %b0:i3:i32
|
||||||
%b0:i5:i32 = load @g:i32*
|
%b0:i5:i32 = load @nonce:i32*
|
||||||
%b0:i6:i32 = add %b0:i4:i32 %b0:i5:i32
|
%b0:i6:i32 = add %b0:i4:i32 %b0:i5:i32
|
||||||
ret %b0:i6:i32
|
ret %b0:i6:i32
|
||||||
|
|
||||||
@@ -35,9 +36,7 @@ block b0:
|
|||||||
%b0:i2:i32 = load %l0:i32*
|
%b0:i2:i32 = load %l0:i32*
|
||||||
%b0:i3:i32 = load %l0:i32*
|
%b0:i3:i32 = load %l0:i32*
|
||||||
%b0:i4:i32 = call @foo:[ret:i32 params:(i32, i32)]*(%b0:i2:i32, %b0:i3:i32)
|
%b0:i4:i32 = call @foo:[ret:i32 params:(i32, i32)]*(%b0:i2:i32, %b0:i3:i32)
|
||||||
%b0:i5:u1 = cmp eq %b0:i4:i32 30:i32
|
ret %b0:i4:i32
|
||||||
%b0:i6:i32 = typecast %b0:i5:u1 to i32
|
|
||||||
ret %b0:i6:i32
|
|
||||||
|
|
||||||
block b1:
|
block b1:
|
||||||
ret 0:i32
|
ret 0:i32
|
||||||
|
|||||||
@@ -1,3 +1,4 @@
|
|||||||
|
var i32 @nonce = default
|
||||||
|
|
||||||
fun i32 @main () {
|
fun i32 @main () {
|
||||||
init:
|
init:
|
||||||
@@ -6,8 +7,10 @@ init:
|
|||||||
%l0:i32:x
|
%l0:i32:x
|
||||||
|
|
||||||
block b0:
|
block b0:
|
||||||
%b0:i0:unit = store 1:i32 %l0:i32*
|
%b0:i0:i32 = load @nonce:i32*
|
||||||
ret 1:i32
|
%b0:i1:unit = store %b0:i0:i32 %l0:i32*
|
||||||
|
%b0:i2:i32 = load %l0:i32*
|
||||||
|
ret %b0:i2:i32
|
||||||
|
|
||||||
block b1:
|
block b1:
|
||||||
ret 0:i32
|
ret 0:i32
|
||||||
|
|||||||
@@ -1,3 +1,4 @@
|
|||||||
|
var i32 @nonce = default
|
||||||
|
|
||||||
fun i32 @foo () {
|
fun i32 @foo () {
|
||||||
init:
|
init:
|
||||||
@@ -5,21 +6,26 @@ init:
|
|||||||
allocations:
|
allocations:
|
||||||
%l0:i32:sum
|
%l0:i32:sum
|
||||||
%l1:i32:i
|
%l1:i32:i
|
||||||
|
%l2:i32:continue_num
|
||||||
|
|
||||||
block b0:
|
block b0:
|
||||||
%b0:i0:unit = store 0:i32 %l0:i32*
|
%b0:i0:unit = store 0:i32 %l0:i32*
|
||||||
%b0:i1:unit = store 0:i32 %l1:i32*
|
%b0:i1:unit = store 0:i32 %l1:i32*
|
||||||
|
%b0:i2:i32 = load @nonce:i32*
|
||||||
|
%b0:i3:i32 = mod %b0:i2:i32 98:i32
|
||||||
|
%b0:i4:unit = store %b0:i3:i32 %l2:i32*
|
||||||
j b1()
|
j b1()
|
||||||
|
|
||||||
block b1:
|
block b1:
|
||||||
%b1:i0:i32 = load %l1:i32*
|
%b1:i0:i32 = load %l1:i32*
|
||||||
%b1:i1:u1 = cmp lt %b1:i0:i32 10:i32
|
%b1:i1:u1 = cmp lt %b1:i0:i32 100:i32
|
||||||
br %b1:i1:u1, b2(), b3()
|
br %b1:i1:u1, b2(), b3()
|
||||||
|
|
||||||
block b2:
|
block b2:
|
||||||
%b2:i0:i32 = load %l1:i32*
|
%b2:i0:i32 = load %l1:i32*
|
||||||
%b2:i1:u1 = cmp eq %b2:i0:i32 3:i32
|
%b2:i1:i32 = load %l2:i32*
|
||||||
br %b2:i1:u1, b4(), b5()
|
%b2:i2:u1 = cmp eq %b2:i0:i32 %b2:i1:i32
|
||||||
|
br %b2:i2:u1, b4(), b5()
|
||||||
|
|
||||||
block b3:
|
block b3:
|
||||||
%b3:i0:i32 = load %l0:i32*
|
%b3:i0:i32 = load %l0:i32*
|
||||||
@@ -43,8 +49,10 @@ block b6:
|
|||||||
%b6:i5:i32 = add %b6:i4:i32 1:i32
|
%b6:i5:i32 = add %b6:i4:i32 1:i32
|
||||||
%b6:i6:unit = store %b6:i5:i32 %l1:i32*
|
%b6:i6:unit = store %b6:i5:i32 %l1:i32*
|
||||||
%b6:i7:i32 = load %l1:i32*
|
%b6:i7:i32 = load %l1:i32*
|
||||||
%b6:i8:u1 = cmp eq %b6:i7:i32 5:i32
|
%b6:i8:i32 = load %l2:i32*
|
||||||
br %b6:i8:u1, b8(), b9()
|
%b6:i9:i32 = add %b6:i8:i32 2:i32
|
||||||
|
%b6:i10:u1 = cmp eq %b6:i7:i32 %b6:i9:i32
|
||||||
|
br %b6:i10:u1, b8(), b9()
|
||||||
|
|
||||||
block b7:
|
block b7:
|
||||||
j b6()
|
j b6()
|
||||||
@@ -73,9 +81,7 @@ init:
|
|||||||
|
|
||||||
block b0:
|
block b0:
|
||||||
%b0:i0:i32 = call @foo:[ret:i32 params:()]*()
|
%b0:i0:i32 = call @foo:[ret:i32 params:()]*()
|
||||||
%b0:i1:u1 = cmp eq %b0:i0:i32 7:i32
|
ret %b0:i0:i32
|
||||||
%b0:i2:i32 = typecast %b0:i1:u1 to i32
|
|
||||||
ret %b0:i2:i32
|
|
||||||
|
|
||||||
block b1:
|
block b1:
|
||||||
ret 0:i32
|
ret 0:i32
|
||||||
|
|||||||
@@ -1,3 +1,4 @@
|
|||||||
|
var i32 @nonce = default
|
||||||
|
|
||||||
fun i32 @main () {
|
fun i32 @main () {
|
||||||
init:
|
init:
|
||||||
@@ -9,7 +10,8 @@ init:
|
|||||||
%l3:i32:r
|
%l3:i32:r
|
||||||
%l4:i32:t0
|
%l4:i32:t0
|
||||||
%l5:i32:t1
|
%l5:i32:t1
|
||||||
%l6:i32:t2
|
%l6:i32:loop_num
|
||||||
|
%l7:i32:t2
|
||||||
|
|
||||||
block b0:
|
block b0:
|
||||||
%b0:i0:unit = store 2:i32 %l1:i32*
|
%b0:i0:unit = store 2:i32 %l1:i32*
|
||||||
@@ -33,7 +35,10 @@ block b2:
|
|||||||
block b3:
|
block b3:
|
||||||
%b3:i0:i32 = load %l5:i32*
|
%b3:i0:i32 = load %l5:i32*
|
||||||
%b3:i1:unit = store %b3:i0:i32 %l3:i32*
|
%b3:i1:unit = store %b3:i0:i32 %l3:i32*
|
||||||
%b3:i2:unit = store 0:i32 %l0:i32*
|
%b3:i2:i32 = load @nonce:i32*
|
||||||
|
%b3:i3:i32 = mod %b3:i2:i32 100:i32
|
||||||
|
%b3:i4:unit = store %b3:i3:i32 %l6:i32*
|
||||||
|
%b3:i5:unit = store 0:i32 %l0:i32*
|
||||||
j b8()
|
j b8()
|
||||||
|
|
||||||
block b4:
|
block b4:
|
||||||
@@ -57,8 +62,9 @@ block b6:
|
|||||||
|
|
||||||
block b8:
|
block b8:
|
||||||
%b8:i0:i32 = load %l0:i32*
|
%b8:i0:i32 = load %l0:i32*
|
||||||
%b8:i1:u1 = cmp lt %b8:i0:i32 11:i32
|
%b8:i1:i32 = load %l6:i32*
|
||||||
br %b8:i1:u1, b9(), b11()
|
%b8:i2:u1 = cmp lt %b8:i0:i32 %b8:i1:i32
|
||||||
|
br %b8:i2:u1, b9(), b11()
|
||||||
|
|
||||||
block b9:
|
block b9:
|
||||||
%b9:i0:i32 = load %l0:i32*
|
%b9:i0:i32 = load %l0:i32*
|
||||||
@@ -68,9 +74,7 @@ block b9:
|
|||||||
|
|
||||||
block b11:
|
block b11:
|
||||||
%b11:i0:i32 = load %l1:i32*
|
%b11:i0:i32 = load %l1:i32*
|
||||||
%b11:i1:u1 = cmp eq %b11:i0:i32 34:i32
|
ret %b11:i0:i32
|
||||||
%b11:i2:i32 = typecast %b11:i1:u1 to i32
|
|
||||||
ret %b11:i2:i32
|
|
||||||
|
|
||||||
block b12:
|
block b12:
|
||||||
%b12:i0:i32 = load %l1:i32*
|
%b12:i0:i32 = load %l1:i32*
|
||||||
@@ -96,17 +100,17 @@ block b15:
|
|||||||
%b15:i0:i32 = load %l0:i32*
|
%b15:i0:i32 = load %l0:i32*
|
||||||
%b15:i1:i32 = add %b15:i0:i32 2:i32
|
%b15:i1:i32 = add %b15:i0:i32 2:i32
|
||||||
%b15:i2:unit = store %b15:i1:i32 %l0:i32*
|
%b15:i2:unit = store %b15:i1:i32 %l0:i32*
|
||||||
%b15:i3:unit = store %b15:i1:i32 %l6:i32*
|
%b15:i3:unit = store %b15:i1:i32 %l7:i32*
|
||||||
j b17()
|
j b17()
|
||||||
|
|
||||||
block b16:
|
block b16:
|
||||||
%b16:i0:i32 = load %l0:i32*
|
%b16:i0:i32 = load %l0:i32*
|
||||||
%b16:i1:i32 = add %b16:i0:i32 1:i32
|
%b16:i1:i32 = add %b16:i0:i32 1:i32
|
||||||
%b16:i2:unit = store %b16:i1:i32 %l0:i32*
|
%b16:i2:unit = store %b16:i1:i32 %l0:i32*
|
||||||
%b16:i3:unit = store %b16:i1:i32 %l6:i32*
|
%b16:i3:unit = store %b16:i1:i32 %l7:i32*
|
||||||
j b17()
|
j b17()
|
||||||
|
|
||||||
block b17:
|
block b17:
|
||||||
%b17:i0:i32 = load %l6:i32*
|
%b17:i0:i32 = load %l7:i32*
|
||||||
j b8()
|
j b8()
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,3 +1,4 @@
|
|||||||
|
var i32 @nonce = default
|
||||||
|
|
||||||
fun i32 @fibonacci (i32) {
|
fun i32 @fibonacci (i32) {
|
||||||
init:
|
init:
|
||||||
@@ -31,11 +32,13 @@ fun i32 @main () {
|
|||||||
init:
|
init:
|
||||||
bid: b0
|
bid: b0
|
||||||
allocations:
|
allocations:
|
||||||
|
%l0:i32:number
|
||||||
|
|
||||||
block b0:
|
block b0:
|
||||||
%b0:i0:i32 = call @fibonacci:[ret:i32 params:(i32)]*(9:i32)
|
%b0:i0:i32 = load @nonce:i32*
|
||||||
%b0:i1:u1 = cmp eq %b0:i0:i32 34:i32
|
%b0:i1:i32 = mod %b0:i0:i32 20:i32
|
||||||
%b0:i2:i32 = typecast %b0:i1:u1 to i32
|
%b0:i2:unit = store %b0:i1:i32 %l0:i32*
|
||||||
ret %b0:i2:i32
|
%b0:i3:i32 = load %l0:i32*
|
||||||
|
%b0:i4:i32 = call @fibonacci:[ret:i32 params:(i32)]*(%b0:i3:i32)
|
||||||
|
ret %b0:i4:i32
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,4 +1,5 @@
|
|||||||
var i32 @g = 10
|
var i32 @g = 10
|
||||||
|
var i32 @nonce = default
|
||||||
|
|
||||||
fun i32 @foo (i32, i32) {
|
fun i32 @foo (i32, i32) {
|
||||||
init:
|
init:
|
||||||
@@ -15,7 +16,7 @@ block b0:
|
|||||||
%b0:i2:i32 = load %l0:i32*
|
%b0:i2:i32 = load %l0:i32*
|
||||||
%b0:i3:i32 = load %l1:i32*
|
%b0:i3:i32 = load %l1:i32*
|
||||||
%b0:i4:i32 = add %b0:i2:i32 %b0:i3:i32
|
%b0:i4:i32 = add %b0:i2:i32 %b0:i3:i32
|
||||||
%b0:i5:i32 = load @g:i32*
|
%b0:i5:i32 = load @nonce:i32*
|
||||||
%b0:i6:i32 = add %b0:i4:i32 %b0:i5:i32
|
%b0:i6:i32 = add %b0:i4:i32 %b0:i5:i32
|
||||||
ret %b0:i6:i32
|
ret %b0:i6:i32
|
||||||
}
|
}
|
||||||
@@ -32,7 +33,5 @@ block b0:
|
|||||||
%b0:i2:i32 = load %l0:i32*
|
%b0:i2:i32 = load %l0:i32*
|
||||||
%b0:i3:i32 = load %l0:i32*
|
%b0:i3:i32 = load %l0:i32*
|
||||||
%b0:i4:i32 = call @foo:[ret:i32 params:(i32, i32)]*(%b0:i2:i32, %b0:i3:i32)
|
%b0:i4:i32 = call @foo:[ret:i32 params:(i32, i32)]*(%b0:i2:i32, %b0:i3:i32)
|
||||||
%b0:i5:u1 = cmp eq %b0:i4:i32 30:i32
|
ret %b0:i4:i32
|
||||||
%b0:i6:i32 = typecast %b0:i5:u1 to i32
|
|
||||||
ret %b0:i6:i32
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,3 +1,4 @@
|
|||||||
|
var i32 @nonce = default
|
||||||
|
|
||||||
fun i32 @main () {
|
fun i32 @main () {
|
||||||
init:
|
init:
|
||||||
@@ -6,6 +7,8 @@ init:
|
|||||||
%l0:i32:x
|
%l0:i32:x
|
||||||
|
|
||||||
block b0:
|
block b0:
|
||||||
%b0:i0:unit = store 1:i32 %l0:i32*
|
%b0:i0:i32 = load @nonce:i32*
|
||||||
ret 1:i32
|
%b0:i1:unit = store %b0:i0:i32 %l0:i32*
|
||||||
|
%b0:i2:i32 = load %l0:i32*
|
||||||
|
ret %b0:i2:i32
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,3 +1,4 @@
|
|||||||
|
var i32 @nonce = default
|
||||||
|
|
||||||
fun i32 @foo () {
|
fun i32 @foo () {
|
||||||
init:
|
init:
|
||||||
@@ -5,21 +6,26 @@ init:
|
|||||||
allocations:
|
allocations:
|
||||||
%l0:i32:sum
|
%l0:i32:sum
|
||||||
%l1:i32:i
|
%l1:i32:i
|
||||||
|
%l2:i32:continue_num
|
||||||
|
|
||||||
block b0:
|
block b0:
|
||||||
%b0:i0:unit = store 0:i32 %l0:i32*
|
%b0:i0:unit = store 0:i32 %l0:i32*
|
||||||
%b0:i1:unit = store 0:i32 %l1:i32*
|
%b0:i1:unit = store 0:i32 %l1:i32*
|
||||||
|
%b0:i2:i32 = load @nonce:i32*
|
||||||
|
%b0:i3:i32 = mod %b0:i2:i32 98:i32
|
||||||
|
%b0:i4:unit = store %b0:i3:i32 %l2:i32*
|
||||||
j b1()
|
j b1()
|
||||||
|
|
||||||
block b1:
|
block b1:
|
||||||
%b1:i0:i32 = load %l1:i32*
|
%b1:i0:i32 = load %l1:i32*
|
||||||
%b1:i1:u1 = cmp lt %b1:i0:i32 10:i32
|
%b1:i1:u1 = cmp lt %b1:i0:i32 100:i32
|
||||||
br %b1:i1:u1, b2(), b3()
|
br %b1:i1:u1, b2(), b3()
|
||||||
|
|
||||||
block b2:
|
block b2:
|
||||||
%b2:i0:i32 = load %l1:i32*
|
%b2:i0:i32 = load %l1:i32*
|
||||||
%b2:i1:u1 = cmp eq %b2:i0:i32 3:i32
|
%b2:i1:i32 = load %l2:i32*
|
||||||
br %b2:i1:u1, b4(), b5()
|
%b2:i2:u1 = cmp eq %b2:i0:i32 %b2:i1:i32
|
||||||
|
br %b2:i2:u1, b4(), b5()
|
||||||
|
|
||||||
block b3:
|
block b3:
|
||||||
%b3:i0:i32 = load %l0:i32*
|
%b3:i0:i32 = load %l0:i32*
|
||||||
@@ -40,8 +46,10 @@ block b5:
|
|||||||
%b5:i5:i32 = add %b5:i4:i32 1:i32
|
%b5:i5:i32 = add %b5:i4:i32 1:i32
|
||||||
%b5:i6:unit = store %b5:i5:i32 %l1:i32*
|
%b5:i6:unit = store %b5:i5:i32 %l1:i32*
|
||||||
%b5:i7:i32 = load %l1:i32*
|
%b5:i7:i32 = load %l1:i32*
|
||||||
%b5:i8:u1 = cmp eq %b5:i7:i32 5:i32
|
%b5:i8:i32 = load %l2:i32*
|
||||||
br %b5:i8:u1, b3(), b1()
|
%b5:i9:i32 = add %b5:i8:i32 2:i32
|
||||||
|
%b5:i10:u1 = cmp eq %b5:i7:i32 %b5:i9:i32
|
||||||
|
br %b5:i10:u1, b3(), b1()
|
||||||
}
|
}
|
||||||
|
|
||||||
fun i32 @main () {
|
fun i32 @main () {
|
||||||
@@ -52,7 +60,5 @@ init:
|
|||||||
|
|
||||||
block b0:
|
block b0:
|
||||||
%b0:i0:i32 = call @foo:[ret:i32 params:()]*()
|
%b0:i0:i32 = call @foo:[ret:i32 params:()]*()
|
||||||
%b0:i1:u1 = cmp eq %b0:i0:i32 7:i32
|
ret %b0:i0:i32
|
||||||
%b0:i2:i32 = typecast %b0:i1:u1 to i32
|
|
||||||
ret %b0:i2:i32
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,3 +1,4 @@
|
|||||||
|
var i32 @nonce = default
|
||||||
|
|
||||||
fun i32 @main () {
|
fun i32 @main () {
|
||||||
init:
|
init:
|
||||||
@@ -9,7 +10,8 @@ init:
|
|||||||
%l3:i32:r
|
%l3:i32:r
|
||||||
%l4:i32:t0
|
%l4:i32:t0
|
||||||
%l5:i32:t1
|
%l5:i32:t1
|
||||||
%l6:i32:t2
|
%l6:i32:loop_num
|
||||||
|
%l7:i32:t2
|
||||||
|
|
||||||
block b0:
|
block b0:
|
||||||
%b0:i0:unit = nop
|
%b0:i0:unit = nop
|
||||||
@@ -35,7 +37,10 @@ block b3:
|
|||||||
%b3:p1:i32:t1
|
%b3:p1:i32:t1
|
||||||
%b3:i0:unit = nop
|
%b3:i0:unit = nop
|
||||||
%b3:i1:unit = nop
|
%b3:i1:unit = nop
|
||||||
%b3:i2:unit = nop
|
%b3:i2:i32 = load @nonce:i32*
|
||||||
|
%b3:i3:i32 = mod %b3:i2:i32 100:i32
|
||||||
|
%b3:i4:unit = nop
|
||||||
|
%b3:i5:unit = nop
|
||||||
j b8(0:i32, %b3:p0:i32)
|
j b8(0:i32, %b3:p0:i32)
|
||||||
|
|
||||||
block b4:
|
block b4:
|
||||||
@@ -63,8 +68,9 @@ block b8:
|
|||||||
%b8:p0:i32:i
|
%b8:p0:i32:i
|
||||||
%b8:p1:i32:p
|
%b8:p1:i32:p
|
||||||
%b8:i0:unit = nop
|
%b8:i0:unit = nop
|
||||||
%b8:i1:u1 = cmp lt %b8:p0:i32 11:i32
|
%b8:i1:unit = nop
|
||||||
br %b8:i1:u1, b9(), b11()
|
%b8:i2:u1 = cmp lt %b8:p0:i32 %b3:i3:i32
|
||||||
|
br %b8:i2:u1, b9(), b11()
|
||||||
|
|
||||||
block b9:
|
block b9:
|
||||||
%b9:i0:unit = nop
|
%b9:i0:unit = nop
|
||||||
@@ -74,9 +80,7 @@ block b9:
|
|||||||
|
|
||||||
block b11:
|
block b11:
|
||||||
%b11:i0:unit = nop
|
%b11:i0:unit = nop
|
||||||
%b11:i1:u1 = cmp eq %b8:p1:i32 34:i32
|
ret %b8:p1:i32
|
||||||
%b11:i2:i32 = typecast %b11:i1:u1 to i32
|
|
||||||
ret %b11:i2:i32
|
|
||||||
|
|
||||||
block b12:
|
block b12:
|
||||||
%b12:i0:unit = nop
|
%b12:i0:unit = nop
|
||||||
|
|||||||
@@ -1,3 +1,4 @@
|
|||||||
|
var i32 @nonce = default
|
||||||
|
|
||||||
fun i32 @fibonacci (i32) {
|
fun i32 @fibonacci (i32) {
|
||||||
init:
|
init:
|
||||||
@@ -31,11 +32,13 @@ fun i32 @main () {
|
|||||||
init:
|
init:
|
||||||
bid: b0
|
bid: b0
|
||||||
allocations:
|
allocations:
|
||||||
|
%l0:i32:number
|
||||||
|
|
||||||
block b0:
|
block b0:
|
||||||
%b0:i0:i32 = call @fibonacci:[ret:i32 params:(i32)]*(9:i32)
|
%b0:i0:i32 = load @nonce:i32*
|
||||||
%b0:i1:u1 = cmp eq %b0:i0:i32 34:i32
|
%b0:i1:i32 = mod %b0:i0:i32 20:i32
|
||||||
%b0:i2:i32 = typecast %b0:i1:u1 to i32
|
%b0:i2:unit = nop
|
||||||
ret %b0:i2:i32
|
%b0:i3:unit = nop
|
||||||
|
%b0:i4:i32 = call @fibonacci:[ret:i32 params:(i32)]*(%b0:i1:i32)
|
||||||
|
ret %b0:i4:i32
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,4 +1,5 @@
|
|||||||
var i32 @g = 10
|
var i32 @g = 10
|
||||||
|
var i32 @nonce = default
|
||||||
|
|
||||||
fun i32 @foo (i32, i32) {
|
fun i32 @foo (i32, i32) {
|
||||||
init:
|
init:
|
||||||
@@ -15,7 +16,7 @@ block b0:
|
|||||||
%b0:i2:unit = nop
|
%b0:i2:unit = nop
|
||||||
%b0:i3:unit = nop
|
%b0:i3:unit = nop
|
||||||
%b0:i4:i32 = add %b0:p0:i32 %b0:p1:i32
|
%b0:i4:i32 = add %b0:p0:i32 %b0:p1:i32
|
||||||
%b0:i5:i32 = load @g:i32*
|
%b0:i5:i32 = load @nonce:i32*
|
||||||
%b0:i6:i32 = add %b0:i4:i32 %b0:i5:i32
|
%b0:i6:i32 = add %b0:i4:i32 %b0:i5:i32
|
||||||
ret %b0:i6:i32
|
ret %b0:i6:i32
|
||||||
}
|
}
|
||||||
@@ -32,7 +33,5 @@ block b0:
|
|||||||
%b0:i2:unit = nop
|
%b0:i2:unit = nop
|
||||||
%b0:i3:unit = nop
|
%b0:i3:unit = nop
|
||||||
%b0:i4:i32 = call @foo:[ret:i32 params:(i32, i32)]*(%b0:i0:i32, %b0:i0:i32)
|
%b0:i4:i32 = call @foo:[ret:i32 params:(i32, i32)]*(%b0:i0:i32, %b0:i0:i32)
|
||||||
%b0:i5:u1 = cmp eq %b0:i4:i32 30:i32
|
ret %b0:i4:i32
|
||||||
%b0:i6:i32 = typecast %b0:i5:u1 to i32
|
|
||||||
ret %b0:i6:i32
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,3 +1,4 @@
|
|||||||
|
var i32 @nonce = default
|
||||||
|
|
||||||
fun i32 @main () {
|
fun i32 @main () {
|
||||||
init:
|
init:
|
||||||
@@ -6,6 +7,8 @@ init:
|
|||||||
%l0:i32:x
|
%l0:i32:x
|
||||||
|
|
||||||
block b0:
|
block b0:
|
||||||
%b0:i0:unit = nop
|
%b0:i0:i32 = load @nonce:i32*
|
||||||
ret 1:i32
|
%b0:i1:unit = nop
|
||||||
|
%b0:i2:unit = nop
|
||||||
|
ret %b0:i0:i32
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,3 +1,4 @@
|
|||||||
|
var i32 @nonce = default
|
||||||
|
|
||||||
fun i32 @foo () {
|
fun i32 @foo () {
|
||||||
init:
|
init:
|
||||||
@@ -5,23 +6,28 @@ init:
|
|||||||
allocations:
|
allocations:
|
||||||
%l0:i32:sum
|
%l0:i32:sum
|
||||||
%l1:i32:i
|
%l1:i32:i
|
||||||
|
%l2:i32:continue_num
|
||||||
|
|
||||||
block b0:
|
block b0:
|
||||||
%b0:i0:unit = nop
|
%b0:i0:unit = nop
|
||||||
%b0:i1:unit = nop
|
%b0:i1:unit = nop
|
||||||
|
%b0:i2:i32 = load @nonce:i32*
|
||||||
|
%b0:i3:i32 = mod %b0:i2:i32 98:i32
|
||||||
|
%b0:i4:unit = nop
|
||||||
j b1(0:i32, 0:i32)
|
j b1(0:i32, 0:i32)
|
||||||
|
|
||||||
block b1:
|
block b1:
|
||||||
%b1:p0:i32:sum
|
%b1:p0:i32:sum
|
||||||
%b1:p1:i32:i
|
%b1:p1:i32:i
|
||||||
%b1:i0:unit = nop
|
%b1:i0:unit = nop
|
||||||
%b1:i1:u1 = cmp lt %b1:p1:i32 10:i32
|
%b1:i1:u1 = cmp lt %b1:p1:i32 100:i32
|
||||||
br %b1:i1:u1, b2(), b3(%b1:p0:i32)
|
br %b1:i1:u1, b2(), b3(%b1:p0:i32)
|
||||||
|
|
||||||
block b2:
|
block b2:
|
||||||
%b2:i0:unit = nop
|
%b2:i0:unit = nop
|
||||||
%b2:i1:u1 = cmp eq %b1:p1:i32 3:i32
|
%b2:i1:unit = nop
|
||||||
br %b2:i1:u1, b4(), b5()
|
%b2:i2:u1 = cmp eq %b1:p1:i32 %b0:i3:i32
|
||||||
|
br %b2:i2:u1, b4(), b5()
|
||||||
|
|
||||||
block b3:
|
block b3:
|
||||||
%b3:p0:i32:sum
|
%b3:p0:i32:sum
|
||||||
@@ -43,8 +49,10 @@ block b5:
|
|||||||
%b5:i5:i32 = add %b1:p1:i32 1:i32
|
%b5:i5:i32 = add %b1:p1:i32 1:i32
|
||||||
%b5:i6:unit = nop
|
%b5:i6:unit = nop
|
||||||
%b5:i7:unit = nop
|
%b5:i7:unit = nop
|
||||||
%b5:i8:u1 = cmp eq %b5:i5:i32 5:i32
|
%b5:i8:unit = nop
|
||||||
br %b5:i8:u1, b3(%b5:i2:i32), b1(%b5:i2:i32, %b5:i5:i32)
|
%b5:i9:i32 = add %b0:i3:i32 2:i32
|
||||||
|
%b5:i10:u1 = cmp eq %b5:i5:i32 %b5:i9:i32
|
||||||
|
br %b5:i10:u1, b3(%b5:i2:i32), b1(%b5:i2:i32, %b5:i5:i32)
|
||||||
}
|
}
|
||||||
|
|
||||||
fun i32 @main () {
|
fun i32 @main () {
|
||||||
@@ -55,7 +63,5 @@ init:
|
|||||||
|
|
||||||
block b0:
|
block b0:
|
||||||
%b0:i0:i32 = call @foo:[ret:i32 params:()]*()
|
%b0:i0:i32 = call @foo:[ret:i32 params:()]*()
|
||||||
%b0:i1:u1 = cmp eq %b0:i0:i32 7:i32
|
ret %b0:i0:i32
|
||||||
%b0:i2:i32 = typecast %b0:i1:u1 to i32
|
|
||||||
ret %b0:i2:i32
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,3 +1,4 @@
|
|||||||
|
var i32 @nonce = default
|
||||||
|
|
||||||
fun i32 @main () {
|
fun i32 @main () {
|
||||||
init:
|
init:
|
||||||
@@ -20,6 +21,8 @@ block b2:
|
|||||||
block b3:
|
block b3:
|
||||||
%b3:p0:i32:p
|
%b3:p0:i32:p
|
||||||
%b3:p1:i32:t1
|
%b3:p1:i32:t1
|
||||||
|
%b3:i0:i32 = load @nonce:i32*
|
||||||
|
%b3:i1:i32 = mod %b3:i0:i32 100:i32
|
||||||
j b8(0:i32, %b3:p0:i32)
|
j b8(0:i32, %b3:p0:i32)
|
||||||
|
|
||||||
block b4:
|
block b4:
|
||||||
@@ -38,7 +41,7 @@ block b6:
|
|||||||
block b8:
|
block b8:
|
||||||
%b8:p0:i32:i
|
%b8:p0:i32:i
|
||||||
%b8:p1:i32:p
|
%b8:p1:i32:p
|
||||||
%b8:i0:u1 = cmp lt %b8:p0:i32 11:i32
|
%b8:i0:u1 = cmp lt %b8:p0:i32 %b3:i1:i32
|
||||||
br %b8:i0:u1, b9(), b11()
|
br %b8:i0:u1, b9(), b11()
|
||||||
|
|
||||||
block b9:
|
block b9:
|
||||||
@@ -47,9 +50,7 @@ block b9:
|
|||||||
br %b9:i1:u1, b12(), b13()
|
br %b9:i1:u1, b12(), b13()
|
||||||
|
|
||||||
block b11:
|
block b11:
|
||||||
%b11:i0:u1 = cmp eq %b8:p1:i32 34:i32
|
ret %b8:p1:i32
|
||||||
%b11:i1:i32 = typecast %b11:i0:u1 to i32
|
|
||||||
ret %b11:i1:i32
|
|
||||||
|
|
||||||
block b12:
|
block b12:
|
||||||
%b12:i0:i32 = add %b8:p1:i32 5:i32
|
%b12:i0:i32 = add %b8:p1:i32 5:i32
|
||||||
|
|||||||
@@ -1,3 +1,4 @@
|
|||||||
|
var i32 @nonce = default
|
||||||
|
|
||||||
fun i32 @fibonacci (i32) {
|
fun i32 @fibonacci (i32) {
|
||||||
init:
|
init:
|
||||||
@@ -29,8 +30,8 @@ init:
|
|||||||
|
|
||||||
|
|
||||||
block b0:
|
block b0:
|
||||||
%b0:i0:i32 = call @fibonacci:[ret:i32 params:(i32)]*(9:i32)
|
%b0:i0:i32 = load @nonce:i32*
|
||||||
%b0:i1:u1 = cmp eq %b0:i0:i32 34:i32
|
%b0:i1:i32 = mod %b0:i0:i32 20:i32
|
||||||
%b0:i2:i32 = typecast %b0:i1:u1 to i32
|
%b0:i2:i32 = call @fibonacci:[ret:i32 params:(i32)]*(%b0:i1:i32)
|
||||||
ret %b0:i2:i32
|
ret %b0:i2:i32
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,4 +1,5 @@
|
|||||||
var i32 @g = 10
|
var i32 @g = 10
|
||||||
|
var i32 @nonce = default
|
||||||
|
|
||||||
fun i32 @foo (i32, i32) {
|
fun i32 @foo (i32, i32) {
|
||||||
init:
|
init:
|
||||||
@@ -10,7 +11,7 @@ block b0:
|
|||||||
%b0:p0:i32:i
|
%b0:p0:i32:i
|
||||||
%b0:p1:i32:j
|
%b0:p1:i32:j
|
||||||
%b0:i0:i32 = add %b0:p0:i32 %b0:p1:i32
|
%b0:i0:i32 = add %b0:p0:i32 %b0:p1:i32
|
||||||
%b0:i1:i32 = load @g:i32*
|
%b0:i1:i32 = load @nonce:i32*
|
||||||
%b0:i2:i32 = add %b0:i0:i32 %b0:i1:i32
|
%b0:i2:i32 = add %b0:i0:i32 %b0:i1:i32
|
||||||
ret %b0:i2:i32
|
ret %b0:i2:i32
|
||||||
}
|
}
|
||||||
@@ -24,7 +25,5 @@ init:
|
|||||||
block b0:
|
block b0:
|
||||||
%b0:i0:i32 = load @g:i32*
|
%b0:i0:i32 = load @g:i32*
|
||||||
%b0:i1:i32 = call @foo:[ret:i32 params:(i32, i32)]*(%b0:i0:i32, %b0:i0:i32)
|
%b0:i1:i32 = call @foo:[ret:i32 params:(i32, i32)]*(%b0:i0:i32, %b0:i0:i32)
|
||||||
%b0:i2:u1 = cmp eq %b0:i1:i32 30:i32
|
ret %b0:i1:i32
|
||||||
%b0:i3:i32 = typecast %b0:i2:u1 to i32
|
|
||||||
ret %b0:i3:i32
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,3 +1,4 @@
|
|||||||
|
var i32 @nonce = default
|
||||||
|
|
||||||
fun i32 @main () {
|
fun i32 @main () {
|
||||||
init:
|
init:
|
||||||
@@ -6,5 +7,6 @@ init:
|
|||||||
|
|
||||||
|
|
||||||
block b0:
|
block b0:
|
||||||
ret 1:i32
|
%b0:i0:i32 = load @nonce:i32*
|
||||||
|
ret %b0:i0:i32
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,3 +1,4 @@
|
|||||||
|
var i32 @nonce = default
|
||||||
|
|
||||||
fun i32 @foo () {
|
fun i32 @foo () {
|
||||||
init:
|
init:
|
||||||
@@ -6,16 +7,18 @@ init:
|
|||||||
|
|
||||||
|
|
||||||
block b0:
|
block b0:
|
||||||
|
%b0:i0:i32 = load @nonce:i32*
|
||||||
|
%b0:i1:i32 = mod %b0:i0:i32 98:i32
|
||||||
j b1(0:i32, 0:i32)
|
j b1(0:i32, 0:i32)
|
||||||
|
|
||||||
block b1:
|
block b1:
|
||||||
%b1:p0:i32:sum
|
%b1:p0:i32:sum
|
||||||
%b1:p1:i32:i
|
%b1:p1:i32:i
|
||||||
%b1:i0:u1 = cmp lt %b1:p1:i32 10:i32
|
%b1:i0:u1 = cmp lt %b1:p1:i32 100:i32
|
||||||
br %b1:i0:u1, b2(), b3(%b1:p0:i32)
|
br %b1:i0:u1, b2(), b3(%b1:p0:i32)
|
||||||
|
|
||||||
block b2:
|
block b2:
|
||||||
%b2:i0:u1 = cmp eq %b1:p1:i32 3:i32
|
%b2:i0:u1 = cmp eq %b1:p1:i32 %b0:i1:i32
|
||||||
br %b2:i0:u1, b4(), b5()
|
br %b2:i0:u1, b4(), b5()
|
||||||
|
|
||||||
block b3:
|
block b3:
|
||||||
@@ -29,8 +32,9 @@ block b4:
|
|||||||
block b5:
|
block b5:
|
||||||
%b5:i0:i32 = add %b1:p0:i32 %b1:p1:i32
|
%b5:i0:i32 = add %b1:p0:i32 %b1:p1:i32
|
||||||
%b5:i1:i32 = add %b1:p1:i32 1:i32
|
%b5:i1:i32 = add %b1:p1:i32 1:i32
|
||||||
%b5:i2:u1 = cmp eq %b5:i1:i32 5:i32
|
%b5:i2:i32 = add %b0:i1:i32 2:i32
|
||||||
br %b5:i2:u1, b3(%b5:i0:i32), b1(%b5:i0:i32, %b5:i1:i32)
|
%b5:i3:u1 = cmp eq %b5:i1:i32 %b5:i2:i32
|
||||||
|
br %b5:i3:u1, b3(%b5:i0:i32), b1(%b5:i0:i32, %b5:i1:i32)
|
||||||
}
|
}
|
||||||
|
|
||||||
fun i32 @main () {
|
fun i32 @main () {
|
||||||
@@ -41,7 +45,5 @@ init:
|
|||||||
|
|
||||||
block b0:
|
block b0:
|
||||||
%b0:i0:i32 = call @foo:[ret:i32 params:()]*()
|
%b0:i0:i32 = call @foo:[ret:i32 params:()]*()
|
||||||
%b0:i1:u1 = cmp eq %b0:i0:i32 7:i32
|
ret %b0:i0:i32
|
||||||
%b0:i2:i32 = typecast %b0:i1:u1 to i32
|
|
||||||
ret %b0:i2:i32
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,3 +1,4 @@
|
|||||||
|
var i32 @nonce = default
|
||||||
|
|
||||||
fun i32 @main () {
|
fun i32 @main () {
|
||||||
init:
|
init:
|
||||||
@@ -20,6 +21,8 @@ block b2:
|
|||||||
block b3:
|
block b3:
|
||||||
%b3:p0:i32:p
|
%b3:p0:i32:p
|
||||||
%b3:p1:i32:t1
|
%b3:p1:i32:t1
|
||||||
|
%b3:i0:i32 = load @nonce:i32*
|
||||||
|
%b3:i1:i32 = mod %b3:i0:i32 100:i32
|
||||||
j b8(0:i32, %b3:p0:i32)
|
j b8(0:i32, %b3:p0:i32)
|
||||||
|
|
||||||
block b4:
|
block b4:
|
||||||
@@ -38,7 +41,7 @@ block b6:
|
|||||||
block b8:
|
block b8:
|
||||||
%b8:p0:i32:i
|
%b8:p0:i32:i
|
||||||
%b8:p1:i32:p
|
%b8:p1:i32:p
|
||||||
%b8:i0:u1 = cmp lt %b8:p0:i32 11:i32
|
%b8:i0:u1 = cmp lt %b8:p0:i32 %b3:i1:i32
|
||||||
br %b8:i0:u1, b9(), b11()
|
br %b8:i0:u1, b9(), b11()
|
||||||
|
|
||||||
block b9:
|
block b9:
|
||||||
@@ -47,9 +50,7 @@ block b9:
|
|||||||
br %b9:i1:u1, b12(), b13()
|
br %b9:i1:u1, b12(), b13()
|
||||||
|
|
||||||
block b11:
|
block b11:
|
||||||
%b11:i0:u1 = cmp eq %b8:p1:i32 34:i32
|
ret %b8:p1:i32
|
||||||
%b11:i1:i32 = typecast %b11:i0:u1 to i32
|
|
||||||
ret %b11:i1:i32
|
|
||||||
|
|
||||||
block b12:
|
block b12:
|
||||||
%b12:i0:i32 = add %b8:p1:i32 5:i32
|
%b12:i0:i32 = add %b8:p1:i32 5:i32
|
||||||
|
|||||||
@@ -1,3 +1,4 @@
|
|||||||
|
var i32 @nonce = default
|
||||||
|
|
||||||
fun i32 @fibonacci (i32) {
|
fun i32 @fibonacci (i32) {
|
||||||
init:
|
init:
|
||||||
@@ -29,8 +30,8 @@ init:
|
|||||||
|
|
||||||
|
|
||||||
block b0:
|
block b0:
|
||||||
%b0:i0:i32 = call @fibonacci:[ret:i32 params:(i32)]*(9:i32)
|
%b0:i0:i32 = load @nonce:i32*
|
||||||
%b0:i1:u1 = cmp eq %b0:i0:i32 34:i32
|
%b0:i1:i32 = mod %b0:i0:i32 20:i32
|
||||||
%b0:i2:i32 = typecast %b0:i1:u1 to i32
|
%b0:i2:i32 = call @fibonacci:[ret:i32 params:(i32)]*(%b0:i1:i32)
|
||||||
ret %b0:i2:i32
|
ret %b0:i2:i32
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,4 +1,5 @@
|
|||||||
var i32 @g = 10
|
var i32 @g = 10
|
||||||
|
var i32 @nonce = default
|
||||||
|
|
||||||
fun i32 @foo (i32, i32) {
|
fun i32 @foo (i32, i32) {
|
||||||
init:
|
init:
|
||||||
@@ -10,7 +11,7 @@ block b0:
|
|||||||
%b0:p0:i32:i
|
%b0:p0:i32:i
|
||||||
%b0:p1:i32:j
|
%b0:p1:i32:j
|
||||||
%b0:i0:i32 = add %b0:p0:i32 %b0:p1:i32
|
%b0:i0:i32 = add %b0:p0:i32 %b0:p1:i32
|
||||||
%b0:i1:i32 = load @g:i32*
|
%b0:i1:i32 = load @nonce:i32*
|
||||||
%b0:i2:i32 = add %b0:i0:i32 %b0:i1:i32
|
%b0:i2:i32 = add %b0:i0:i32 %b0:i1:i32
|
||||||
ret %b0:i2:i32
|
ret %b0:i2:i32
|
||||||
}
|
}
|
||||||
@@ -24,7 +25,5 @@ init:
|
|||||||
block b0:
|
block b0:
|
||||||
%b0:i0:i32 = load @g:i32*
|
%b0:i0:i32 = load @g:i32*
|
||||||
%b0:i1:i32 = call @foo:[ret:i32 params:(i32, i32)]*(%b0:i0:i32, %b0:i0:i32)
|
%b0:i1:i32 = call @foo:[ret:i32 params:(i32, i32)]*(%b0:i0:i32, %b0:i0:i32)
|
||||||
%b0:i2:u1 = cmp eq %b0:i1:i32 30:i32
|
ret %b0:i1:i32
|
||||||
%b0:i3:i32 = typecast %b0:i2:u1 to i32
|
|
||||||
ret %b0:i3:i32
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,3 +1,4 @@
|
|||||||
|
var i32 @nonce = default
|
||||||
|
|
||||||
fun i32 @main () {
|
fun i32 @main () {
|
||||||
init:
|
init:
|
||||||
@@ -6,5 +7,6 @@ init:
|
|||||||
|
|
||||||
|
|
||||||
block b0:
|
block b0:
|
||||||
ret 1:i32
|
%b0:i0:i32 = load @nonce:i32*
|
||||||
|
ret %b0:i0:i32
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,3 +1,4 @@
|
|||||||
|
var i32 @nonce = default
|
||||||
|
|
||||||
fun i32 @foo () {
|
fun i32 @foo () {
|
||||||
init:
|
init:
|
||||||
@@ -6,16 +7,18 @@ init:
|
|||||||
|
|
||||||
|
|
||||||
block b0:
|
block b0:
|
||||||
|
%b0:i0:i32 = load @nonce:i32*
|
||||||
|
%b0:i1:i32 = mod %b0:i0:i32 98:i32
|
||||||
j b1(0:i32, 0:i32)
|
j b1(0:i32, 0:i32)
|
||||||
|
|
||||||
block b1:
|
block b1:
|
||||||
%b1:p0:i32:sum
|
%b1:p0:i32:sum
|
||||||
%b1:p1:i32:i
|
%b1:p1:i32:i
|
||||||
%b1:i0:u1 = cmp lt %b1:p1:i32 10:i32
|
%b1:i0:u1 = cmp lt %b1:p1:i32 100:i32
|
||||||
br %b1:i0:u1, b2(), b3(%b1:p0:i32)
|
br %b1:i0:u1, b2(), b3(%b1:p0:i32)
|
||||||
|
|
||||||
block b2:
|
block b2:
|
||||||
%b2:i0:u1 = cmp eq %b1:p1:i32 3:i32
|
%b2:i0:u1 = cmp eq %b1:p1:i32 %b0:i1:i32
|
||||||
br %b2:i0:u1, b4(), b5()
|
br %b2:i0:u1, b4(), b5()
|
||||||
|
|
||||||
block b3:
|
block b3:
|
||||||
@@ -29,8 +32,9 @@ block b4:
|
|||||||
block b5:
|
block b5:
|
||||||
%b5:i0:i32 = add %b1:p0:i32 %b1:p1:i32
|
%b5:i0:i32 = add %b1:p0:i32 %b1:p1:i32
|
||||||
%b5:i1:i32 = add %b1:p1:i32 1:i32
|
%b5:i1:i32 = add %b1:p1:i32 1:i32
|
||||||
%b5:i2:u1 = cmp eq %b5:i1:i32 5:i32
|
%b5:i2:i32 = add %b0:i1:i32 2:i32
|
||||||
br %b5:i2:u1, b3(%b5:i0:i32), b1(%b5:i0:i32, %b5:i1:i32)
|
%b5:i3:u1 = cmp eq %b5:i1:i32 %b5:i2:i32
|
||||||
|
br %b5:i3:u1, b3(%b5:i0:i32), b1(%b5:i0:i32, %b5:i1:i32)
|
||||||
}
|
}
|
||||||
|
|
||||||
fun i32 @main () {
|
fun i32 @main () {
|
||||||
@@ -41,7 +45,5 @@ init:
|
|||||||
|
|
||||||
block b0:
|
block b0:
|
||||||
%b0:i0:i32 = call @foo:[ret:i32 params:()]*()
|
%b0:i0:i32 = call @foo:[ret:i32 params:()]*()
|
||||||
%b0:i1:u1 = cmp eq %b0:i0:i32 7:i32
|
ret %b0:i0:i32
|
||||||
%b0:i2:i32 = typecast %b0:i1:u1 to i32
|
|
||||||
ret %b0:i2:i32
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -527,7 +527,12 @@ impl TryFrom<&ast::Constant> for Constant {
|
|||||||
ast::IntegerBase::Octal => Self::OCTAL,
|
ast::IntegerBase::Octal => Self::OCTAL,
|
||||||
ast::IntegerBase::Hexadecimal => Self::HEXADECIMAL,
|
ast::IntegerBase::Hexadecimal => Self::HEXADECIMAL,
|
||||||
};
|
};
|
||||||
let value = u128::from_str_radix(integer.number.deref(), pat).unwrap();
|
|
||||||
|
let value = if integer.suffix.unsigned {
|
||||||
|
u128::from_str_radix(integer.number.deref(), pat).unwrap()
|
||||||
|
} else {
|
||||||
|
i128::from_str_radix(integer.number.deref(), pat).unwrap() as u128
|
||||||
|
};
|
||||||
|
|
||||||
let is_signed = !integer.suffix.unsigned && {
|
let is_signed = !integer.suffix.unsigned && {
|
||||||
// Even if `suffix` represents `signed`, integer literal cannot be translated
|
// Even if `suffix` represents `signed`, integer literal cannot be translated
|
||||||
|
|||||||
@@ -580,6 +580,14 @@ peg::parser! {
|
|||||||
suffix,
|
suffix,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
/
|
||||||
|
"0" suffix:ast_integer_suffix() {
|
||||||
|
ast::Integer {
|
||||||
|
base: ast::IntegerBase::Decimal,
|
||||||
|
number: Box::from("0"),
|
||||||
|
suffix,
|
||||||
|
}
|
||||||
|
}
|
||||||
/
|
/
|
||||||
"<ast_integer>" {
|
"<ast_integer>" {
|
||||||
todo!()
|
todo!()
|
||||||
|
|||||||
113
src/tests.rs
113
src/tests.rs
@@ -1,3 +1,5 @@
|
|||||||
|
use lang_c::*;
|
||||||
|
use rand::Rng;
|
||||||
use std::fs::{self, File};
|
use std::fs::{self, File};
|
||||||
use std::io::{stderr, Read, Write};
|
use std::io::{stderr, Read, Write};
|
||||||
use std::path::Path;
|
use std::path::Path;
|
||||||
@@ -7,6 +9,67 @@ use wait_timeout::ChildExt;
|
|||||||
|
|
||||||
use crate::*;
|
use crate::*;
|
||||||
|
|
||||||
|
const NONCE_DTYPE: &str = "int";
|
||||||
|
const NONCE_NAME: &str = "nonce";
|
||||||
|
|
||||||
|
fn modify_c(path: &Path, rand_num: i32) -> String {
|
||||||
|
let mut src = File::open(path).expect("`path` must exist");
|
||||||
|
let mut data = String::new();
|
||||||
|
src.read_to_string(&mut data)
|
||||||
|
.expect("`src` must be converted to string");
|
||||||
|
drop(src);
|
||||||
|
|
||||||
|
let from = format!("{} {}", NONCE_DTYPE, NONCE_NAME);
|
||||||
|
let to = format!("{} = {}", from, rand_num);
|
||||||
|
data.replace(&from, &to)
|
||||||
|
}
|
||||||
|
|
||||||
|
fn ast_initializer(number: i32) -> ast::Initializer {
|
||||||
|
let expr = ast::Expression::Constant(Box::new(span::Node::new(
|
||||||
|
ast::Constant::Integer(ast::Integer {
|
||||||
|
base: ast::IntegerBase::Decimal,
|
||||||
|
number: Box::from(&number.to_string() as &str),
|
||||||
|
suffix: ast::IntegerSuffix {
|
||||||
|
size: ast::IntegerSize::Int,
|
||||||
|
unsigned: false,
|
||||||
|
imaginary: false,
|
||||||
|
},
|
||||||
|
}),
|
||||||
|
span::Span::none(),
|
||||||
|
)));
|
||||||
|
|
||||||
|
ast::Initializer::Expression(Box::new(span::Node::new(expr, span::Span::none())))
|
||||||
|
}
|
||||||
|
|
||||||
|
fn modify_ir(unit: &mut ir::TranslationUnit, rand_num: i32) {
|
||||||
|
for (name, decl) in &mut unit.decls {
|
||||||
|
if name == NONCE_NAME {
|
||||||
|
let (dtype, initializer) = decl.get_variable().expect("`decl` must be variable");
|
||||||
|
assert!(initializer.is_none());
|
||||||
|
|
||||||
|
let initializer = ast_initializer(rand_num);
|
||||||
|
let new_decl = ir::Declaration::Variable {
|
||||||
|
dtype: dtype.clone(),
|
||||||
|
initializer: Some(initializer),
|
||||||
|
};
|
||||||
|
|
||||||
|
*decl = new_decl;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fn modify_asm(unit: &mut asm::Asm, rand_num: i32) {
|
||||||
|
for variable in &mut unit.unit.variables {
|
||||||
|
let body = &mut variable.body;
|
||||||
|
if body.label == asm::Label(NONCE_NAME.to_string()) {
|
||||||
|
let directive =
|
||||||
|
asm::Directive::try_from_data_size(asm::DataSize::Word, rand_num as u64);
|
||||||
|
|
||||||
|
body.directives = vec![directive];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Rust sets an exit code of 101 when the process panicked.
|
// Rust sets an exit code of 101 when the process panicked.
|
||||||
// So, we decide KECC sets an exit code of 102 after 101 when the test skipped.
|
// So, we decide KECC sets an exit code of 102 after 101 when the test skipped.
|
||||||
pub const SKIP_TEST: i32 = 102;
|
pub const SKIP_TEST: i32 = 102;
|
||||||
@@ -39,13 +102,27 @@ pub fn test_irgen(path: &Path) {
|
|||||||
.translate(&path)
|
.translate(&path)
|
||||||
.unwrap_or_else(|_| panic!("parse failed {}", path.display()));
|
.unwrap_or_else(|_| panic!("parse failed {}", path.display()));
|
||||||
|
|
||||||
// Test parse
|
let mut ir = Irgen::default()
|
||||||
c::Parse::default()
|
.translate(&unit)
|
||||||
.translate(&path)
|
.unwrap_or_else(|irgen_error| panic!("{}", irgen_error));
|
||||||
.expect("failed to parse the given program");
|
|
||||||
|
|
||||||
let file_path = path.display().to_string();
|
// Apply random value to global variable `dyn`
|
||||||
let bin_path = path.with_extension("irgen").as_path().display().to_string();
|
let rand_num = rand::thread_rng().gen();
|
||||||
|
let new_c = modify_c(path, rand_num);
|
||||||
|
modify_ir(&mut ir, rand_num);
|
||||||
|
|
||||||
|
// compile recolved c example
|
||||||
|
let temp_dir = tempdir().expect("temp dir creation failed");
|
||||||
|
let temp_file_path = temp_dir.path().join("temp.c");
|
||||||
|
let mut temp_file = File::create(&temp_file_path).unwrap();
|
||||||
|
temp_file.write_all(new_c.as_bytes()).unwrap();
|
||||||
|
|
||||||
|
let file_path = temp_file_path.display().to_string();
|
||||||
|
let bin_path = temp_file_path
|
||||||
|
.with_extension("irgen")
|
||||||
|
.as_path()
|
||||||
|
.display()
|
||||||
|
.to_string();
|
||||||
|
|
||||||
// Compile c file: If fails, test is vacuously success
|
// Compile c file: If fails, test is vacuously success
|
||||||
if !Command::new("gcc")
|
if !Command::new("gcc")
|
||||||
@@ -100,10 +177,10 @@ pub fn test_irgen(path: &Path) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
let status = some_or_exit!(status.code(), SKIP_TEST);
|
let status = some_or_exit!(status.code(), SKIP_TEST);
|
||||||
|
drop(temp_file);
|
||||||
|
temp_dir.close().expect("temp dir deletion failed");
|
||||||
|
|
||||||
let ir = Irgen::default()
|
// Interpret resolved ir
|
||||||
.translate(&unit)
|
|
||||||
.unwrap_or_else(|irgen_error| panic!("{}", irgen_error));
|
|
||||||
let args = Vec::new();
|
let args = Vec::new();
|
||||||
let result = ir::interp(&ir, args).unwrap_or_else(|interp_error| panic!("{}", interp_error));
|
let result = ir::interp(&ir, args).unwrap_or_else(|interp_error| panic!("{}", interp_error));
|
||||||
// We only allow main function whose return type is `int`
|
// We only allow main function whose return type is `int`
|
||||||
@@ -217,22 +294,28 @@ pub fn test_opt<P1: AsRef<Path>, P2: AsRef<Path>, O: Optimize<ir::TranslationUni
|
|||||||
pub fn test_asmgen(path: &Path) {
|
pub fn test_asmgen(path: &Path) {
|
||||||
// Check if the file has .ir extension
|
// Check if the file has .ir extension
|
||||||
assert_eq!(path.extension(), Some(std::ffi::OsStr::new("ir")));
|
assert_eq!(path.extension(), Some(std::ffi::OsStr::new("ir")));
|
||||||
let unit = ir::Parse::default()
|
let mut ir = ir::Parse::default()
|
||||||
.translate(&path)
|
.translate(&path)
|
||||||
.unwrap_or_else(|_| panic!("parse failed {}", path.display()));
|
.unwrap_or_else(|_| panic!("parse failed {}", path.display()));
|
||||||
|
|
||||||
|
// Generate RISC-V assembly from IR
|
||||||
|
let mut asm = Asmgen::default()
|
||||||
|
.translate(&ir)
|
||||||
|
.expect("fail to create riscv assembly code");
|
||||||
|
|
||||||
|
// Resolve examples
|
||||||
|
let rand_num = rand::thread_rng().gen();
|
||||||
|
modify_ir(&mut ir, rand_num);
|
||||||
|
modify_asm(&mut asm, rand_num);
|
||||||
|
|
||||||
// Execute IR
|
// Execute IR
|
||||||
let args = Vec::new();
|
let args = Vec::new();
|
||||||
let result = ir::interp(&unit, args).unwrap_or_else(|interp_error| panic!("{}", interp_error));
|
let result = ir::interp(&ir, args).unwrap_or_else(|interp_error| panic!("{}", interp_error));
|
||||||
// We only allow main function whose return type is `int`
|
// We only allow main function whose return type is `int`
|
||||||
let (value, width, is_signed) = result.get_int().expect("non-integer value occurs");
|
let (value, width, is_signed) = result.get_int().expect("non-integer value occurs");
|
||||||
assert_eq!(width, 32);
|
assert_eq!(width, 32);
|
||||||
assert!(is_signed);
|
assert!(is_signed);
|
||||||
|
|
||||||
// Generate RISC-V assembly from IR
|
|
||||||
let asm = Asmgen::default()
|
|
||||||
.translate(&unit)
|
|
||||||
.expect("fail to create riscv assembly code");
|
|
||||||
let asm_path = path.with_extension("S").as_path().display().to_string();
|
let asm_path = path.with_extension("S").as_path().display().to_string();
|
||||||
let mut buffer = File::create(Path::new(&asm_path)).expect("need to success creating file");
|
let mut buffer = File::create(Path::new(&asm_path)).expect("need to success creating file");
|
||||||
write(&asm, &mut buffer).unwrap();
|
write(&asm, &mut buffer).unwrap();
|
||||||
|
|||||||
@@ -56,4 +56,4 @@ then
|
|||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
cargo run --manifest-path $PROJECT_DIR/Cargo.toml --release --bin fuzz -- $FUZZ_ARG test_reduced.c 2>&1 | grep -q '(left == right)'
|
cargo run --manifest-path $PROJECT_DIR/Cargo.toml --release --bin fuzz -- $FUZZ_ARG test_reduced.c 2>&1 | grep -q 'assertion failed'
|
||||||
|
|||||||
Reference in New Issue
Block a user