summaryrefslogtreecommitdiffstats
path: root/testsuite/systemtap.maps/pmap_agg_overflow.stp
diff options
context:
space:
mode:
authorfche <fche>2006-08-12 05:13:09 +0000
committerfche <fche>2006-08-12 05:13:09 +0000
commit814bc89d4635f101b2c0077598f31aad95ed15b7 (patch)
tree407a49dbaf446af4751f5068607a7fb8dad0611d /testsuite/systemtap.maps/pmap_agg_overflow.stp
parent6b6d04673a1ef175821afc7d4fabdb496698e8e3 (diff)
downloadsystemtap-steved-814bc89d4635f101b2c0077598f31aad95ed15b7.tar.gz
systemtap-steved-814bc89d4635f101b2c0077598f31aad95ed15b7.tar.xz
systemtap-steved-814bc89d4635f101b2c0077598f31aad95ed15b7.zip
2006-08-12 Frank Ch. Eigler <fche@elastic.org>
* configure.ac, Makefile.am: Descend into testsuite/ directory. Remove local test logic. * configure, Makefile.in: Regenerated. * runtest.sh: Not yet removed. * HACKING: Update for new testsuite layout. 2006-08-12 Frank Ch. Eigler <fche@elastic.org> * all: Reorganized old pass-1..4 tests one dejagnu bucket. Moved over old pass-5 tests, except for disabled syscalls tests. * Makefile (installcheck): New target for running pass-1..5 tests against installed systemtap.
Diffstat (limited to 'testsuite/systemtap.maps/pmap_agg_overflow.stp')
-rwxr-xr-xtestsuite/systemtap.maps/pmap_agg_overflow.stp38
1 files changed, 38 insertions, 0 deletions
diff --git a/testsuite/systemtap.maps/pmap_agg_overflow.stp b/testsuite/systemtap.maps/pmap_agg_overflow.stp
new file mode 100755
index 00000000..81268550
--- /dev/null
+++ b/testsuite/systemtap.maps/pmap_agg_overflow.stp
@@ -0,0 +1,38 @@
+# try to induce overflow of pmap aggregation
+# (this will only work on smp machines)
+
+global stat, count, max_count
+
+probe begin {
+ if (num_online_cpus() < 2) {
+ warn("This test only applies to smp systems...")
+ exit()
+ }
+ max_count = num_online_cpus() * max_map_entries()
+}
+
+probe timer.profile {
+ i = ++count
+ if (i >= max_count) exit()
+ stat[i] <<< i
+}
+
+probe end {
+ # pmap aggregation should overflow here
+ foreach (i in stat)
+ printf("@count(stat[%d]) = %d\n", i, @count(stat[i]))
+}
+
+probe end {
+ # sorted pmap aggregation should overflow here
+ foreach (i+ in stat)
+ printf("@count(stat[%d]) = %d\n", i, @count(stat[i]))
+}
+
+function max_map_entries:long() %{
+ THIS->__retvalue = MAXMAPENTRIES;
+%}
+
+function num_online_cpus:long() %{
+ THIS->__retvalue = num_online_cpus();
+%}