]> sourceware.org Git - systemtap.git/log
systemtap.git
14 years agocheck for module-building Makefile more clearly
Frank Ch. Eigler [Wed, 14 Oct 2009 17:16:28 +0000 (13:16 -0400)]
check for module-building Makefile more clearly

* buildrun.cxx (compile_pass): stat the Makefile, not just the build/
  directory.

14 years agoMerge branch 'master' of ssh://sourceware.org/git/systemtap
Tim Moore [Wed, 14 Oct 2009 16:45:25 +0000 (18:45 +0200)]
Merge branch 'master' of ssh://sourceware.org/git/systemtap

14 years agocleanup of graph data parser, using Boost functions where useful
Tim Moore [Wed, 14 Oct 2009 15:46:31 +0000 (17:46 +0200)]
cleanup of graph data parser, using Boost functions where useful

* grapher/StapParser.cxx (commaSplit): Use Boost string split function
  (findTaggedValue): Return bool instead of position
  (ioCallback): Avoid using hard-coded string lengths

14 years agoAdd DTRACE_PROBE10.
Mark Wielaard [Wed, 14 Oct 2009 10:46:51 +0000 (12:46 +0200)]
Add DTRACE_PROBE10.

We already had STAP_PROBE10, but not DTRACE_PROBE10 yet.

* includes/sys/sdt.h: Declare DTRACE_PROBE10 as STAP_PROBE10.

14 years agoMerge branch 'master' of ssh://wenji@sources.redhat.com/git/systemtap
Wenji Huang [Wed, 14 Oct 2009 02:26:03 +0000 (10:26 +0800)]
Merge branch 'master' of ssh://wenji@sources.redhat.com/git/systemtap

14 years agoMerge branch 'master' of sourceware.org:/git/systemtap
Josh Stone [Wed, 14 Oct 2009 02:20:05 +0000 (19:20 -0700)]
Merge branch 'master' of sourceware.org:/git/systemtap

14 years agoPR10746: update test cases related to probe process.*
Wenji Huang [Wed, 14 Oct 2009 02:19:05 +0000 (10:19 +0800)]
PR10746: update test cases related to probe process.*

* testsuite/semok/utrace01.stp: Switch by CONFIG_UTRACE.
* testsuite/systemtap.base/bz10294.stp: Ditto.
* testsuite/systemtap.base/bz6905.stp: Ditto.
* testsuite/systemtap.base/statement.exp: Mark untested if
  non-utrace kernel.

14 years agoConsolidate print_format creation
Josh Stone [Tue, 13 Oct 2009 23:57:38 +0000 (16:57 -0700)]
Consolidate print_format creation

We almost had a factory in print_format::parse_print, so let's take that
the rest of the way.  This way we don't have so much duplication in
initializing the print flags.

* staptree.cxx (print_format::parse_print): Replaced with...
  (print_format::create): New factory to parse and create print_formats.
* elaborate.cxx (add_global_var_display): Use this factory.
* parse.cxx (parser::parse_symbol): Ditto.
* tapset-mark.cxx
  (mark_var_expanding_visitor::visit_target_symbol_context): Ditto.
* tapset-utrace.cxx
  (utrace_var_expanding_visitor::visit_target_symbol_arg): Ditto.
* tapsets.cxx
  (dwarf_var_expanding_visitor::visit_target_symbol_context): Ditto.
  (tracepoint_var_expanding_visitor::visit_target_symbol_context) Ditto.

14 years agoruntime shutdown errors: simplify, improve error specificity
Frank Ch. Eigler [Tue, 13 Oct 2009 21:33:29 +0000 (17:33 -0400)]
runtime shutdown errors: simplify, improve error specificity

* transport/control.c (*_cmd): Return -Ecodes rather than "-1" from
  file_operations callbacks.
* staprun/ctl.c (init_ctl_channel): Return distinct error codes.
* staprun/staprun.c (remove_module): Skip connection attempt to .ctl
  file; just do delete_module() with O_NONBLOCK.

14 years agoRefactor some of the histogram printing
Josh Stone [Tue, 13 Oct 2009 21:10:08 +0000 (14:10 -0700)]
Refactor some of the histogram printing

* runtime/stat-common.c (reprint_buf): Removed.
  (_stp_stat_print_histogram_buf): Use a local HIST_PRINTF macro to
  abstract the buffer management.  Also convert reprint_buf calls to
  either %* formats or simple for-loops.

14 years agoAdd buildok tests for sprint[ln](@hist_*)
Josh Stone [Tue, 13 Oct 2009 21:07:58 +0000 (14:07 -0700)]
Add buildok tests for sprint[ln](@hist_*)

14 years agoPR10257: Add support for sprint[ln](@hist_*).
Przemyslaw Pawelczyk [Tue, 13 Oct 2009 12:44:29 +0000 (14:44 +0200)]
PR10257: Add support for sprint[ln](@hist_*).

* parse.cxx (parser::parse_symbol): Add sprint[ln] to @hist_* hack.
* runtime/stat-common.c: Replace reprint with new reprint_buf, add more
  generic _stp_stat_print_histogram_buf and call it from the older one.
  Also correct some formatting issues.
* translate.cxx (c_unparser::visit_print_format): Add sprint case.

14 years agoPR5434: Fix syscall.nfsservctl.
Przemyslaw Pawelczyk [Tue, 13 Oct 2009 01:23:45 +0000 (03:23 +0200)]
PR5434: Fix syscall.nfsservctl.

Use proper $vars according to CONFIG_NFSD and CONFIG_COMPAT in
syscall.nfsservctl and mask it out along with return probe if
CONFIG_NFSD != "[ym]" && CONFIG_COMPAT != "y".

* tapset/syscalls2.stp (syscall.nfsservctl): Fix it.

14 years agoLet semko/utrace.stp fail even with CONFIG_UTRACE=y
Josh Stone [Tue, 13 Oct 2009 18:59:23 +0000 (11:59 -0700)]
Let semko/utrace.stp fail even with CONFIG_UTRACE=y

