Blame SOURCES/rhbz1643997.0004-stapbpf-assembler-WIP-3-additional-assembly-test-cas.patch

e4e640
From 6411e53fe729a987a300274f6b15fd88b737367d Mon Sep 17 00:00:00 2001
e4e640
From: Serhei Makarov <smakarov@redhat.com>
e4e640
Date: Tue, 16 Oct 2018 18:13:47 -0400
e4e640
Subject: [PATCH 04/32] stapbpf assembler WIP #3 :: additional assembly test
e4e640
 cases
e4e640
e4e640
---
e4e640
 testsuite/systemtap.bpf/asm_tests/err_alloc.stp   | 10 ++++++++++
e4e640
 testsuite/systemtap.bpf/asm_tests/err_numeric.stp | 18 ++++++++++++++++++
e4e640
 testsuite/systemtap.bpf/asm_tests/simple.stp      |  6 +++---
e4e640
 testsuite/systemtap.bpf/asm_tests/string.stp      | 22 ++++++++++++++++++++++
e4e640
 testsuite/systemtap.bpf/asm_tests/temporary.stp   | 14 ++++++++++++++
e4e640
 5 files changed, 67 insertions(+), 3 deletions(-)
e4e640
 create mode 100644 testsuite/systemtap.bpf/asm_tests/err_alloc.stp
e4e640
 create mode 100644 testsuite/systemtap.bpf/asm_tests/err_numeric.stp
e4e640
 create mode 100644 testsuite/systemtap.bpf/asm_tests/string.stp
e4e640
 create mode 100644 testsuite/systemtap.bpf/asm_tests/temporary.stp
e4e640
e4e640
diff --git a/testsuite/systemtap.bpf/asm_tests/err_alloc.stp b/testsuite/systemtap.bpf/asm_tests/err_alloc.stp
e4e640
new file mode 100644
e4e640
index 000000000..6778a52e2
e4e640
--- /dev/null
e4e640
+++ b/testsuite/systemtap.bpf/asm_tests/err_alloc.stp
e4e640
@@ -0,0 +1,10 @@
e4e640
+function foo:long (x:long) %{ /* bpf */ /* pure */
e4e640
+  alloc "not a register", BPF_MAXSTRINGLEN; /* SHOULD ERROR */
e4e640
+  0xbf, $$, "fifty", -, -; /* mov $$, "fifty" */
e4e640
+%}
e4e640
+
e4e640
+
e4e640
+probe begin {
e4e640
+  printf("foo(1)=%d should be fifty\n", foo(1))
e4e640
+  exit()
e4e640
+}
e4e640
diff --git a/testsuite/systemtap.bpf/asm_tests/err_numeric.stp b/testsuite/systemtap.bpf/asm_tests/err_numeric.stp
e4e640
new file mode 100644
e4e640
index 000000000..9428e5704
e4e640
--- /dev/null
e4e640
+++ b/testsuite/systemtap.bpf/asm_tests/err_numeric.stp
e4e640
@@ -0,0 +1,18 @@
e4e640
+function foo:long (x:long) %{ /* bpf */ /* pure */
e4e640
+  /* verify refusal to accept gibberish */
e4e640
+  0xd33333333333333333333333333333333333333333333333333333333333333333333333333334db33f, $x, -, _bar, 10; /* XTREAM opcode */
e4e640
+  /* 0xb7, $$, -, huirgishvirguwishgiburg, 100; /* XTREAM 3rd arg */
e4e640
+  /* 0xb7, $$, -, -, borkborkborkborkbork; /* XTREAM 4th arg */
e4e640
+%}
e4e640
+
e4e640
+function bar:long (x:long) {
e4e640
+  if (x <= 10) return 50 else return 100
e4e640
+}
e4e640
+
e4e640
+probe begin {
e4e640
+  printf("foo(1)=%d should be %d\n", foo(1), bar(1))
e4e640
+  printf("foo(8)=%d should be %d\n", foo(8), bar(8))
e4e640
+  printf("foo(15)=%d should be %d\n", foo(15), bar(15))
e4e640
+  exit()
e4e640
+}
e4e640
+
e4e640
diff --git a/testsuite/systemtap.bpf/asm_tests/simple.stp b/testsuite/systemtap.bpf/asm_tests/simple.stp
e4e640
index 693219d15..17184a139 100644
e4e640
--- a/testsuite/systemtap.bpf/asm_tests/simple.stp
e4e640
+++ b/testsuite/systemtap.bpf/asm_tests/simple.stp
e4e640
@@ -1,11 +1,11 @@
e4e640
 function foo:long (x:long) %{ /* bpf */ /* pure */
e4e640
   /* compute 100-x */
e4e640
-  0xb7, $$, -, -, 100; /* mov $$, ee */
e4e640
+  0xb7, $$, -, -, 100; /* mov $$, 100 */
e4e640
   0x1f, $$, $x, -, -; /* sub $$, $x */
e4e640
 %}
