diff options
author | Bryan Cantrill <bryan@joyent.com> | 2012-09-18 00:50:06 +0000 |
---|---|---|
committer | Richard Lowe <richlowe@richlowe.net> | 2014-02-25 12:54:01 -0500 |
commit | d339a29bb4765c4b6883a935cf69b669cd05bca0 (patch) | |
tree | e72f7f94c3ee4139fc13c178524c48ec23a6ec60 /usr/src | |
parent | aea650180b31dd5423d26fc0e8ae6b3a4dc50137 (diff) | |
download | illumos-joyent-d339a29bb4765c4b6883a935cf69b669cd05bca0.tar.gz |
4478 dtrace_dof_maxsize is far too small
Reviewed by: Keith Wesolowski <keith.wesolowski@joyent.com>
Reviewed by: Matthew Ahrens <mahrens@delphix.com>
Approved by: Gordon Ross <gwr@nexenta.com>
Diffstat (limited to 'usr/src')
-rw-r--r-- | usr/src/cmd/dtrace/test/tst/common/misc/tst.dofmax.ksh | 97 | ||||
-rw-r--r-- | usr/src/pkg/manifests/system-dtrace-tests.mf | 1 | ||||
-rw-r--r-- | usr/src/uts/common/dtrace/dtrace.c | 2 |
3 files changed, 99 insertions, 1 deletions
diff --git a/usr/src/cmd/dtrace/test/tst/common/misc/tst.dofmax.ksh b/usr/src/cmd/dtrace/test/tst/common/misc/tst.dofmax.ksh new file mode 100644 index 0000000000..22c267dcfc --- /dev/null +++ b/usr/src/cmd/dtrace/test/tst/common/misc/tst.dofmax.ksh @@ -0,0 +1,97 @@ +# +# CDDL HEADER START +# +# The contents of this file are subject to the terms of the +# Common Development and Distribution License (the "License"). +# You may not use this file except in compliance with the License. +# +# You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE +# or http://www.opensolaris.org/os/licensing. +# See the License for the specific language governing permissions +# and limitations under the License. +# +# When distributing Covered Code, include this CDDL HEADER in each +# file and include the License file at usr/src/OPENSOLARIS.LICENSE. +# If applicable, add the following below this CDDL HEADER, with the +# fields enclosed by brackets "[]" replaced with your own identifying +# information: Portions Copyright [yyyy] [name of copyright owner] +# +# CDDL HEADER END +# + +# +# Copyright (c) 2012, Joyent, Inc. All rights reserved. +# + +let j=8 + +enable() +{ + prog=/var/tmp/dtest.$$.d + err=/var/tmp/dtest.$$.err + + nawk -v nprobes=$1 'BEGIN { \ + for (i = 0; i < nprobes - 1; i++) { \ + printf("dtrace:::BEGIN,\n"); \ + } \ + \ + printf("dtrace:::BEGIN { exit(0); }\n"); \ + }' /dev/null > $prog + + dtrace -qs $prog > /dev/null 2> $err + + if [[ "$?" -eq 0 ]]; then + return 0 + else + if ! grep "DIF program exceeds maximum program size" $err \ + 1> /dev/null 2>&1 ; then + echo "failed to enable $prog: `cat $err`" + exit 1 + fi + + return 1 + fi +} + +# +# First, establish an upper bound +# +let upper=1 + +while enable $upper ; do + let lower=upper + let upper=upper+upper + echo success at $lower, raised to $upper +done + +# +# Now search for the highest value that can be enabled +# +while [[ "$lower" -lt "$upper" ]]; do + let guess=$(((lower + upper) / 2)) + echo "lower is $lower; upper is $upper; guess is $guess\c" + + if enable $guess ; then + if [[ $((upper - lower)) -le 2 ]]; then + let upper=guess + fi + + echo " (success)" + let lower=guess + else + echo " (failure)" + let upper=guess + fi +done + +let expected=10000 + +if [[ "$lower" -lt "$expected" ]]; then + echo "expected support for enablings of at least $expected probes; \c" + echo "found $lower" + exit 1 +fi + +echo "maximum supported enabled probes found to be $lower" +exit 0 + diff --git a/usr/src/pkg/manifests/system-dtrace-tests.mf b/usr/src/pkg/manifests/system-dtrace-tests.mf index e6126f532b..75f54afe37 100644 --- a/usr/src/pkg/manifests/system-dtrace-tests.mf +++ b/usr/src/pkg/manifests/system-dtrace-tests.mf @@ -1054,6 +1054,7 @@ file path=opt/SUNWdtrt/tst/common/misc/err.D_PRAGMA_OPTSET.d mode=0444 file path=opt/SUNWdtrt/tst/common/misc/tst.badopt.d mode=0444 file path=opt/SUNWdtrt/tst/common/misc/tst.boolopt.d mode=0444 file path=opt/SUNWdtrt/tst/common/misc/tst.boolopt.d.out mode=0444 +file path=opt/SUNWdtrt/tst/common/misc/tst.dofmax.ksh mode=0444 file path=opt/SUNWdtrt/tst/common/misc/tst.dynopt.d mode=0444 file path=opt/SUNWdtrt/tst/common/misc/tst.dynopt.d.out mode=0444 file path=opt/SUNWdtrt/tst/common/misc/tst.enablerace.ksh mode=0444 diff --git a/usr/src/uts/common/dtrace/dtrace.c b/usr/src/uts/common/dtrace/dtrace.c index afff7be41a..3c6140980a 100644 --- a/usr/src/uts/common/dtrace/dtrace.c +++ b/usr/src/uts/common/dtrace/dtrace.c @@ -117,7 +117,7 @@ int dtrace_destructive_disallow = 0; dtrace_optval_t dtrace_nonroot_maxsize = (16 * 1024 * 1024); size_t dtrace_difo_maxsize = (256 * 1024); -dtrace_optval_t dtrace_dof_maxsize = (256 * 1024); +dtrace_optval_t dtrace_dof_maxsize = (8 * 1024 * 1024); size_t dtrace_global_maxsize = (16 * 1024); size_t dtrace_actions_max = (16 * 1024); size_t dtrace_retain_max = 1024; |