14 years agoAdd a test for CONFIG_FOO wildcards
Josh Stone [Tue, 13 Oct 2009 18:50:34 +0000 (11:50 -0700)]
Add a test for CONFIG_FOO wildcards

14 years agoMerge branch 'master' of ssh://sources.redhat.com/git/systemtap
Dave Brolley [Tue, 13 Oct 2009 18:02:26 +0000 (14:02 -0400)]
Merge branch 'master' of ssh://sources.redhat.com/git/systemtap

14 years agoPR10761: pass -v's to final "staprun -d" if appropriate
Frank Ch. Eigler [Tue, 13 Oct 2009 15:57:19 +0000 (11:57 -0400)]
PR10761: pass -v's to final "staprun -d" if appropriate

* mainloop.c (cleanup_and_exit): Remove non-BUG9788_WORKAROUND
  branch.  Remove execlp branch.  Pass -v to staprun-d if verbose.

14 years agoMerge branch 'master' of ssh://sources.redhat.com/git/systemtap
Dave Brolley [Tue, 13 Oct 2009 15:55:11 +0000 (11:55 -0400)]
Merge branch 'master' of ssh://sources.redhat.com/git/systemtap

14 years agoEnsure that unprivileged-authorized probe point functions are hashed differently
Dave Brolley [Tue, 13 Oct 2009 15:52:22 +0000 (11:52 -0400)]
Ensure that unprivileged-authorized probe point functions are hashed differently
than non-authorized ones for the purpose of removing duplicates.

2009-10-13  Dave Brolley  <brolley@redhat.com>

        * elaborate.h (print_dupe_stamp_unprivileged): New static method
        of derived_probe.
        (print_dupe_stamp_unprivileged_process_owner): Likewise.

        * elaborate.cxx (print_dupe_stamp_unprivileged): New static method
        of derived_probe.
        (print_dupe_stamp_unprivileged_process_owner): Likewise.

        * tapset-been.cxx (print_dupe_stamp): New virtual method of be_derived_p
robe
        and never_derived_probe.

        * tapset-utrace.cxx (print_dupe_stamp): New virtual method of utrace_der
ived_probe

        * tapset-itrace.cxx (itrace_derived_probe::emit_unprivileged_assertion):
 Removed.
        (itrace_builder::check_unprivileged): Removed.

        * tapsets.cxx (print_dupe_stamp): New virtual method of uprobe_derived_p
robe

14 years agoPR 10575. Improves running target commands.
David Smith [Tue, 13 Oct 2009 13:55:57 +0000 (08:55 -0500)]
PR 10575.  Improves running target commands.
* runtime/staprun/mainloop.c (signal_usr1): Renamed from signal_dontcare.
  Sets a new variable, usr1_interrupt.
  (start_cmd): Avoids pause() race condition by switching to blocking
  SIGUSR1, then waiting on SIGUSR1 with sigsuspend().

14 years agoparse: fix CONFIG_ matching typo
Frank Ch. Eigler [Tue, 13 Oct 2009 11:59:25 +0000 (07:59 -0400)]
parse: fix CONFIG_ matching typo

* parse.cxx (eval_pp_conditional): Flip rhs and lhs args for fnmatch().

14 years agoAdd the .call modifier to syscall entry probes.
Przemyslaw Pawelczyk [Sat, 10 Oct 2009 10:14:54 +0000 (12:14 +0200)]
Add the .call modifier to syscall entry probes.

Inline functions do not have an indentifiable return point and require
kernel built using VTA-enabled gcc to get tracking of variables. OTOH
syscall functions are very rarely inlined (depending on the compiler
mood), therefore filtering probes to include only non-inlined functions
ensures consistent behavior between different kernels.

This removes the problem of inaccessible variables in inlined syscalls
that is described in comments #6-9 to PR5890 and gives us the status quo
w.r.t. syscall probing, because before the commit solving PR10572
(b7478964) inline instances were masked anyway by non-inline ones.

You can check whether you have inlined syscalls using following command:
$ stap -l 'kernel.function("sys_*"),kernel.function("compat_sys_*")' \
                      2>&1 -vvv | awk '/^selected inline/{print $5}'

* tapset/syscalls.stp: Add .call to all entry probes.
* tapset/syscalls2.stp: Ditto.

14 years agoAdd task_time tapset, functions to query time resource usage of current task.
Mark Wielaard [Fri, 9 Oct 2009 21:23:12 +0000 (23:23 +0200)]
Add task_time tapset, functions to query time resource usage of current task.

* tapset/task_time.stp: New tapset.
* testsuite/buildok/task_test.stp: Add new task_time functions.
* doc/SystemTap_Tapset_Reference/tapsets.tmpl: Add new section on
  Task Time Tapset. Include tapset/task_time.stp.

14 years agoGenerate safety net assertions in probe function not authorized for unprivileged...
Dave Brolley [Fri, 9 Oct 2009 15:09:12 +0000 (11:09 -0400)]
Generate safety net assertions in probe function not authorized for unprivileged users.

2009-10-08  Dave Brolley  <brolley@redhat.com>

        * elaborate.h (emit_unprivileged_assertion): New virtual method of deriv
ed_probe.
        (emit_process_owner_assertion): New static method of derived_probe.
        (check_unprivileged): New virtual method of derived_probe_builder.
        (match_node::unprivileged_ok): Removed.
        (match_node::allow_unprivileged): Removed.
        (match_node::unprivileged_allowed): Removed.

        * elaborate.cxx (translate.h): #include it.
        (emit_unprivileged_assertion): New virtual method of derived_probe.
        (emit_process_owner_assertion): New static method of derived_probe.
        (check_unprivileged): New virtual method of derived_probe_builder.
        (match_node::unprivileged_ok): Removed.
        (match_node::allow_unprivileged): Removed.
        (match_node::unprivileged_allowed): Removed.
        (find_and_build): Don't check for unprivileged restrictions here. Call t
he
        builder's check_unprivileged method.
        (alias_expansion_builder::check_unprivileged): New virtual method.

        * tapset-been.cxx (be_derived_probe::emit_unprivileged_assertion): New v