e4e640
 
e4e640
 probe begin {
e4e640
-  printf("foo(1)=%d\n", foo(1))
e4e640
-  printf("foo(15)=%d\n", foo(15))
e4e640
+  printf("foo(1)=%d, should be 99\n", foo(1))
e4e640
+  printf("foo(15)=%d, should be 85\n", foo(15))
e4e640
   exit()
e4e640
 }
e4e640
diff --git a/testsuite/systemtap.bpf/asm_tests/string.stp b/testsuite/systemtap.bpf/asm_tests/string.stp
e4e640
new file mode 100644
e4e640
index 000000000..dce665c14
e4e640
--- /dev/null
e4e640
+++ b/testsuite/systemtap.bpf/asm_tests/string.stp
e4e640
@@ -0,0 +1,22 @@
e4e640
+function foo:long (x:long) %{ /* bpf */ /* pure */
e4e640
+  /* if x <= 10 then "fifty" else "one-hundred" */
e4e640
+  0xd5, $x, -, _bar, 10; /* jsle $x, 10, _bar */
e4e640
+  0xbf, $$, "one-hundred", -, -; /* mov $$, "one-hundred" */
e4e640
+  0x05, -, -, _done, -; /* ja _done; */
e4e640
+  label, _bar;
e4e640
+  0xbf, $$, "fifty", -, -; /* mov $$, "fifty" */
e4e640
+  label, _done;
e4e640
+  /* 0xbf, $$, $$, -, -; /* dummy op */
e4e640
+%}
e4e640
+
e4e640
+function bar:long (x:long) {
e4e640
+  if (x <= 10) return 50 else return 100
e4e640
+}
e4e640
+
e4e640
+probe begin {
e4e640
+  printf("foo(1)=%d should be %d\n", foo(1), bar(1))
e4e640
+  printf("foo(8)=%d should be %d\n", foo(8), bar(8))
e4e640
+  printf("foo(15)=%d should be %d\n", foo(15), bar(15))
e4e640
+  exit()
e4e640
+}
e4e640
+
e4e640
diff --git a/testsuite/systemtap.bpf/asm_tests/temporary.stp b/testsuite/systemtap.bpf/asm_tests/temporary.stp
e4e640
new file mode 100644
e4e640
index 000000000..153c759ba
e4e640
--- /dev/null
e4e640
+++ b/testsuite/systemtap.bpf/asm_tests/temporary.stp
e4e640
@@ -0,0 +1,14 @@
e4e640
+function foo:long (x:long) %{ /* bpf */ /* pure */
e4e640
+  /* compute (100-x)*(x+2) */
e4e640
+  0xb7, $$, -, -, 100; /* mov $$, 100 */
e4e640
+  0x1f, $$, $x, -, -; /* sub $$, $x */
e4e640
+  0xbf, $tmp, $x, -, -; /* mov $tmp, $x */
e4e640
+  0x07, $tmp, -, -, 2; /* add $tmp, 2 */
e4e640
+  0x2f, $$, $tmp, -, -; /* mul $$, $tmp */
e4e640
+%}
e4e640
+
e4e640
+probe begin {
e4e640
+  printf("foo(1)=%d, should be 99*3=297\n", foo(1))
e4e640
+  printf("foo(15)=%d, should be 85*18=1530\n", foo(15))
e4e640
+  exit()
e4e640
+}
e4e640
-- 
e4e640
2.14.5
e4e640