summaryrefslogtreecommitdiffstats
path: root/runtime
diff options
context:
space:
mode:
authorhunt <hunt>2005-11-08 19:23:27 +0000
committerhunt <hunt>2005-11-08 19:23:27 +0000
commitb5c4668faa92b45d19ee38b64fc43684df1c365f (patch)
tree35d1a4be5f30de45a28a6afe632500fa689051e7 /runtime
parent1a0e4851043eb5679543c7779b00e3d925e83004 (diff)
downloadsystemtap-steved-b5c4668faa92b45d19ee38b64fc43684df1c365f.tar.gz
systemtap-steved-b5c4668faa92b45d19ee38b64fc43684df1c365f.tar.xz
systemtap-steved-b5c4668faa92b45d19ee38b64fc43684df1c365f.zip
2005-11-08 Martin Hunt <hunt@redhat.com>
* pmaps/*: Add new pmaps tests.
Diffstat (limited to 'runtime')
-rw-r--r--runtime/tests/ChangeLog4
-rw-r--r--runtime/tests/pmaps/Makefile5
-rw-r--r--runtime/tests/pmaps/all.tcl5
-rw-r--r--runtime/tests/pmaps/ii.c62
-rw-r--r--runtime/tests/pmaps/is.c67
-rw-r--r--runtime/tests/pmaps/ix.c61
-rw-r--r--runtime/tests/pmaps/map_format.c92
-rw-r--r--runtime/tests/pmaps/pmap.test375
-rw-r--r--runtime/tests/pmaps/si.c59
9 files changed, 730 insertions, 0 deletions
diff --git a/runtime/tests/ChangeLog b/runtime/tests/ChangeLog
index 5b0dd74c..b3813572 100644
--- a/runtime/tests/ChangeLog
+++ b/runtime/tests/ChangeLog
@@ -1,3 +1,7 @@
+2005-11-08 Martin Hunt <hunt@redhat.com>
+
+ * pmaps/*: Add new pmaps tests.
+
2005-10-28 Martin Hunt <hunt@redhat.com>
* maps/keys.c: New file. Tests specific to _stp_key_get_*().
diff --git a/runtime/tests/pmaps/Makefile b/runtime/tests/pmaps/Makefile
new file mode 100644
index 00000000..c396c132
--- /dev/null
+++ b/runtime/tests/pmaps/Makefile
@@ -0,0 +1,5 @@
+default: tests
+
+tests:
+ tclsh all.tcl
+
diff --git a/runtime/tests/pmaps/all.tcl b/runtime/tests/pmaps/all.tcl
new file mode 100644
index 00000000..c0b38a0e
--- /dev/null
+++ b/runtime/tests/pmaps/all.tcl
@@ -0,0 +1,5 @@
+package require tcltest
+namespace import -force tcltest::*
+tcltest::testsDirectory [file dir [info script]]
+tcltest::runAllTests
+
diff --git a/runtime/tests/pmaps/ii.c b/runtime/tests/pmaps/ii.c
new file mode 100644
index 00000000..4b058b2f
--- /dev/null
+++ b/runtime/tests/pmaps/ii.c
@@ -0,0 +1,62 @@
+#include "runtime.h"
+
+/* test of pmaps with keys of int64 and value of int64 */
+
+/* It's not clear this would ever be used in the systemtap language.
+ It would be useful as an array of counters. */
+
+#define VALUE_TYPE INT64
+#define KEY1_TYPE INT64
+#include "pmap-gen.c"
+
+#include "map.c"
+
+int main ()
+{
+ MAP map = _stp_pmap_new_ii(4);
+ int64_t x;
+
+ /* put some data in. _processor_number is a global hack that allows */
+ /* us to set the current emulated cpu number for our userspace tests. */
+ /* Note that we set values based on the cpu number just to show that */
+ /* different values are stored in each cpu */
+ for (_processor_number = 0; _processor_number < NR_CPUS; _processor_number++) {
+ _stp_pmap_add_ii(map, 1, _processor_number);
+ _stp_pmap_add_ii(map, 2, 10 *_processor_number + 1);
+ _stp_pmap_add_ii(map, 3, _processor_number * _processor_number);
+ _stp_pmap_add_ii(map, 4, 1);
+ }
+
+ /* read it back out and verify. Use the special get_cpu call to get non-aggregated data */
+ for (_processor_number = 0; _processor_number < NR_CPUS; _processor_number++) {
+ x = _stp_pmap_get_cpu_ii (map, 3);
+ if (x != _processor_number * _processor_number)
+ printf("ERROR: Got %lld when expected %lld\n", x, (long long)(_processor_number * _processor_number));
+ x = _stp_pmap_get_cpu_ii (map, 1);
+ if (x != _processor_number)
+ printf("ERROR: Got %lld when expected %lld\n", x, (long long)_processor_number);
+ x = _stp_pmap_get_cpu_ii (map, 2);
+ if (x != 10 * _processor_number + 1)
+ printf("ERROR: Got %lld when expected %lld\n", x, (long long)(10 * _processor_number + 1));
+ x = _stp_pmap_get_cpu_ii (map, 4);
+ if (x != 1LL)
+ printf("ERROR: Got %lld when expected %lld\n", x, 1LL);
+ }
+
+ /* now print the per-cpu data */
+ for (_processor_number = 0; _processor_number < NR_CPUS; _processor_number++) {
+ printf("CPU #%d\n", _processor_number);
+ _stp_pmap_printn_cpu (map,0, "map[%1d] = %d", _processor_number);
+ }
+ _processor_number = 0;
+
+ /* print the aggregated data */
+ _stp_pmap_print(map,"map[%1d] = %d");
+
+
+
+
+ _stp_pmap_del (map);
+ return 0;
+}
+
diff --git a/runtime/tests/pmaps/is.c b/runtime/tests/pmaps/is.c
new file mode 100644
index 00000000..64c12460
--- /dev/null
+++ b/runtime/tests/pmaps/is.c
@@ -0,0 +1,67 @@
+#include "runtime.h"
+
+/* test of pmaps with keys of int64 and value of string */
+
+/* It's not clear this would ever be used in the systemtap language.
+ It is not clear this would be useful. */
+
+#define VALUE_TYPE STRING
+#define KEY1_TYPE INT64
+#include "pmap-gen.c"
+
+#include "map.c"
+
+int main ()
+{
+ MAP map = _stp_pmap_new_is(4);
+ char *x;
+ char buf[32];
+
+ /* put some data in. _processor_number is a global hack that allows */
+ /* us to set the current emulated cpu number for our userspace tests. */
+ /* Note that we set values based on the cpu number just to show that */
+ /* different values are stored in each cpu */
+ for (_processor_number = 0; _processor_number < NR_CPUS; _processor_number++) {
+ sprintf(buf, "%d,", _processor_number);
+ _stp_pmap_add_is(map, 1, buf);
+ sprintf(buf, "%d,", 10 *_processor_number + 1);
+ _stp_pmap_add_is(map, 2, buf);
+ sprintf(buf, "%d,", _processor_number * _processor_number);
+ _stp_pmap_add_is(map, 3, buf);
+ _stp_pmap_add_is(map, 4, "1,");
+ }
+
+ /* read it back out and verify. Use the special get_cpu call to get non-aggregated data */
+ for (_processor_number = 0; _processor_number < NR_CPUS; _processor_number++) {
+ x = _stp_pmap_get_cpu_is (map, 3);
+ sprintf(buf, "%d,", _processor_number * _processor_number);
+ if (strcmp(x, buf))
+ printf("ERROR: Got %s when expected %s\n", x, buf);
+ x = _stp_pmap_get_cpu_is (map, 1);
+ sprintf(buf, "%d,", _processor_number);
+ if (strcmp(x, buf))
+ printf("ERROR: Got %s when expected %s\n", x, buf);
+ x = _stp_pmap_get_cpu_is (map, 4);
+ sprintf(buf, "%d,", 1);
+ if (strcmp(x, buf))
+ printf("ERROR: Got %s when expected %s\n", x, buf);
+ x = _stp_pmap_get_cpu_is (map, 2);
+ sprintf(buf, "%d,", 10 * _processor_number +1);
+ if (strcmp(x, buf))
+ printf("ERROR: Got %s when expected %s\n", x, buf);
+ }
+
+ /* now print the per-cpu data */
+ for (_processor_number = 0; _processor_number < NR_CPUS; _processor_number++) {
+ printf("CPU #%d\n", _processor_number);
+ _stp_pmap_printn_cpu (map,0, "map[%1d] = %s", _processor_number);
+ }
+ _processor_number = 0;
+
+ /* print the aggregated data */
+ _stp_pmap_print(map,"map[%1d] = %s");
+
+ _stp_pmap_del (map);
+ return 0;
+}
+
diff --git a/runtime/tests/pmaps/ix.c b/runtime/tests/pmaps/ix.c
new file mode 100644
index 00000000..2c79c3d1
--- /dev/null
+++ b/runtime/tests/pmaps/ix.c
@@ -0,0 +1,61 @@
+#include "runtime.h"
+
+/* test of pmaps with keys of int64 and value of stat */
+
+#define VALUE_TYPE STAT
+#define KEY1_TYPE INT64
+#include "pmap-gen.c"
+
+#include "map.c"
+
+int main ()
+{
+ MAP map = _stp_pmap_new_ix(4, HIST_LINEAR, 0, 100, 10);
+ int64_t x;
+
+ /* put some data in. _processor_number is a global hack that allows */
+ /* us to set the current emulated cpu number for our userspace tests. */
+ /* Note that we set values based on the cpu number just to show that */
+ /* different values are stored in each cpu */
+ for (_processor_number = 0; _processor_number < NR_CPUS; _processor_number++) {
+ _stp_pmap_add_ix(map, 1, _processor_number);
+ _stp_pmap_add_ix(map, 2, 10 *_processor_number + 1);
+ _stp_pmap_add_ix(map, 3, _processor_number * _processor_number);
+ _stp_pmap_add_ix(map, 4, 1);
+ }
+
+#if 0
+ /* read it back out and verify. Use the special get_cpu call to get non-aggregated data */
+ for (_processor_number = 0; _processor_number < NR_CPUS; _processor_number++) {
+ x = _stp_pmap_get_cpu_ix (map, 3);
+ if (x != _processor_number * _processor_number)
+ printf("ERROR: Got %lld when expected %lld\n", x, (long long)(_processor_number * _processor_number));
+ x = _stp_pmap_get_cpu_ix (map, 1);
+ if (x != _processor_number)
+ printf("ERROR: Got %lld when expected %lld\n", x, (long long)_processor_number);
+ x = _stp_pmap_get_cpu_ix (map, 2);
+ if (x != 10 * _processor_number + 1)
+ printf("ERROR: Got %lld when expected %lld\n", x, (long long)(10 * _processor_number + 1));
+ x = _stp_pmap_get_cpu_ix (map, 4);
+ if (x != 1LL)
+ printf("ERROR: Got %lld when expected %lld\n", x, 1LL);
+ }
+#endif
+
+ /* now print the per-cpu data */
+ for (_processor_number = 0; _processor_number < NR_CPUS; _processor_number++) {
+ printf("CPU #%d\n", _processor_number);
+ _stp_pmap_printn_cpu (map,
+ 0,
+ "map[%1d] = count:%C sum:%S avg:%A min:%m max:%M",
+ _processor_number);
+ }
+ _processor_number = 0;
+
+ /* print the aggregated data */
+ _stp_pmap_print(map,"map[%1d] = count:%C sum:%S avg:%A min:%m max:%M\n%H");
+
+ _stp_pmap_del (map);
+ return 0;
+}
+
diff --git a/runtime/tests/pmaps/map_format.c b/runtime/tests/pmaps/map_format.c
new file mode 100644
index 00000000..5b99b64e
--- /dev/null
+++ b/runtime/tests/pmaps/map_format.c
@@ -0,0 +1,92 @@
+#include "runtime.h"
+
+/* map formatting test. Same as the non-pmap version. Output should be identical */
+
+/* torture test of map formatting */
+#define VALUE_TYPE STRING
+#define KEY1_TYPE INT64
+#define KEY2_TYPE INT64
+#define KEY3_TYPE STRING
+#include "pmap-gen.c"
+
+#define VALUE_TYPE INT64
+#define KEY1_TYPE STRING
+#define KEY2_TYPE STRING
+#include "pmap-gen.c"
+
+#define VALUE_TYPE STAT
+#define KEY1_TYPE STRING
+#define KEY2_TYPE STRING
+#include "pmap-gen.c"
+
+#include "map.c"
+
+void inc_cpu(void)
+{
+ _processor_number++;
+ if (_processor_number == NR_CPUS)
+ _processor_number = 0;
+}
+
+int main ()
+{
+ MAP mapiis = _stp_pmap_new_iiss(4);
+ _processor_number = 0;
+ _stp_pmap_set_iiss (mapiis, 1,2,"Ohio", "Columbus" );
+ _stp_pmap_set_iiss (mapiis, 3,4,"California", "Sacramento" );
+ _stp_pmap_set_iiss (mapiis, 5,6,"Washington", "Olympia" );
+ _stp_pmap_set_iiss (mapiis, 7,8,"Oregon", "Salem" );
+ _stp_pmap_print (mapiis, "%s -> mapiis %1d %2d %3s");
+
+ /* test printing of '%' */
+ _stp_pmap_print (mapiis, "%s %% %3s");
+
+ /* very bad string. don't crash */
+ _stp_pmap_print (mapiis, "%s -> mapiis %1s %2s %3d %4d");
+
+ MAP mapss = _stp_pmap_new_ssi(4);
+ _stp_pmap_set_ssi (mapss, "Riga", "Latvia", 0x0000c0dedbad0000LL);
+ _stp_pmap_set_ssi (mapss, "Sofia", "Bulgaria", 0xdeadf00d12345678LL);
+ _stp_pmap_set_ssi (mapss, "Valletta", "Malta", 1);
+ _stp_pmap_set_ssi (mapss, "Nicosia", "Cyprus", -1);
+ _stp_pmap_print (mapss, "The capitol of %1s is %2s and the nerd population is %d");
+ _stp_pmap_print (mapss, "The capitol of %1s is %2s and the nerd population is %x");
+ _stp_pmap_print (mapss, "The capitol of %1s is %2s and the nerd population is %X");
+
+ MAP mapssx = _stp_pmap_new_ssx (4, HIST_LINEAR, 0, 100, 10 );
+ int i,j;
+
+ for (i = 0; i < 100; i++)
+ for (j = 0; j <= i*10 ; j++ ) {
+ inc_cpu();
+ _stp_pmap_add_ssx (mapssx, "Riga", "Latvia", i);
+ }
+
+ for (i = 0; i < 10; i++)
+ for (j = 0; j < 10 ; j++ ) {
+ inc_cpu();
+ _stp_pmap_add_ssx (mapssx, "Sofia", "Bulgaria", j * i );
+ }
+
+ for (i = 0; i < 100; i += 10)
+ for (j = 0; j < i/10 ; j++ ) {
+ inc_cpu();
+ _stp_pmap_add_ssx (mapssx, "Valletta", "Malta", i);
+ }
+
+ _stp_pmap_print (mapssx, "Bogons per packet for %1s\ncount:%C sum:%S avg:%A min:%m max:%M\n%H");
+
+ _stp_pmap_print (mapssx, "%C was the count for %1s, %2s");
+
+ /* here's how to print a map without using _stp_pmap_print(). */
+ _stp_pmap_agg (mapssx);
+ struct map_node *ptr;
+ foreach (AGG_PMAP(mapssx), ptr)
+ _stp_printf ("mapssx[%09s,%09s] = %llX\n", key1str(ptr), key2str(ptr), _stp_get_stat(ptr)->sum);
+ _stp_print_flush();
+
+ _stp_pmap_del (mapssx);
+ _stp_pmap_del (mapiis);
+ _stp_pmap_del (mapss);
+ return 0;
+}
diff --git a/runtime/tests/pmaps/pmap.test b/runtime/tests/pmaps/pmap.test
new file mode 100644
index 00000000..a8f82506
--- /dev/null
+++ b/runtime/tests/pmaps/pmap.test
@@ -0,0 +1,375 @@
+package require tcltest
+namespace import -force tcltest::*
+
+cd $tcltest::testsDirectory
+
+set CFLAGS "-Os"
+set KPATH "/lib/modules/[exec uname -r]/build/include"
+set MPATH "/lib/modules/[exec uname -r]/build/include/asm/mach-default"
+set PATH "../../user"
+
+test ii {Test of int64 keys and int64 values} -setup {
+ puts "gcc $CFLAGS -I $KPATH -I $PATH -I $MPATH -o test ii.c"
+ exec gcc $CFLAGS -I $KPATH -I $PATH -I $MPATH -o test ii.c
+} -body {
+ exec ./test
+} -result {CPU #0
+map[2] = 1
+map[4] = 1
+
+CPU #1
+map[1] = 1
+map[2] = 11
+map[3] = 1
+map[4] = 1
+
+CPU #2
+map[1] = 2
+map[2] = 21
+map[3] = 4
+map[4] = 1
+
+CPU #3
+map[1] = 3
+map[2] = 31
+map[3] = 9
+map[4] = 1
+
+CPU #4
+map[1] = 4
+map[2] = 41
+map[3] = 16
+map[4] = 1
+
+CPU #5
+map[1] = 5
+map[2] = 51
+map[3] = 25
+map[4] = 1
+
+CPU #6
+map[1] = 6
+map[2] = 61
+map[3] = 36
+map[4] = 1
+
+CPU #7
+map[1] = 7
+map[2] = 71
+map[3] = 49
+map[4] = 1
+
+map[2] = 288
+map[4] = 8
+map[1] = 28
+map[3] = 140
+}
+
+test is {Test of int64 keys and string values} -setup {
+ exec gcc $CFLAGS -I $KPATH -I $PATH -I $MPATH -o test is.c
+} -body {
+ exec ./test
+} -result {CPU #0
+map[1] = 0,
+map[2] = 1,
+map[3] = 0,
+map[4] = 1,
+
+CPU #1
+map[1] = 1,
+map[2] = 11,
+map[3] = 1,
+map[4] = 1,
+
+CPU #2
+map[1] = 2,
+map[2] = 21,
+map[3] = 4,
+map[4] = 1,
+
+CPU #3
+map[1] = 3,
+map[2] = 31,
+map[3] = 9,
+map[4] = 1,
+
+CPU #4
+map[1] = 4,
+map[2] = 41,
+map[3] = 16,
+map[4] = 1,
+
+CPU #5
+map[1] = 5,
+map[2] = 51,
+map[3] = 25,
+map[4] = 1,
+
+CPU #6
+map[1] = 6,
+map[2] = 61,
+map[3] = 36,
+map[4] = 1,
+
+CPU #7
+map[1] = 7,
+map[2] = 71,
+map[3] = 49,
+map[4] = 1,
+
+map[2] = 1,11,21,31,41,51,61,71,
+map[4] = 1,1,1,1,1,1,1,1,
+map[1] = 0,1,2,3,4,5,6,7,
+map[3] = 0,1,4,9,16,25,36,49,
+}
+
+test si {Test of string keys and int64 values} -setup {
+ exec gcc $CFLAGS -I $KPATH -I $PATH -I $MPATH -o test si.c
+} -body {
+ exec ./test
+} -result {CPU #0
+map[TWO] = 1
+map[FOUR] = 1
+
+CPU #1
+map[ONE] = 1
+map[TWO] = 11
+map[THREE] = 1
+map[FOUR] = 1
+
+CPU #2
+map[ONE] = 2
+map[TWO] = 21
+map[THREE] = 4
+map[FOUR] = 1
+
+CPU #3
+map[ONE] = 3
+map[TWO] = 31
+map[THREE] = 9
+map[FOUR] = 1
+
+CPU #4
+map[ONE] = 4
+map[TWO] = 41
+map[THREE] = 16
+map[FOUR] = 1
+
+CPU #5
+map[ONE] = 5
+map[TWO] = 51
+map[THREE] = 25
+map[FOUR] = 1
+
+CPU #6
+map[ONE] = 6
+map[TWO] = 61
+map[THREE] = 36
+map[FOUR] = 1
+
+CPU #7
+map[ONE] = 7
+map[TWO] = 71
+map[THREE] = 49
+map[FOUR] = 1
+
+map[FOUR] = 8
+map[TWO] = 288
+map[THREE] = 140
+map[ONE] = 28
+}
+
+test ix {Test of int64 keys and string values} -setup {
+ exec gcc $CFLAGS -I $KPATH -I $PATH -I $MPATH -o test ix.c
+} -body {
+ exec ./test
+} -result {CPU #0
+map[1] = count:1 sum:0 avg:0 min:0 max:0
+map[2] = count:1 sum:1 avg:1 min:1 max:1
+map[3] = count:1 sum:0 avg:0 min:0 max:0
+map[4] = count:1 sum:1 avg:1 min:1 max:1
+
+CPU #1
+map[1] = count:1 sum:1 avg:1 min:1 max:1
+map[2] = count:1 sum:11 avg:11 min:11 max:11
+map[3] = count:1 sum:1 avg:1 min:1 max:1
+map[4] = count:1 sum:1 avg:1 min:1 max:1
+
+CPU #2
+map[1] = count:1 sum:2 avg:2 min:2 max:2
+map[2] = count:1 sum:21 avg:21 min:21 max:21
+map[3] = count:1 sum:4 avg:4 min:4 max:4
+map[4] = count:1 sum:1 avg:1 min:1 max:1
+
+CPU #3
+map[1] = count:1 sum:3 avg:3 min:3 max:3
+map[2] = count:1 sum:31 avg:31 min:31 max:31
+map[3] = count:1 sum:9 avg:9 min:9 max:9
+map[4] = count:1 sum:1 avg:1 min:1 max:1
+
+CPU #4
+map[1] = count:1 sum:4 avg:4 min:4 max:4
+map[2] = count:1 sum:41 avg:41 min:41 max:41
+map[3] = count:1 sum:16 avg:16 min:16 max:16
+map[4] = count:1 sum:1 avg:1 min:1 max:1
+
+CPU #5
+map[1] = count:1 sum:5 avg:5 min:5 max:5
+map[2] = count:1 sum:51 avg:51 min:51 max:51
+map[3] = count:1 sum:25 avg:25 min:25 max:25
+map[4] = count:1 sum:1 avg:1 min:1 max:1
+
+CPU #6
+map[1] = count:1 sum:6 avg:6 min:6 max:6
+map[2] = count:1 sum:61 avg:61 min:61 max:61
+map[3] = count:1 sum:36 avg:36 min:36 max:36
+map[4] = count:1 sum:1 avg:1 min:1 max:1
+
+CPU #7
+map[1] = count:1 sum:7 avg:7 min:7 max:7
+map[2] = count:1 sum:71 avg:71 min:71 max:71
+map[3] = count:1 sum:49 avg:49 min:49 max:49
+map[4] = count:1 sum:1 avg:1 min:1 max:1
+
+map[2] = count:8 sum:288 avg:36 min:1 max:71
+value |-------------------------------------------------- count
+ 0 |@ 1
+ 10 |@ 1
+ 20 |@ 1
+ 30 |@ 1
+ 40 |@ 1
+ 50 |@ 1
+ 60 |@ 1
+ 70 |@ 1
+ 80 | 0
+ 90 | 0
+
+map[4] = count:8 sum:8 avg:1 min:1 max:1
+value |-------------------------------------------------- count
+ 0 |@@@@@@@@ 8
+ 10 | 0
+ 20 | 0
+ 30 | 0
+ 40 | 0
+ 50 | 0
+ 60 | 0
+ 70 | 0
+ 80 | 0
+ 90 | 0
+
+map[1] = count:8 sum:28 avg:3 min:0 max:7
+value |-------------------------------------------------- count
+ 0 |@@@@@@@@ 8
+ 10 | 0
+ 20 | 0
+ 30 | 0
+ 40 | 0
+ 50 | 0
+ 60 | 0
+ 70 | 0
+ 80 | 0
+ 90 | 0
+
+map[3] = count:8 sum:140 avg:17 min:0 max:49
+value |-------------------------------------------------- count
+ 0 |@@@@ 4
+ 10 |@ 1
+ 20 |@ 1
+ 30 |@ 1
+ 40 |@ 1
+ 50 | 0
+ 60 | 0
+ 70 | 0
+ 80 | 0
+ 90 | 0
+
+}
+
+test map_format {Test of map formatting and histograms} -setup {
+ exec gcc $CFLAGS -I $KPATH -I $PATH -I $MPATH -o test map_format.c
+} -body {
+ exec ./test
+} -result {Columbus -> mapiis 1 2 Ohio
+Salem -> mapiis 7 8 Oregon
+Olympia -> mapiis 5 6 Washington
+Sacramento -> mapiis 3 4 California
+
+Columbus % Ohio
+Salem % Oregon
+Olympia % Washington
+Sacramento % California
+
+Columbus -> mapiis
+Salem -> mapiis
+Olympia -> mapiis
+Sacramento -> mapiis
+
+The capitol of Riga is Latvia and the nerd population is 212063400820736
+The capitol of Sofia is Bulgaria and the nerd population is -2400999087387945352
+The capitol of Nicosia is Cyprus and the nerd population is -1
+The capitol of Valletta is Malta and the nerd population is 1
+
+The capitol of Riga is Latvia and the nerd population is c0dedbad0000
+The capitol of Sofia is Bulgaria and the nerd population is deadf00d12345678
+The capitol of Nicosia is Cyprus and the nerd population is ffffffffffffffff
+The capitol of Valletta is Malta and the nerd population is 1
+
+The capitol of Riga is Latvia and the nerd population is C0DEDBAD0000
+The capitol of Sofia is Bulgaria and the nerd population is DEADF00D12345678
+The capitol of Nicosia is Cyprus and the nerd population is FFFFFFFFFFFFFFFF
+The capitol of Valletta is Malta and the nerd population is 1
+
+Bogons per packet for Riga
+count:49600 sum:3288450 avg:66 min:0 max:99
+value |-------------------------------------------------- count
+ 0 |@@ 460
+ 10 |@@@@@@@ 1460
+ 20 |@@@@@@@@@@@@ 2460
+ 30 |@@@@@@@@@@@@@@@@@@ 3460
+ 40 |@@@@@@@@@@@@@@@@@@@@@@@ 4460
+ 50 |@@@@@@@@@@@@@@@@@@@@@@@@@@@@ 5460
+ 60 |@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@ 6460
+ 70 |@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@ 7460
+ 80 |@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@ 8460
+ 90 |@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@ 9460
+
+Bogons per packet for Sofia
+count:100 sum:2025 avg:20 min:0 max:81
+value |-------------------------------------------------- count
+ 0 |@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@ 42
+ 10 |@@@@@@@@@@@@@@@@@ 17
+ 20 |@@@@@@@@@@@@@ 13
+ 30 |@@@@@@@@@ 9
+ 40 |@@@@@@@@@ 9
+ 50 |@@@@ 4
+ 60 |@@@ 3
+ 70 |@@ 2
+ 80 |@ 1
+ 90 | 0
+
+Bogons per packet for Valletta
+count:45 sum:2850 avg:63 min:10 max:90
+value |-------------------------------------------------- count
+ 0 | 0
+ 10 |@ 1
+ 20 |@@ 2
+ 30 |@@@ 3
+ 40 |@@@@ 4
+ 50 |@@@@@ 5
+ 60 |@@@@@@ 6
+ 70 |@@@@@@@ 7
+ 80 |@@@@@@@@ 8
+ 90 |@@@@@@@@@ 9
+
+
+49600 was the count for Riga, Latvia
+100 was the count for Sofia, Bulgaria
+45 was the count for Valletta, Malta
+
+mapssx[ Riga, Latvia] = 322D82
+mapssx[ Sofia, Bulgaria] = 7E9
+mapssx[ Valletta, Malta] = B22}
+
+catch {exec rm test}
+
+cleanupTests
diff --git a/runtime/tests/pmaps/si.c b/runtime/tests/pmaps/si.c
new file mode 100644
index 00000000..49eb3caf
--- /dev/null
+++ b/runtime/tests/pmaps/si.c
@@ -0,0 +1,59 @@
+#include "runtime.h"
+
+/* test of pmaps with keys of string and value of int64 */
+
+/* It's not clear this would ever be used in the systemtap language.
+ It would be useful as an array of counters. */
+
+#define VALUE_TYPE INT64
+#define KEY1_TYPE STRING
+#include "pmap-gen.c"
+
+#include "map.c"
+
+int main ()
+{
+ MAP map = _stp_pmap_new_si(4);
+ int64_t x;
+
+ /* put some data in. _processor_number is a global hack that allows */
+ /* us to set the current emulated cpu number for our userspace tests. */
+ /* Note that we set values based on the cpu number just to show that */
+ /* different values are stored in each cpu */
+ for (_processor_number = 0; _processor_number < NR_CPUS; _processor_number++) {
+ _stp_pmap_add_si(map, "ONE", _processor_number);
+ _stp_pmap_add_si(map, "TWO", 10 *_processor_number + 1);
+ _stp_pmap_add_si(map, "THREE", _processor_number * _processor_number);
+ _stp_pmap_add_si(map, "FOUR", 1);
+ }
+
+ /* read it back out and verify. Use the special get_cpu call to get non-aggregated data */
+ for (_processor_number = 0; _processor_number < NR_CPUS; _processor_number++) {
+ x = _stp_pmap_get_cpu_si (map, "THREE");
+ if (x != _processor_number * _processor_number)
+ printf("ERROR: Got %lld when expected %lld\n", x, (long long)(_processor_number * _processor_number));
+ x = _stp_pmap_get_cpu_si (map, "ONE");
+ if (x != _processor_number)
+ printf("ERROR: Got %lld when expected %lld\n", x, (long long)_processor_number);
+ x = _stp_pmap_get_cpu_si (map, "TWO");
+ if (x != 10 * _processor_number + 1)
+ printf("ERROR: Got %lld when expected %lld\n", x, (long long)(10 * _processor_number + 1));
+ x = _stp_pmap_get_cpu_si (map, "FOUR");
+ if (x != 1LL)
+ printf("ERROR: Got %lld when expected %lld\n", x, 1LL);
+ }
+
+ /* now print the per-cpu data */
+ for (_processor_number = 0; _processor_number < NR_CPUS; _processor_number++) {
+ printf("CPU #%d\n", _processor_number);
+ _stp_pmap_printn_cpu (map,0, "map[%1s] = %d", _processor_number);
+ }
+ _processor_number = 0;
+
+ /* print the aggregated data */
+ _stp_pmap_print(map,"map[%1s] = %d");
+
+ _stp_pmap_del (map);
+ return 0;
+}
+