irtual
        method.
        (be_builder::check_unprivileged): Likewise.
        (never_derived_probe::emit_unprivileged_assertion): Likewise.
        (never_builder::check_unprivileged): Likewise.
        (register_tapset_been): Don't call allow_unprivileged.

        * tapset-itrace.cxx (itrace_derived_probe::emit_unprivileged_assertion):
 New virtual
        method.
        (itrace_builder::check_unprivileged): Likewise.
        (register_tapset_itrace): Don't call allow_unprivileged.

        * tapset-utrace.cxx (utrace_derived_probe::emit_unprivileged_assertion):
 New virtual
        method.
        (utrace_builder::check_unprivileged): Likewise.
        (register_tapset_utrace): Don't call allow_unprivileged.

        * tapset-timer.cxx (timer_derived_probe::emit_unprivileged_assertion): N
ew virtual
        method.
        (timer_builder::check_unprivileged): Likewise.
        (register_tapset_timers): Don't call allow_unprivileged.

        * tapsets.cxx (uprobe_derived_probe::emit_unprivileged_assertion): New v
irtual
        method.
        (uprobe_builder::check_unprivileged): Likewise.
        (register_standard_tapsets): Don't call allow_unprivileged.
        (register_statement_variants): Remove unprivileged_ok_p parameter. Don't
 call
        allow_unprivileged.
        (register_function_variants): Likewise.
        (register_function_and_statement_variants): Likewise.
        (register_patterns): Don't call allow_unprivileged.

        * translate.cxx (emit_probe): Call v->emit_unprivileged_assertion.

14 years agotapset/proc_mem.stp: Document function parameters.
Mark Wielaard [Fri, 9 Oct 2009 12:31:18 +0000 (14:31 +0200)]
tapset/proc_mem.stp: Document function parameters.

14 years agoPR10746: improve error message on utrace-less kernels
Frank Ch. Eigler [Thu, 8 Oct 2009 21:36:36 +0000 (17:36 -0400)]
PR10746: improve error message on utrace-less kernels

* tapset-itrace.exp (itrace_derived_probe ctor): Fail if !CONFIG_UTRACE.
* tapset-utrace.exp (utrace_derived_probe ctor): Fail if !CONFIG_UTRACE.
* tapsets.cxx (dwarf_builder::build): Fail process.* if !CONFIG_UTRACE.
* testsuite/semko/utrace.stp: New test.

14 years agoexamples: regen indexes
Frank Ch. Eigler [Thu, 8 Oct 2009 21:23:42 +0000 (17:23 -0400)]
examples: regen indexes

14 years agoexamples: add mbrwatch sample
Frank Ch. Eigler [Thu, 8 Oct 2009 21:21:08 +0000 (17:21 -0400)]
examples: add mbrwatch sample

14 years agotestsuite: robustify check_* invocation of examples meta
Frank Ch. Eigler [Thu, 8 Oct 2009 21:18:51 +0000 (17:18 -0400)]
testsuite: robustify check_* invocation of examples meta

testsuite/systemtap.examples/

* check.exp (extract_tag): Log extracted tags.  Tolerate embedded '$'.
  (run_command): Pass through commands to sh -c without eval quoting.
* README: Document "sh -c"-ness of check_* tags.
* *.meta: Fix quoting, add a few check_support predicates.

14 years agoThis script (tcp_trace) can be used to trace tcp connection parameters and state...
David J. Wilder [Thu, 8 Oct 2009 18:00:20 +0000 (11:00 -0700)]
This script (tcp_trace) can be used to trace tcp connection parameters and state changes.  This work was original inspired by Stephen Hemminger's TCP cwnd snooper (net/ipv4/tcp_probe.c). Tcp_trace is a helpful tool for troubleshooting connection performance issues.

14 years agoPR10702: preprocessor conditional for kernel CONFIG_foo
Frank Ch. Eigler [Thu, 8 Oct 2009 13:57:43 +0000 (09:57 -0400)]
PR10702: preprocessor conditional for kernel CONFIG_foo

* session.h (kernel_config[]): New session field.
* main.cxx (parse_kernel_config): Populate it.
* parse.cxx (eval_comparison): Use it.
* testsuite/buildok/utrace.stp, testsuite/parseok/kconfig.stp: New tests.
* NEWS, stap.1.in, doc/langref.tex: Mention it.

14 years agobuild: fix !HAVE_NSS case
Frank Ch. Eigler [Wed, 7 Oct 2009 22:31:07 +0000 (18:31 -0400)]
build: fix !HAVE_NSS case

* staprun_funcs.c (assert_permissions): Move "check_signature_rc"
  variable inside #if HAVE_NSS.

14 years agoMerge commit 'origin/master'
Tim Moore [Wed, 7 Oct 2009 18:10:17 +0000 (20:10 +0200)]
Merge commit 'origin/master'

14 years agoAdded man page for stapgraph
Tim Moore [Wed, 7 Oct 2009 18:08:50 +0000 (20:08 +0200)]
Added man page for stapgraph

* grapher/stapgraph.1.in: new file

14 years agoRemove the global derived_probe->semaphore map
Josh Stone [Wed, 7 Oct 2009 03:01:13 +0000 (20:01 -0700)]
Remove the global derived_probe->semaphore map

Instead just make the semaphore address a member of derived_probe.

* session.h (systemtap_session): Remove the map sdt_semaphore_addr.
* elaborate.h (derived_probe): Add sdt_semaphore_addr directly.
* tapsets.cxx (sdt_query::record_semaphore): Write the addr directly.
  (uprobe_derived_probe_group::emit_module_decls): Read it directly.
* tapset-utrace.cxx (utrace_derived_probe_group::emit_probe_decl): Ditto

14 years agoAdd proc_mem tapset, functions to query memory usage of the current process.
Mark Wielaard [Tue, 6 Oct 2009 17:24:22 +0000 (19:24 +0200)]
Add proc_mem tapset, functions to query memory usage of the current process.

* tapset/proc_mem.stp: New tapset.
* testsuite/buildok/proc_mem.stp
* doc/SystemTap_Tapset_Reference/tapsets.tmpl (memory_stp): Include
  tapset/proc_mem.stp.

14 years agoPR10724: staprun: simplify permissions checking logic
Charley Wang [Tue, 6 Oct 2009 14:26:36 +0000 (10:26 -0400)]
PR10724: staprun: simplify permissions checking logic

Pending advice from Frank and Dave, changed check_permission to return void and
renamed it to assert_permission. assert_permission simply returns if
permissions are okay, and calls exit(-1) if there are any permissions errors.

14 years agoPR10726 remove testcase workaround.
Mark Wielaard [Tue, 6 Oct 2009 13:26:58 +0000 (15:26 +0200)]
PR10726 remove testcase workaround.

* testsuite/systemtap.base/const_value.c: Allow inlining since PR10726 was
  fixed.

14 years agoPR10739 testcase. Split const_value test in two. Absolute const addr fails.
Mark Wielaard [Tue, 6 Oct 2009 13:22:21 +0000 (15:22 +0200)]
PR10739 testcase. Split const_value test in two. Absolute const addr fails.

* testsuite/systemtap.base/const_value.exp: Handle both const_value blocks
  and address separately. XFAIL second test as PR10739.
* testsuite/systemtap.base/const_value.stp: Only query baz const value.
* testsuite/systemtap.base/const_value_func.c: New test for bar address.
* testsuite/systemtap.base/const_value_func.stp: Likewise.

14 years agoPR10726: Get the correct scope for statement(NUM)
Josh Stone [Tue, 6 Oct 2009 00:41:30 +0000 (17:41 -0700)]
PR10726: Get the correct scope for statement(NUM)

The problem in this bug is that our statement(NUM) lookup was only
searching for the outermost function (not inlined) which contains the PC
in question.  When that PC happens to be the beginning of the function
and also the beginning of an inline, the caching was using the wrong
variable scope.

The function/statement(NUM) lookup has been rewritten to bypass all of
the CU and function iteration, and just go straight to a getscopes(pc)
lookup, so it will now always use the innermost containing die for the
variable scope.

* tapsets.cxx (query_addr): New, short-circuit for numeric probes.
  (dwarf_query::query_module_dwarf): Route num probes to query_addr.
  (query_label): Assume now that we only need to handle _str probes.
  (query_dwarf_inline_instance): Ditto.
  (query_dwarf_func): Ditto.
  (query_cu): Ditto.

14 years agoNEWS: Better gcc 4.5 DWARF support (kernel module deps, DW_AT_const_value).
Mark Wielaard [Mon, 5 Oct 2009 08:22:59 +0000 (10:22 +0200)]
NEWS: Better gcc 4.5 DWARF support (kernel module deps, DW_AT_const_value).

14 years agoAdd tescase for DW_AT_const_value location descriptions.
Mark Wielaard [Mon, 5 Oct 2009 07:14:49 +0000 (09:14 +0200)]
Add tescase for DW_AT_const_value location descriptions.

* testsuite/systemtap.base/const_value.c: New test.
* testsuite/systemtap.base/const_value.exp: Likewise.
* testsuite/systemtap.base/const_value.stp: Likewise.

14 years agoHandle DW_AT_const_value as alternative to location description.
Mark Wielaard [Mon, 5 Oct 2009 07:11:59 +0000 (09:11 +0200)]
Handle DW_AT_const_value as alternative to location description.

* dwflpp.cxx (translate_location): Call c_translate_constant when
  attribute is DW_AT_const_value.
  (literal_stmt_for_local): Allow  both DW_AT_location and DW_AT_const_value.

14 years agoMake sure loc2c declare_noncontig_union for different locs don't overlap.
Mark Wielaard [Mon, 5 Oct 2009 07:05:29 +0000 (09:05 +0200)]
Make sure loc2c declare_noncontig_union for different locs don't overlap.

* loc2c.c (declare_noncontig_union): Name union u_pieces for
  loc_noncontiguous or u_const for loc_constant.
  (translate_base_store): Use u_pieces for loc_noncontiguous.
  (translate_base_fetch): Likewise or u_const for loc_constant.

14 years agoAUTHORS bump for Kiran
Josh Stone [Fri, 2 Oct 2009 23:50:18 +0000 (16:50 -0700)]
AUTHORS bump for Kiran

14 years agoUpdates samples index for sched_switch
Josh Stone [Fri, 2 Oct 2009 23:42:44 +0000 (16:42 -0700)]
Updates samples index for sched_switch

14 years agoScheduler Tapset based on kernel tracepoints
Kiran Prakesh [Thu, 1 Oct 2009 17:09:32 +0000 (22:39 +0530)]
Scheduler Tapset based on kernel tracepoints

This patch adds kernel tracepoints based probes to the scheduler tapset
along with the testcase, scheduler-test-tracepoints.stp and an example
script, sched_switch.stp.

Signed-off-by: Kiran Prakash <kiran@linux.vnet.ibm.com>
Signed-off-by: Josh Stone <jistone@redhat.com>
14 years agoindent tapset: make O(1) rather than O(n)
Frank Ch. Eigler [Fri, 2 Oct 2009 20:24:00 +0000 (16:24 -0400)]
indent tapset: make O(1) rather than O(n)

* tapset/indent.stp (_generic_indent): Use "%-*s" instead of
  string concatenation loop.

14 years agoFix stap-server bug. --unprivileged not processed if processed as first argument.
Dave Brolley [Fri, 2 Oct 2009 20:20:31 +0000 (16:20 -0400)]
Fix stap-server bug. --unprivileged not processed if processed as first argument.

14 years agoloc2c discontiguify loops for not small enough loc_constant.
Mark Wielaard [Fri, 2 Oct 2009 15:07:10 +0000 (17:07 +0200)]
loc2c discontiguify loops for not small enough loc_constant.

* loc2c.c (loc_constant): Add offset to size after creating piece in
  loc_constant loop.

14 years agoPR10678 vta-gcc: module debuginfo: relocation refers to undefined symbol
Mark Wielaard [Thu, 1 Oct 2009 22:28:46 +0000 (00:28 +0200)]
PR10678 vta-gcc: module debuginfo: relocation refers to undefined symbol

libdwfl tries to resolve all relocations in a module debuginfo file and
if it cannot find a symbol used in a relocation it will fail when
dwfl_module_getdwarf() is called. So we must make sure all possible
dependencies of the module are also in the dwfl. We do this by trying
to find and parse the modules.dep file and insert all dependencies
into the dwfl.

* setupdwfl.cxx (elfutils_kernel_path): Lift from setup_dwfl_kernel and
  make static.
  (is_comma_dash): New function.
  (modname_from_path): Likewise.
  (setup_mod_deps): Likewise.
  (setup_dwfl_report_kernel_p): Call setup_mod_deps().
* testsuite/buildok/pr10678.stp: New test.

14 years agoFixed grapher build.
David Smith [Thu, 1 Oct 2009 18:07:12 +0000 (13:07 -0500)]
Fixed grapher build.
* systemtap.spec: Updated grapher's buildreqs and file list.

14 years agoGrapher support now also needs libglademm24-devel, version 2.6.7 or higher.
Mark Wielaard [Thu, 1 Oct 2009 13:30:20 +0000 (15:30 +0200)]
Grapher support now also needs libglademm24-devel, version 2.6.7 or higher.

* configure.ac: Clarify fail/help string when gtkmm support wasn't found.
* configure: Regenerated.

14 years agoAdd DEBUG_UPROBES for sdt semaphores.
Stan Cox [Thu, 1 Oct 2009 13:18:21 +0000 (09:18 -0400)]
Add DEBUG_UPROBES for sdt semaphores.

* tapsets.cxx (uprobe_derived_probe_group::emit_module_decls):  Add
DEBUG_UPROBES for sdt semaphores
* dtrace.in (main): Add -k option to keep around the temp files.

14 years agoPrint total memory usage in verbose mode after pass 1, 2 and 3.
Mark Wielaard [Thu, 1 Oct 2009 12:22:23 +0000 (14:22 +0200)]
Print total memory usage in verbose mode after pass 1, 2 and 3.

Makes it easier to see which probe queries use lots of memory.

* main.cxx (getmemusage): New function.
  (main): Use new function printing passes in verbose mode.

14 years agoActually indent_thread() is a very useful function, but
Breno Leitao [Thu, 1 Oct 2009 03:09:07 +0000 (00:09 -0300)]
Actually indent_thread() is a very useful function, but
sometimes you're probing something that is not related to
any task, as an interrupt function, and if the application
changes during the interrupt, the indentation gets confused.
For example:

    0 swapper(0): -> neo_copy_data_from_queue_to_uart
    69 a.out(7659):   -> neo_parse_modem
    74 a.out(7659):    -> neo_param
    14 swapper(0): <- neo_copy_data_from_queue_to_uart
    83 a.out(7659):  -> jsm_carrier
    86 a.out(7659):  <- jsm_carrier
     0 swapper(0): -> neo_parse_modem
    94 a.out(7659): <- jsm_tty_set_termios
     8 swapper(0): <- neo_parse_modem

So, I decided to create a simpler function that doesn't
consider the task.

Much of the idea of this implementation came from Frank(Thanks)

14 years agodoc build: support older xmlto without --stringparm option
Frank Ch. Eigler [Wed, 30 Sep 2009 23:07:26 +0000 (19:07 -0400)]
doc build: support older xmlto without --stringparm option

* configure.ac: Check for xmlto --stringparam support.
* doc/Systemtap_Tapset_Reference/Makefile.am: Be sensitive to the result.

14 years agodialog for choosing stap script and providing arguments to stap and the script
Tim Moore [Wed, 30 Sep 2009 17:02:42 +0000 (19:02 +0200)]
dialog for choosing stap script and providing arguments to stap and the script

* grapher/grapher.cxx (GraphicalStapLauncher): New class.
  (GrapherWindow constructor): Bind actions for graphical launcher buttons
  (GrapherWindow::setGraphicalLauncher): new method
  (GrapherWindow::on_menu_script_start): new method
  grapher/stap-start.glade, grapher/stap-start.gladep: new files
  grapher/Makefile.am: install stap-start.glade

14 years agoclasses for launching stap and listening for its death
Tim Moore [Wed, 23 Sep 2009 16:03:00 +0000 (18:03 +0200)]
classes for launching stap and listening for its death

* grapher/grapher.cxx (ChildDeathReader): New class to handle I/O signalling
  death of a child.
  (GrapherWindow): Inherit from ChildDeathReader.
  (StapLauncher): New class for passing arguments to inferior stap process
  and checking for its demise.
  (main): Move launching logic to StapLauncher.

14 years agoPass command line arguments on to stap
Tim Moore [Mon, 21 Sep 2009 20:35:17 +0000 (22:35 +0200)]
Pass command line arguments on to stap

* grapher/grapher.cxx (main): Pass program arguments to stap

14 years agocleanup of graph data dialog
Tim Moore [Wed, 16 Sep 2009 17:15:21 +0000 (19:15 +0200)]
cleanup of graph data dialog

* grapher/GraphWidget.cxx (on_button_release_event, onDataAdd): tweaks
for graph data dialog

14 years agographer: Handle the death of the child stap process
Tim Moore [Wed, 16 Sep 2009 17:06:29 +0000 (19:06 +0200)]
grapher: Handle the death of the child stap process

* grapher/grapher.c (main): Set up signal and i/o handlers to detect death
  of child.
* grapher/StapParser.cxx (errIoCallback): New method

14 years agoCreate lists of graph data to choose
Tim Moore [Wed, 2 Sep 2009 13:16:26 +0000 (15:16 +0200)]
Create lists of graph data to choose

14 years agoAdd graph data chooser window, based on glade
Tim Moore [Wed, 2 Sep 2009 10:39:05 +0000 (12:39 +0200)]
Add graph data chooser window, based on glade

* configure.ac: Test for libglademm
* grapher/GraphWidget.hxx (DataModelColumns): new class
  (onDataDialogCancel, void onDataAdd, onDataRemove, onDataDialogOpen):
  new methods
* grapher/GraphWidget.cxx: ditto; methods for the graph data dialog.
* grapher/graph-dialog.glade: New file.
* grapher/graph-dialog.gladep: New file.
* grapher/Makefile.am (dist_pkgdata_DATA): add graph-dialog.glade to
  installation.
* grapher/GraphWidget.cxx (GraphWidget constructor): Use PKGDATADIR

14 years agomore multiple graph fixes
Tim Moore [Tue, 4 Aug 2009 21:46:02 +0000 (23:46 +0200)]
more multiple graph fixes

* grapher/Graph.cxx (Graph constructor): set _drawX, _drawY
* grapher/GraphWidget.cxx (addGraph): Fix graph layout
(on_button_press_event): Fix test of play button in multiple graphs

14 years agoDraw multiple graphs
Tim Moore [Wed, 29 Jul 2009 11:11:10 +0000 (13:11 +0200)]
Draw multiple graphs

* grapher/Graph.cxx (Graph constructor): Initialize graph dimensions.
(draw): Don't clear the drawing area.
* grapher/GraphWidget.hxx (GraphWidget): Add dimensions and
on_size_request() method.
* grapher/GraphWidget.cxx (GraphWidget constructor): Initialize
dimensions.
(addGraph): New method.
(on_size_request): New method to pass widget's size to parent widgets
* grapher/grapher.cxx (GrapherWindow constructor): add "add graph"
action.
(addGraph): New method.

14 years agoPR10678 module reloc refers to symbol in dwarf refer to kernel symbols.
Mark Wielaard [Wed, 30 Sep 2009 14:51:29 +0000 (16:51 +0200)]
PR10678 module reloc refers to symbol in dwarf refer to kernel symbols.

First part of a fix for PR10678. Always include the kernel in the dwfl.
This doesn't seem to impact performance noticable, so for now enable
always.

* setupdwfl.cxx (setup_dwfl_done): New variable, used to clean up logic
  in setup_dwfl_report_kernel_p().
  (setup_all_deps): New static bool to indicate we want all deps (just
  the kernel for now, other modules coming).
  (setup_dwfl_report_kernel_p): Use new variables, shortcut kernel
  inclusion.
  (setup_dwfl_kernel): Setup setup_dwfl_done (false).

14 years agobuild fix: use boost shared_ptr if libstdc++ to old to have <tr1/memory>
Frank Ch. Eigler [Tue, 29 Sep 2009 21:09:20 +0000 (17:09 -0400)]
build fix: use boost shared_ptr if libstdc++ to old to have <tr1/memory>

* configure.ac: Look for tr1/memory and boost/shared_ptr.hpp
* setupdwfl.h (shared_ptr): Define conditionally based on above.
* systemtap.spec (with_boost): New parameter, default-off.

14 years agoDelete trailing whitespace
Robb Romans [Tue, 29 Sep 2009 20:51:23 +0000 (15:51 -0500)]
Delete trailing whitespace

14 years agoAdd information about userspace probing
Robb Romans [Tue, 29 Sep 2009 20:49:51 +0000 (15:49 -0500)]
Add information about userspace probing

Add information from the manual pages and from Prerna Saxena about
userspace probing to the Language Reference Guide.

14 years agoAdd -Werror to tracequery build
Josh Stone [Tue, 29 Sep 2009 18:35:18 +0000 (11:35 -0700)]
Add -Werror to tracequery build

The final module build uses -Werror, so tracequery should as well to
catch problems as early as possible.  Some ext4 errors have crept in
again (PR10703).

* buildrun.cxx (make_tracequery): Add -Werror to EXTRA_CFLAGS.

14 years agotapset docs cleanup
Frank Ch. Eigler [Tue, 29 Sep 2009 18:09:32 +0000 (14:09 -0400)]
tapset docs cleanup

Several problems: some invalid <command> etc. directives
in the tapset embedded docs; some analysis about the
non-generation of the pdf; some cleanup of the generated
man pages.

* configure.ac (BUILD_PDFREFDOCS): Correct condition typo, but still
  leave disabled.
* doc/SystemTap_Tapset_Reference/Makefile.am (XMLTOMANPARMS): Add,
  to disable noise "AUTHORS" / "COPYRIGHT" sections.
* tapset/*.stp: Removed several docbook-y markup that is not valid
  in kerneldoc.

14 years agoAdded timeouts to test 15 & 16.
David Smith [Tue, 29 Sep 2009 16:00:26 +0000 (11:00 -0500)]
Added timeouts to test 15 & 16.

14 years agoCache Dwfl's for reuse between pass 2 and pass 3.
Mark Wielaard [Tue, 29 Sep 2009 14:45:37 +0000 (16:45 +0200)]
Cache Dwfl's for reuse between pass 2 and pass 3.

* setupdwfl.h: Introduce DwflPtr.
* setupdwfl.cxx: Cache kernel_dwfl and user_dwfl. Keep track of last used
  module strings. Return cached versions if same query used.
* dwflpp.h: Use DwflPtr instead of Dwfl*.
* dwflpp.cxx: Use DwflPtr and don't dwfl_end().
* translate.cxx: Likewise. Run through dwfl_getmodules() with returned
  ptr offset.

14 years agoHandle non-regex full path kernel module dwfl setup earlier.
Mark Wielaard [Tue, 29 Sep 2009 09:22:30 +0000 (11:22 +0200)]
Handle non-regex full path kernel module dwfl setup earlier.

* setupdwfl.cxx (setup_dwfl_kernel(unsigned*,systemtap_session&)):
  Don't switch around offline_search_modname and offline_search_names here.
  (setup_dwfl_kernel(string&,unsigned*,systemtap_session&): But here.

14 years agoMake sys32_pipe probe available only before 2.6.32
Wenji Huang [Tue, 29 Sep 2009 05:05:54 +0000 (13:05 +0800)]
Make sys32_pipe probe available only before 2.6.32

* tapset/x86_64/nd_syscalls.stp: Switch by kernel version.
* tapset/x86_64/syscalls.stp: Ditto.

14 years ago* tapsets.cxx (sdt_query::record_semaphore): Adjust addr relative to
Stan Cox [Tue, 29 Sep 2009 02:40:33 +0000 (22:40 -0400)]
* tapsets.cxx (sdt_query::record_semaphore): Adjust addr relative to
relocation base.

14 years agoRemove cached signature files along with modules
Josh Stone [Tue, 29 Sep 2009 02:04:00 +0000 (19:04 -0700)]
Remove cached signature files along with modules

* cache.cxx (cache_ent_info::cache_ent_info): Count the sgn in the size
  (cache_ent_info::unlink): Remove the sgn too.

14 years agoSimplify copy_file calls
Josh Stone [Tue, 29 Sep 2009 01:49:51 +0000 (18:49 -0700)]
Simplify copy_file calls

Every single copy_file call we had was converting strings to char*,
printing the same error message, and optionally printing the same
verbose string.  Let's canonicalize that.

* util.cxx (copy_file): Take string filenames, add a verbose flag, and
  consolidate the message printing.
* cache.cxx (add_to_cache): Pass strings and remove message printing.
  (get_from_cache): Ditto.
* main.cxx (main): Ditto.
* tapsets.cxx (tracepoint_builder::get_tracequery_module): Ditto.
  (dwarf_cast_expanding_visitor::filter_special_modules): Ditto.

14 years agoTry to build tracequery for all headers at once
Josh Stone [Tue, 29 Sep 2009 00:36:04 +0000 (17:36 -0700)]
Try to build tracequery for all headers at once

To mitigate PR10424, we switched to building a separate tracequery
module for each tracepoint header, so a bad header wouldn't break all of
the others.  However, with recent kernels that leads to ~18 make
commands, which adds up quickly in time.  It's cached, so that's not too
bad, but as a developer who rebuilds stap frequently, it gets annoying.

If we're going to call 18 makes, it's worth it to start with one bigger
make that covers all the headers at once (like we used to).  If that one
fails, we can still fall back to compiling individually.

FWIW, the failing ext4.h header was only created in 2.6.31, and was
fixed before 2.6.32, so the specific failure in PR10424 has a fairly
small window.

* buildrun.cxx (make_tracequery): Just take a single vector of headers.
* hash.cxx (find_tracequery_hash): Deal with multiple headers.
* tapsets.cxx (tracepoint_builder::get_tracequery_module): Ditto.
  (tracepoint_builder::init_dw): Attempt all system headers together,
  and if that fails, try again individually.

14 years agoFactor out duplicated code to setup user/module Dwfl from dwflpp/translate.
Mark Wielaard [Mon, 28 Sep 2009 22:12:26 +0000 (00:12 +0200)]
Factor out duplicated code to setup user/module Dwfl from dwflpp/translate.

* setupdwfl.h: Add setup_dwfl_user() and is_user_module().
* setupdwfl.cxx: Likewise.
* dwflpp.cxx (setup_user): Use setup_dwfl_user().
* translate.cxx (emit_symbol_data): Likewise and is_user_module().
* tapsets.cxx (dwarf_cast_expanding_visitor::visit_cast_op):
  Use is_user_module().

14 years agoHandle full path .ko modules in setup_dwfl_kernel.
Mark Wielaard [Mon, 28 Sep 2009 21:30:49 +0000 (23:30 +0200)]
Handle full path .ko modules in setup_dwfl_kernel.

* setupdwfl.cxx (setup_dwfl_kernel): First report all full path modules.

14 years agoBetter cleanup.
David Smith [Mon, 28 Sep 2009 20:18:58 +0000 (15:18 -0500)]
Better cleanup.
* testsuite/systemtap.base/cmd_parse.exp: Remove temporary module.

14 years agocleanup: tweak "read-only <variable>" message
Frank Ch. Eigler [Mon, 28 Sep 2009 20:01:29 +0000 (16:01 -0400)]
cleanup: tweak "read-only <variable>" message

* elaborate.cxx (semantic_pass_opt2): Use "never-assigned" instead
  of "read-only".
  (dead_stmtexpr_remover::visit_expr_statement): Ditto.

14 years agoUse dwlpp::setup_kernel for tracepoint modules.
Mark Wielaard [Mon, 28 Sep 2009 15:12:04 +0000 (17:12 +0200)]
Use dwlpp::setup_kernel for tracepoint modules.

Tracepoint modules ended up going through dwflpp::setup_user() because
there was no setup_kernel that takes a list of module names.

* dwflpp.h: Add kernel_p bool to constructor that takes a module list.
  Add setup_kernel() variant that takes a module list.
* dwflpp.cxx: Likewise.
* tapsets.cxx (tracepoint_builder::init_dw): Call dwflpp constructor
  indicating we expect kernel modules.

14 years agoFactor out duplicated code to setup kernel/module Dwfl from dwflpp/translate.
Mark Wielaard [Mon, 28 Sep 2009 13:36:33 +0000 (15:36 +0200)]
Factor out duplicated code to setup kernel/module Dwfl from dwflpp/translate.

* setupdwfl.h: New header file.
* setupdwfl.cxx: New source file containing shared setup_dwfl_kernel() code.
* dwflpp.cxx (dwfl_report_offline_predicate): Removed.
  (setup_kernel): Call setup_dwfl_kernel().
* translate.cxx (dwfl_report_offline_predicate2): Remove.
  (emit_symbol_data): Call setup_dwfl_kernel().
* Makefile.am (stap_SOURCES): Add setupdwfl.cxx.
* Makefile.in: Regenerated.

14 years agoPR10700 Add newline after log() message.
Mark Wielaard [Mon, 28 Sep 2009 13:34:56 +0000 (15:34 +0200)]
PR10700 Add newline after log() message.

* tapset/logging.stp (log): Use _stp_printf "%s\n".

14 years agoRemoving support for InMcastPkts, OutMcastPkts, InBcastPkts and
David J. Wilder [Fri, 25 Sep 2009 22:24:58 +0000 (15:24 -0700)]
Removing support for InMcastPkts, OutMcastPkts, InBcastPkts and
OutBcastPkts.  As they are not needed for tcpipstat and tend to break
easily with kernel changes.

14 years agoNo longer need buffer iterators.
David Smith [Fri, 25 Sep 2009 20:12:10 +0000 (15:12 -0500)]
No longer need buffer iterators.
* runtime/tranport/ring_buffer.c: Removed 'USE_ITERS' definition.

14 years agoPurge warnings from buildok testsuite.
Mark Wielaard [Fri, 25 Sep 2009 13:38:41 +0000 (15:38 +0200)]
Purge warnings from buildok testsuite.

* testsuite/buildok/fortysix.stp: Add -w.
* testsuite/buildok/fortytwo.stp: Likewise.
* testsuite/buildok/four.stp: Avoid empty begin.
* testsuite/buildok/memory-all-probes.stp: Add -w.
* testsuite/buildok/nfsd-all-probes.stp: Likewise.
* testsuite/buildok/nine.stp: Likewise.
* testsuite/buildok/one.stp: Use q.
* testsuite/buildok/printf.stp: Remove unused foo(), printf x.
* testsuite/buildok/process-all-probes.stp: Add -w.
* testsuite/buildok/scheduler-all-probes.stp: Likewise.
* testsuite/buildok/scsi-all-probes.stp: Likewise.
* testsuite/buildok/signal-all-probes.stp: Likewise.
* testsuite/buildok/sixteen.stp: log in foo().
* testsuite/buildok/socket-all-probes.stp: Add -w.
* testsuite/buildok/stat_insert.stp: Declare x, y global.
* testsuite/buildok/syscall.stp: Add -w.
* testsuite/buildok/tcp-all-probes.stp: Likewise.
* testsuite/buildok/thirtyone.stp: Likewise.
* testsuite/buildok/twentyeight.stp: log absolute.
* testsuite/buildok/twentyfour.stp: Add -w.
* testsuite/buildok/udp-all-probes.stp: Likewise.
* testsuite/buildok/vfs-all-probes.stp: Likewise.

14 years agoAUTHORS update
Josh Stone [Thu, 24 Sep 2009 23:29:39 +0000 (16:29 -0700)]
AUTHORS update

* .mailmap: Normalize David (J.) Wilder.
* AUTHORS: Rebuild, also adding Charley Wang & Roland Grunberg.

14 years agoSupport DW_AT_const_value cases in loc2c and loc2c-test.
Roland McGrath [Thu, 24 Sep 2009 20:05:41 +0000 (13:05 -0700)]
Support DW_AT_const_value cases in loc2c and loc2c-test.

* loc2c.c (c_translate_constant): New function.
* loc2c.h: Declare it.
* loc2c-test.c (main): Use it for DW_AT_const_value cases.

14 years agoAdded a basic ring_buffer transport test.
David Smith [Thu, 24 Sep 2009 18:32:22 +0000 (13:32 -0500)]
Added a basic ring_buffer transport test.
* testsuite/systemtap.printf/ring_buffer.exp: New test.

14 years agoMerge branch 'master' of ssh://sources.redhat.com/git/systemtap
David Smith [Thu, 24 Sep 2009 13:11:09 +0000 (08:11 -0500)]
Merge branch 'master' of ssh://sources.redhat.com/git/systemtap

14 years agoFixed grapher build problem caused by configure update.
David Smith [Thu, 24 Sep 2009 13:10:16 +0000 (08:10 -0500)]
Fixed grapher build problem caused by configure update.
* grapher/Makefile.am: Updated gtkmm CFLAGS/LIBS variable name.
* grapher/Makefile.in: Regenerated.
* Makefile.in: Ditto.
* doc/Makefile.in
* doc/SystemTap_Tapset_Reference/Makefile.in

14 years agoMerge branch 'master' of ssh://sources.redhat.com/git/systemtap
Frank Ch. Eigler [Thu, 24 Sep 2009 02:37:19 +0000 (22:37 -0400)]
Merge branch 'master' of ssh://sources.redhat.com/git/systemtap

* 'master' of ssh://sources.redhat.com/git/systemtap:
  Better grapher option handling.
  Fix configure on systems without 'gcc -fgnu89-inline' support (rhel4).

14 years agoPR10632: make randint() unprivileged
Frank Ch. Eigler [Thu, 24 Sep 2009 02:36:48 +0000 (22:36 -0400)]
PR10632: make randint() unprivileged

14 years agoBetter grapher option handling.
David Smith [Wed, 23 Sep 2009 21:14:46 +0000 (16:14 -0500)]
Better grapher option handling.
* configure.ac: Don't check for gtkmm if '--disable-grapher' was used.
  Also, error if '--enable-grapher' was used but gtkmm isn't installed.
* configure: Regenerated.

14 years agoPR10632: simplify randint() implementation
Frank Ch. Eigler [Wed, 23 Sep 2009 20:41:40 +0000 (16:41 -0400)]
PR10632: simplify randint() implementation

* tapset/random.stp (randint): Make it 1-arity (imply min=0).
  Document with kerneldoc.
* doc/Systemtap_Tapset_Reference/tapsets.tmpl: Extract the docs.
* runtime/arith.c (_stp_random_pm_u): Rename without _pm.
  (_stp_random_pm): Rewrite in terms of ..._u.
* testsuite/random.stp: Adapt & simplify.

14 years agoFix configure on systems without 'gcc -fgnu89-inline' support (rhel4).
David Smith [Wed, 23 Sep 2009 20:37:37 +0000 (15:37 -0500)]
Fix configure on systems without 'gcc -fgnu89-inline' support (rhel4).
* configure.ac: Only compile elfutils with '-fgnu89-inline' if the
  compiler actually supports it.
* configure: Regenerated.

This page took 0.068998 seconds and 5 git commands to generate.