]> sourceware.org Git - systemtap.git/log
systemtap.git
13 years agoPR12773: Fixed Test Suite Regressions
Chris Meek [Mon, 8 Aug 2011 20:49:17 +0000 (16:49 -0400)]
PR12773: Fixed Test Suite Regressions

13 years agoPR12773: Fixed NULL check - no longer aborts
Chris Meek [Mon, 8 Aug 2011 15:36:40 +0000 (11:36 -0400)]
PR12773: Fixed NULL check - no longer aborts

13 years agoPR12773: Use abrt to download and install debuginfo
Chris Meek [Thu, 4 Aug 2011 14:11:38 +0000 (10:11 -0400)]
PR12773: Use abrt to download and install debuginfo

dwflpp.cxx
  In setup_user(), pass the session to setup_dwfl_user().

setupdwfl.cxx
  Added internal_find_debuginfo() and
  execute_abrt_action_install_debuginfo_to_abrt_cache() to call
  abrt to automatically download and install the needed debuginfo.

setupdwfl.h
  Added function declarations.

util.h
  Added hex_dump() to convert a binary string to a hex string.

13 years agoRelax -G regexp slightly to allow 1-char variable names
Josh Stone [Mon, 8 Aug 2011 19:56:24 +0000 (12:56 -0700)]
Relax -G regexp slightly to allow 1-char variable names

13 years agosdt*exp: When the compiler doesn't recognize flag, mark test as UNTESTED.
Mark Wielaard [Mon, 8 Aug 2011 09:08:42 +0000 (11:08 +0200)]
sdt*exp: When the compiler doesn't recognize flag, mark test as UNTESTED.

Older gcc compilers don't recognize all the -std=[c|gnu]++0x flags we
throw at them. Instead of marking these compilations as FAIL, mark them
as UNTESTED now, so we only see real FAILures in the result (there are
still a couple left against -pedantic).

13 years agoAdd NULL context when creating perf event counter, remove nmi from handler.
Mark Wielaard [Sun, 7 Aug 2011 13:44:58 +0000 (15:44 +0200)]
Add NULL context when creating perf event counter, remove nmi from handler.

More fallout of kernel commit 4dc0da "perf: Add context field to perf_event"
and commit a8b0ca "perf: Remove the nmi parameter from the swevent and
verflow interface". And new autoconf checks for both.

13 years agoproc_mem.stp: Always use atomic counters with kernel 3.1 or higher.
Mark Wielaard [Sun, 7 Aug 2011 12:38:28 +0000 (14:38 +0200)]
proc_mem.stp: Always use atomic counters with kernel 3.1 or higher.

Kernel commit 172703 "mm: delete non-atomic mm counter implementation"
did away with the non-atomic variant of mm_struct rss_stat->count[member].

13 years agoAdd destructor to struct block and delete statements to avoid scope leaks
Lukas Berk [Fri, 5 Aug 2011 18:05:53 +0000 (14:05 -0400)]
Add destructor to struct block and delete statements to avoid scope leaks

* staptree.h: Add destructor to struct block
* elaborate.cxx: Add delete statements to add_global_var_display

13 years agoCheck for hw_breakpoint context argument.
Mark Wielaard [Fri, 5 Aug 2011 12:13:21 +0000 (14:13 +0200)]
Check for hw_breakpoint context argument.

Kernel commit 4dc0da8 "perf: Add context field to perf_event" added
a new void *context field to the register_*_hw_breakpoint() functions.
Detect with a new runtime/autoconf-hw_breakpoint_context.c plus
STAPCONF_HW_BREAKPOINT_CONTEXT conditional.

13 years agocontext-unwind.stp: More STAPCONF_UPROBE_GET_PC wrapping.
Mark Wielaard [Fri, 5 Aug 2011 10:42:04 +0000 (12:42 +0200)]
context-unwind.stp: More STAPCONF_UPROBE_GET_PC wrapping.

13 years agoruntime/stack.c: Wrap GET_PC_URETPROBE_NONE in #ifdef STAPCONF_UPROBE_GET_PC
Mark Wielaard [Thu, 4 Aug 2011 20:27:33 +0000 (22:27 +0200)]
runtime/stack.c: Wrap GET_PC_URETPROBE_NONE in #ifdef STAPCONF_UPROBE_GET_PC

13 years agoMove the comment for STP_MAX_PROCFS_FILES closer
Josh Stone [Thu, 4 Aug 2011 19:44:14 +0000 (12:44 -0700)]
Move the comment for STP_MAX_PROCFS_FILES closer

13 years agovim: bump the date and use a generic email contact
Josh Stone [Thu, 4 Aug 2011 16:11:20 +0000 (09:11 -0700)]
vim: bump the date and use a generic email contact

13 years agoUse $dfd not $mode in testsuite/transok/tval-opt.stp.
Mark Wielaard [Thu, 4 Aug 2011 10:24:35 +0000 (12:24 +0200)]
Use $dfd not $mode in testsuite/transok/tval-opt.stp.

Kernel commit 47c805 "switch do_filp_open() to struct open_flags"
changed the arguments of do_filp_open. Use another int argument
that hasn't changed in testcase.

13 years agoCheck whether syscalls2.stp sigprocmask argument is set or nset.
Mark Wielaard [Wed, 3 Aug 2011 22:26:49 +0000 (00:26 +0200)]
Check whether syscalls2.stp sigprocmask argument is set or nset.

kernel commit b013c3 "signal: cleanup sys_sigprocmask()" renamed the set
parameter to nset. commit bb7efe "signal: cleanup sys_rt_sigprocmask()"
did the same. Check with @defined($set) to see if we want the old or
new definition.

13 years agoFix autoconf-ring_buffer_lost_events.c compile warning.
Mark Wielaard [Wed, 3 Aug 2011 20:45:11 +0000 (22:45 +0200)]
Fix autoconf-ring_buffer_lost_events.c compile warning.

Newer GCC will warn about the event variable not being used,
making this test fail. Just remove the 'event' variable.

13 years agotestsuite warn_overflow be more precise and a bit more lenient.
Mark Wielaard [Wed, 3 Aug 2011 17:30:37 +0000 (19:30 +0200)]
testsuite warn_overflow be more precise and a bit more lenient.

log exactly once for syscall probe hit and counter i == 256.
But do allow more than 3 overflow warning messages to occur
in case stap miraculously recovers and overflows immediately
afterwards.

13 years agotestsuite warnings.stp: match all lines in bio_init@fs/bio.c:*.
Mark Wielaard [Wed, 3 Aug 2011 17:29:24 +0000 (19:29 +0200)]
testsuite warnings.stp: match all lines in bio_init@fs/bio.c:*.

Since we aren't actually interested in the probe itself, and
different kernels have different lines that can be probed, just
match them all.

13 years agoMerge branch 'master' of git://sourceware.org/git/systemtap
Lukas Berk [Wed, 3 Aug 2011 16:17:40 +0000 (12:17 -0400)]
Merge branch 'master' of git://sourceware.org/git/systemtap

13 years agoAdd pattern_root to destructor
Lukas Berk [Wed, 3 Aug 2011 16:14:32 +0000 (12:14 -0400)]
Add pattern_root to destructor

* session.cxx: add delete pattern_root to ~systemtap_session()

13 years agoprobe_type: make unexpected types an error for probe_type()
Frank Ch. Eigler [Wed, 3 Aug 2011 15:48:23 +0000 (11:48 -0400)]
probe_type: make unexpected types an error for probe_type()

13 years agoimplicitptr.exp: Add implicitptr.exp to test_flags.
Mark Wielaard [Wed, 3 Aug 2011 14:24:00 +0000 (16:24 +0200)]
implicitptr.exp: Add implicitptr.exp to test_flags.

Previously the testcase wouldn't compile unless the system had sys/sdt.h.

13 years agocommon_probe_context.h: Put Individual Probe State (ips) into a union.
Mark Wielaard [Wed, 3 Aug 2011 09:17:00 +0000 (11:17 +0200)]
common_probe_context.h: Put Individual Probe State (ips) into a union.

Various probe handlers have dedicated fields in the common probe context
struct. Since the handlers cannot be active at the same time (on the same
cpu) these can just be put into a union to save space. In runtime code
when there might be ambiguity about which probe handler is running, the
CONTEXT->probe_type field can be used to check which field has actual
life data.

13 years agoAdd probe_type to common probe context.
Mark Wielaard [Tue, 2 Aug 2011 14:42:38 +0000 (16:42 +0200)]
Add probe_type to common probe context.

This exposes the type of probe handler for use in runtime functions,
so they can better anticipate which common probe context is valid at
runtime. Also introduces a new context tapset function probe_type()
that exposes a (informational) probe handler string to scripts. Mainly
useful for debugging, when the user wants to find out which kind of
low level probe handler a high-level probe translates to for a particular
kernel/systemtap version.

13 years agoAdd destructor to struct dwarf_pretty_print
Lukas Berk [Tue, 2 Aug 2011 17:55:51 +0000 (13:55 -0400)]
Add destructor to struct dwarf_pretty_print

*tapsets.cxx: add destructor to deallocate ts

13 years agoRemove old context.stp uaddr() comment.
Mark Wielaard [Tue, 2 Aug 2011 08:58:45 +0000 (10:58 +0200)]
Remove old context.stp uaddr() comment.

PR10080 was resolved and we no have  VDSO tracking support.

13 years agoRemove old comment in kretprobe handler.
Mark Wielaard [Tue, 2 Aug 2011 08:56:59 +0000 (10:56 +0200)]
Remove old comment in kretprobe handler.

c->ri -inst is saved just above the old comment.

13 years agoPR12135: Pretty-print should skip masked inherited members
Josh Stone [Mon, 1 Aug 2011 19:41:32 +0000 (12:41 -0700)]
PR12135: Pretty-print should skip masked inherited members

* tapsets.cxx (dwarf_pretty_print::recurse_struct_members): Traverse
  inheritance breadth-first, and remember shallower names printed.
* testsuite/systemtap.base/inherit.*: Add pretty-printing to the test.

13 years agoPR12135: Discard inheritance "dupes" in suggested alternatives
Josh Stone [Mon, 1 Aug 2011 19:24:20 +0000 (12:24 -0700)]
PR12135: Discard inheritance "dupes" in suggested alternatives

* dwflpp.cxx (dwflpp::print_members): Track already seen members in a
  set, so we don't print names twice (as with masked inherited members).

13 years agoPR12135: Prefer subclass members if they mask the superclass
Josh Stone [Mon, 1 Aug 2011 18:58:36 +0000 (11:58 -0700)]
PR12135: Prefer subclass members if they mask the superclass

* dwflpp.cxx (dwflpp::find_struct_member): Use a breadth-first search
  through inheritance trees, so masked members will be pulled from the
  subclass rather than the superclass.
* testsuite/systemtap.base/inherit.*: New test for inheritance games.

13 years agoProbe context data field is only used for procfs. Rename to procfs_data.
Mark Wielaard [Mon, 1 Aug 2011 14:00:05 +0000 (16:00 +0200)]
Probe context data field is only used for procfs. Rename to procfs_data.

itrace and mark probes would also scribble (useless) data into this
context field, without ever using it, for no apparent reason, except
that they had "data" around. Renamed the field to procfs_data to make
clear it has a specific purpose.

Also add documentation for remaining undocumented common_probe_context fields.

13 years agoRestore stream state
Lukas Berk [Mon, 1 Aug 2011 13:50:01 +0000 (09:50 -0400)]
Restore stream state

* util.h: retore stream state back to std::dec

13 years agoOnly add probe_name to the common probe context when really needed.
Mark Wielaard [Mon, 1 Aug 2011 10:39:36 +0000 (12:39 +0200)]
Only add probe_name to the common probe context when really needed.

Guard probe_name with STP_NEED_PROBE_NAME. It is only needed when we include
the pn() tapset function. All this needed was moving the STP_NEED_PROBE_NAME
define from the tapset function to a top-level embedded C block (which are
included early, unlike the tapset functions themselves).

Also document common_probe_context.h busy, probe_point and probe_name fields.

13 years agoCorrect year for systemtap beginners guide.
William Cohen [Fri, 29 Jul 2011 19:23:25 +0000 (15:23 -0400)]
Correct year for systemtap beginners guide.

13 years agoBump beginners guide to 1.6.
William Cohen [Fri, 29 Jul 2011 19:19:36 +0000 (15:19 -0400)]
Bump beginners guide to 1.6.

13 years agosecurity: name fixed CVE's in release sections
Frank Ch. Eigler [Fri, 29 Jul 2011 18:00:32 +0000 (14:00 -0400)]
security: name fixed CVE's in release sections

Suggested-By: Vincent Danen <vdanen@redhat.com>
13 years agoAdd the watchdog.stp to the index.
William Cohen [Fri, 29 Jul 2011 17:12:18 +0000 (13:12 -0400)]
Add the watchdog.stp to the index.

13 years agoAdd the watchdog.stp example
William Cohen [Fri, 29 Jul 2011 17:10:34 +0000 (13:10 -0400)]
Add the watchdog.stp example

13 years agopull in some debian patches
Frank Ch. Eigler [Fri, 29 Jul 2011 12:23:39 +0000 (08:23 -0400)]
pull in some debian patches

Appling a couple of no-brainer patches from
http://anonscm.debian.org/gitweb/?p=collab-maint/systemtap.git;a=tree;f=debian/patches

13 years agoPut common probe and session context state definitions in their own files.
Mark Wielaard [Fri, 29 Jul 2011 11:35:06 +0000 (13:35 +0200)]
Put common probe and session context state definitions in their own files.

translate.cxx contained code to produce the common probe and session
context state as C code snippets. Large parts were not dependent on the
session state at all, so they really were just static blobs of C code
wrapped in c++ io stream operators. These have been put in their own
C runtime header files (common_session_state.h, common_probe_context.h
and runtime_defines.h) to make it easier to edit and document.

13 years agotapset-utrace.cxx: Use 'utrace_engine' instead of 'utrace_attached_engine'
Mark Wielaard [Fri, 29 Jul 2011 09:18:20 +0000 (11:18 +0200)]
tapset-utrace.cxx: Use 'utrace_engine' instead of 'utrace_attached_engine'

Commit 6890af reversed the utrace compatibility fix in utrace_compatibility.h.

13 years agoGuard regparm in probe context with STAP_NEED_REGPARM.
Mark Wielaard [Thu, 28 Jul 2011 16:10:20 +0000 (18:10 +0200)]
Guard regparm in probe context with STAP_NEED_REGPARM.

regparm is only used on i386 (and x86_64 when probing 32bit) for
signaling what the parameter packing is for the probed function
as set in register.stp. So only include it in the probe context
struct when actually used in a stap script.

Also updated docs and fixed signature on other arches.

13 years agoProperly initialize variables and consistently check getenv
Lukas Berk [Thu, 28 Jul 2011 19:52:35 +0000 (15:52 -0400)]
Properly initialize variables and consistently check getenv

* session.cxx: initialize long_opt, change conditional to match other
getenv checks against null
* stap-serverd.cxx: initialize long_opt

13 years agoPR 12916 - Aliased process probes aren't allowed for unprivileged
Dave Brolley [Thu, 28 Jul 2011 18:18:49 +0000 (14:18 -0400)]
PR 12916 - Aliased process probes aren't allowed for unprivileged

Make all probe aliases OK for unprivileged users. The actual referenced
probe points will be checked once the aliases are resolved.
Update test suite.

13 years agoRearrange conditional to include return value check
Lukas Berk [Thu, 28 Jul 2011 14:49:11 +0000 (10:49 -0400)]
Rearrange conditional to include return value check

* tapsets.cxx: add a conditional to check get_param's return value,
this also keeps a consistent check of get_param throughout the function

13 years agoPR13037 Make lock blacklist more specific.
Mark Wielaard [Thu, 28 Jul 2011 12:02:09 +0000 (14:02 +0200)]
PR13037 Make lock blacklist more specific.

The dwflpp::build_blacklist() would also match things like _nolock,
block or clock. Be more specific that we want to only match things
like _lock, _unlock, _trylock or seq[un]lock.

13 years agoTwo task_finder cleanups.
David Smith [Wed, 27 Jul 2011 17:32:50 +0000 (12:32 -0500)]
Two task_finder cleanups.

* runtime/task_finder.c: Two cleanup fixes. Merged 2 different state
  variables into 1. Reversed utrace compatibility fix.  Instead of
  making new utrace look like old utrace, made old utrace look like new
  utrace (i.e. use 'utrace_engine' instead of 'utrace_attached_engine').
* runtime/utrace_compatibility.h: Reversed utrace compatibility fix (use
  'utrace_engine' instead of 'utrace_attached_engine').

13 years agoAdd autoconf-ring_buffer_read_prepare.
Mark Wielaard [Wed, 27 Jul 2011 15:21:31 +0000 (17:21 +0200)]
Add autoconf-ring_buffer_read_prepare.

Kernel commit 72c9dd split ring_buffer starting in a prepare and start phase.

13 years agoAdd autoconf-ring_buffer_lost_events.
Mark Wielaard [Wed, 27 Jul 2011 15:08:58 +0000 (17:08 +0200)]
Add autoconf-ring_buffer_lost_events.

Kernel commit 66a8cb added place holder recording of dropped events.

13 years agoMerge branch 'mjw/backtrace'
Mark Wielaard [Wed, 27 Jul 2011 07:38:57 +0000 (09:38 +0200)]
Merge branch 'mjw/backtrace'

13 years agoFix typo in 1.6 release date.
Stan Cox [Tue, 26 Jul 2011 21:43:32 +0000 (17:43 -0400)]
Fix typo in 1.6 release date.

13 years agoAllow gcc to optimize away uprobe_get_pc() calls in some situations.
Mark Wielaard [Tue, 26 Jul 2011 21:31:01 +0000 (23:31 +0200)]
Allow gcc to optimize away uprobe_get_pc() calls in some situations.

If a call is made to the stack-x86.c __stp_stack_print() it might
try to call uprobe_get_pc(). If this is just a kernel backtrace
then uprobes might not be loaded. Add a hint by explicitly clearing
the struct uretprobe_instance *ri variable in that cass in the
calling function _stp_stack_print() in stack.c, so that gcc
optimizes away the uprobe_get_pc() call, so that the symbol isn't
in the module anymore.

Would cause issues like:
WARNING: "uprobe_get_pc" [stap_d46895_3786.ko] undefined!
Error inserting module 'stap_d46895_3786.ko': Unknown symbol in module

13 years agoAdjust expected "no backtrace" string in context/backtrace.tcl test.
Mark Wielaard [Tue, 26 Jul 2011 21:29:48 +0000 (23:29 +0200)]
Adjust expected "no backtrace" string in context/backtrace.tcl test.

The new generic form is now "<no kernel backtrace at PROBEPOINT>".

13 years agoBump the runtime version to 1.7 too
Josh Stone [Tue, 26 Jul 2011 21:17:32 +0000 (14:17 -0700)]
Bump the runtime version to 1.7 too

13 years agoBreak user_int64 64-bit operation into two for arm
William Cohen [Tue, 26 Jul 2011 21:06:08 +0000 (17:06 -0400)]
Break user_int64 64-bit operation into two for arm

Like the i386, the arm processor is also limited to 32-bit oprations.
The user_int64() needs to break the 64-bit access into 32-bit operations.

13 years agoRevert "Break user_int64 64-bit operation into two for arm"
William Cohen [Tue, 26 Jul 2011 21:01:32 +0000 (17:01 -0400)]
Revert "Break user_int64 64-bit operation into two for arm"

This reverts commit 77bfa15c05ae30b5aed520f5587b8ee6b2b1c446.

13 years agoAdd \n at end of debug message in staprun/mainloop.c.
Mark Wielaard [Tue, 26 Jul 2011 20:37:52 +0000 (22:37 +0200)]
Add \n at end of debug message in staprun/mainloop.c.

13 years ago bump version numbers to 1.7, for future release cycle
Stan Cox [Tue, 26 Jul 2011 20:39:33 +0000 (16:39 -0400)]
 bump version numbers to 1.7, for future release cycle

13 years agoBreak user_int64 64-bit operation into two for arm
William Cohen [Tue, 26 Jul 2011 20:15:41 +0000 (16:15 -0400)]
Break user_int64 64-bit operation into two for arm

Like the i386, the arm processor is also limited to 32-bit oprations.
The user_int64() needs to break the 64-bit access into 32-bit operations.

13 years agoPR12895: Use NOSTDINC_FLAGS in kernel stapconf checks
Josh Stone [Tue, 26 Jul 2011 19:25:34 +0000 (12:25 -0700)]
PR12895: Use NOSTDINC_FLAGS in kernel stapconf checks

We should never be looking in /usr/include/ for headers when building
for the kernel.  This particularly bit us in a case where RHEL6 gained
blk_types.h in newer kernels.  So if the system had kernel-headers.rpm
with this new header in /usr/include/, but was still running an older
kernel that lacked it in /lib/modules/`uname -r`/build/, then we'd
misidentify that header's availability in stapconf.

* buildrun.cxx (compile_pass): Add NOSTDINC_FLAGS to CHECK_BUILD.

13 years agostap-server security: use @PIELDFLAGS@ for all binaries
Frank Ch. Eigler [Tue, 26 Jul 2011 17:26:37 +0000 (13:26 -0400)]
stap-server security: use @PIELDFLAGS@ for all binaries

* Makefile.am (stap-authorize-cert, stap-gen-cert, stap-serverd,
  stap-sign-module): Add @PIELDFLAGS@ to foo_LDFLAGS.

13 years agoFix stack-ppc.c typo level -> levels.
Mark Wielaard [Tue, 26 Jul 2011 15:14:04 +0000 (17:14 +0200)]
Fix stack-ppc.c typo level -> levels.

13 years agoPush all stack logic into stack.c. tapset functions just pass flags.
Mark Wielaard [Tue, 26 Jul 2011 13:10:30 +0000 (15:10 +0200)]
Push all stack logic into stack.c. tapset functions just pass flags.

Some of the logic determining what to print, which register sets to use
and whether the context was valid was repeated multiple times in the
[u]context-unwind.stp functions. Just do all the logic in one place
(_stp_print_stack) and make the tapset functions just push the context
and symbols/stack flags.

13 years agoDon't pass kregprobe, uretprobe and unwind_context around separately.
Mark Wielaard [Tue, 26 Jul 2011 11:27:04 +0000 (13:27 +0200)]
Don't pass kregprobe, uretprobe and unwind_context around separately.

Just pass whole struct context to stack.c _stp_stack functions.

13 years agospec: retroactively add %changelog entries for 1.6 / 1.5
Frank Ch. Eigler [Mon, 25 Jul 2011 21:53:02 +0000 (17:53 -0400)]
spec: retroactively add %changelog entries for 1.6 / 1.5

13 years agoPR 12888 - Filter server-side file paths in the server's response. release-1.6
Dave Brolley [Mon, 25 Jul 2011 18:12:01 +0000 (14:12 -0400)]
PR 12888 - Filter server-side file paths in the server's response.

13 years agocopyright year bump for translator
Frank Ch. Eigler [Mon, 25 Jul 2011 16:53:30 +0000 (12:53 -0400)]
copyright year bump for translator

13 years agoFix sdt v1/v2 shared object probes.
Stan Cox [Mon, 25 Jul 2011 16:01:35 +0000 (12:01 -0400)]
Fix sdt v1/v2 shared object probes.

* dtrace (_provider):  Don't use hidden visibility attribute for sdt v1/v2

13 years agoCVE-2011-2503: read instead of mmap to load modules
Josh Stone [Mon, 25 Jul 2011 15:48:31 +0000 (11:48 -0400)]
CVE-2011-2503: read instead of mmap to load modules

As staprun is preparing to load a kernel module, we first mmap the whole
module as MAP_PRIVATE. Then we proceed with our security checks,
including a trusted-signature validation on the mapped region, and if
all checks out, we'll call init_module() with that same mapped region.

However, MMAP(2) says of MAP_PRIVATE, "It is unspecified whether changes
made to the file after the mmap() call are visible in the mapped
region."  From my testing, it appears that file changes do indeed show
up in our mapped memory.  This means we have a TOCTOU race between
verifying the signature of that memory and then calling init_module().

By using read() instead of mmap(), we ensure that we have a fully
private copy of the module to verify and load, without fear of change.

13 years agoCVE-2011-2502: Don't allow path-based auth for uprobes
Josh Stone [Mon, 25 Jul 2011 13:54:28 +0000 (09:54 -0400)]
CVE-2011-2502: Don't allow path-based auth for uprobes

For users that are only members of stapusr, and not stapdev, we only
allow loading modules that are either signed with a trusted certificate
or located in controlled paths.  For the script itself, that path is
/lib/modules/.../systemtap/, and for uprobes it is the runtime.  When
this policy was first written, uprobes only ever came from the runtime
path, so the path check just returned 1 always.

Later, commit 474d17ad added an optional argument to staprun -u, to
allow the user to specify their own signed copy of uprobes to load.
Unfortunately, if presented with an unsigned module, that would still
fall back to the path check, which blissfully approved it anyway.

Our policy is now that stapusr can only load a signed uprobes.ko, so the
path check for uprobes now unconditionally returns 0.

13 years agoFixed tracescripts.exp when 'stap' is stripped.
David Smith [Mon, 25 Jul 2011 15:40:30 +0000 (10:40 -0500)]
Fixed tracescripts.exp when 'stap' is stripped.

* testsuite/systemtap.base/tracescripts.exp: Look for markers in 'stap'
  executable instead of a function.

13 years agoRemove superfluous definition of MAXSTRINGLEN from runtime.h.
Mark Wielaard [Mon, 25 Jul 2011 13:57:03 +0000 (15:57 +0200)]
Remove superfluous definition of MAXSTRINGLEN from runtime.h.

Already always defined by translator.

13 years agoClean up maximum backtrace level code. And document MAXBACKTRACE.
Mark Wielaard [Mon, 25 Jul 2011 13:52:30 +0000 (15:52 +0200)]
Clean up maximum backtrace level code. And document MAXBACKTRACE.

Lots of functions passed around the maximum level of backtraces allowed.
Now all consolidated inside stack.s. And documented in stap.1.

13 years agoRemove unused arch_unw_init_blocked arch specific unwind functions.
Mark Wielaard [Mon, 25 Jul 2011 13:09:25 +0000 (15:09 +0200)]
Remove unused arch_unw_init_blocked arch specific unwind functions.

13 years agoOnly include runtime/stack.c functions when needed.
Mark Wielaard [Mon, 25 Jul 2011 12:56:04 +0000 (14:56 +0200)]
Only include runtime/stack.c functions when needed.

13 years agoRemove task_backtrace tapset function support.
Mark Wielaard [Mon, 25 Jul 2011 12:38:11 +0000 (14:38 +0200)]
Remove task_backtrace tapset function support.

Deprecated with 1.6. Now removed.
Although useful in some circumstance the current support for it was really
ugly (you had to provide a pointer to a task struct, which couldn't be
sanity checked at all) and it made the current unwind code really ugly
since this task struct had to be carried around. It made creating more
accurate backtraces harder because we would have had to make a distinction
between "reliable" and "unreliable" unwind info.

13 years agoMerge branch 'master' into mjw/backtrace
Mark Wielaard [Mon, 25 Jul 2011 11:19:21 +0000 (13:19 +0200)]
Merge branch 'master' into mjw/backtrace

13 years agoTweak context-unwind.stp and context.stp to allow documentation to build.
William Cohen [Sat, 23 Jul 2011 14:32:52 +0000 (10:32 -0400)]
Tweak context-unwind.stp and context.stp to allow documentation to build.

13 years agoAUTHORS bump
Frank Ch. Eigler [Sat, 23 Jul 2011 00:10:52 +0000 (20:10 -0400)]
AUTHORS bump

13 years agoPR12427: tweak NEWS blurbage
Frank Ch. Eigler [Fri, 22 Jul 2011 18:28:57 +0000 (14:28 -0400)]
PR12427: tweak NEWS blurbage

13 years agotestsuite: memory1 test case name
Frank Ch. Eigler [Fri, 22 Jul 2011 15:59:03 +0000 (11:59 -0400)]
testsuite: memory1 test case name

Reorder the parameters to stap_run2 to put the script name first.

13 years agotestsuite framework: stap_run2 quoting fix
Frank Ch. Eigler [Fri, 22 Jul 2011 15:56:53 +0000 (11:56 -0400)]
testsuite framework: stap_run2 quoting fix

When invoking stap_run2 with multiple optional stap arguments, the
extra arguments are captured in the tcl list $args.  When stap_run2
calls down to stap_run3 to do the real work, it gets packaged as a
single quoted string instead of the original list of options.
We need to unpack this list to pass it on, e.g. via tcl eval.

This impacts test cases that pass multiple parameters, such as
memory1.exp, const_value.exp, process_by_cmd.exp.

13 years agoDeprecated task_backtrace:string (task:long).
Mark Wielaard [Fri, 22 Jul 2011 15:46:10 +0000 (17:46 +0200)]
Deprecated task_backtrace:string (task:long).

This function will go away after 1.6.

13 years agoIntroduce /* pragma:unwind */
Mark Wielaard [Fri, 22 Jul 2011 11:09:35 +0000 (13:09 +0200)]
Introduce /* pragma:unwind */

By marking all tapset functions that really need the unwinder with
/* pragma:unwind */ we can make sure to only compile in unwind.c
when it is really needed.

13 years agoRemove stack-x64x.c specific fallback for _stp_stack_print_fallback().
Mark Wielaard [Fri, 22 Jul 2011 09:51:41 +0000 (11:51 +0200)]
Remove stack-x64x.c specific fallback for _stp_stack_print_fallback().

If the standard kernel based _stp_stack_print_fallback() isn't available
don't try to be smart and guess at stack addresses ourselves. Just give
up. Dwarf based unwinding is good enough now and the kernel dump_stack()
does a much better job than we can at guessing stack values.

13 years agoMerge branch 'master' of ssh://sourceware.org/git/systemtap
Dave Brolley [Thu, 21 Jul 2011 21:37:01 +0000 (17:37 -0400)]
Merge branch 'master' of ssh://sourceware.org/git/systemtap

Conflicts:
NEWS

13 years agoDon't allow the compile server client to honour -I/
Dave Brolley [Thu, 21 Jul 2011 21:34:14 +0000 (17:34 -0400)]
Don't allow the compile server client to honour -I/

- Found by server_args.exp fuzzing tests
- Would require special case code to handle but is a bad bad idea anyway
  so don't allow it.
- Update test suite with the offending test case and some similar ones.

13 years agoRemove STP_USE_FRAME_POINTER support and merge i386/x86_64 into stack-x86.c
Mark Wielaard [Thu, 21 Jul 2011 14:51:48 +0000 (16:51 +0200)]
Remove STP_USE_FRAME_POINTER support and merge i386/x86_64 into stack-x86.c

The only real difference between stack-i386.c and stack-x86_64 was that
the former supported a buggy frame pointer based unwind. Which we never
used and for which the kernel has a better fallback (dump_trace).

13 years agoPIPEFAIL is in bash, but not in sh
William Cohen [Thu, 21 Jul 2011 21:17:48 +0000 (17:17 -0400)]
PIPEFAIL is in bash, but not in sh

Explicitly use /bin/bash because some /bin/sh interpreters do not support
PIPEFAIL.

13 years agoProtect library test from globbing and missing debuginfo.
Stan Cox [Thu, 21 Jul 2011 21:09:27 +0000 (17:09 -0400)]
Protect library test from globbing and missing debuginfo.

library.exp: Allow for debuginfo errors; quote glob pattern.

13 years agoAdd basic functionality for ARM architecture support of nd_syscall.*
William Cohen [Thu, 21 Jul 2011 19:09:07 +0000 (15:09 -0400)]
Add basic functionality for ARM architecture support of nd_syscall.*

The no dwarf syscalls tapset needs some code to access the syscall parameters.
This is a first pass to add the support for the ARM architecture. This
basic support only handles the first 4 arguments on ARM. Argument 5 and
later are on the stack and are not handled.

13 years agoImprove ppc64 test results by handling unimplemented signal syscalls.
David Smith [Thu, 21 Jul 2011 19:12:24 +0000 (14:12 -0500)]
Improve ppc64 test results by handling unimplemented signal syscalls.

* testsuite/systemtap.syscall/signal.c (main): On ppc64, handle the fact
  that sigprocmask()/sigaction() are unimplemented.

13 years agoMerge branch 'master' of git://sourceware.org/git/systemtap
Lukas Berk [Thu, 21 Jul 2011 19:01:15 +0000 (15:01 -0400)]
Merge branch 'master' of git://sourceware.org/git/systemtap

13 years agoReorder open/access sequence
Lukas Berk [Thu, 21 Jul 2011 18:50:54 +0000 (14:50 -0400)]
Reorder open/access sequence

* ctl.c: reorder access()/open()

The previous order was not actually subject to a race condition,
because the file being accessed cannot be modified by a non-root
user.

13 years agoFix unprivilegedok.exp testcase by making test program return 0.
David Smith [Thu, 21 Jul 2011 17:47:27 +0000 (12:47 -0500)]
Fix unprivilegedok.exp testcase by making test program return 0.

* testsuite/systemtap.unprivileged/foo.c (main): Make sure to return 0, to
  avoid warnings from staprun.

13 years agoAdded notes that the STP_OOB_DATA prefixes shouldn't be translated.
David Smith [Thu, 21 Jul 2011 16:41:44 +0000 (11:41 -0500)]
Added notes that the STP_OOB_DATA prefixes shouldn't be translated.

* runtime/transport/control.c (_stp_ctl_alloc_special_buffers):  Added a
  note that the STP_OOB_DATA prefixes ("WARNING:" and "ERROR:") shouldn't
  be translated.
  (_stp_ctl_get_buffer): Ditto.

13 years agoAdded a note that the STP_OOB_DATA prefixes shouldn't be translated.
David Smith [Thu, 21 Jul 2011 16:21:25 +0000 (11:21 -0500)]
Added a note that the STP_OOB_DATA prefixes shouldn't be translated.

* runtime/staprun/mainloop.c (stp_main_loop): Added a note that the
  STP_OOB_DATA prefixes ("WARNING:" and "ERROR:") shouldn't be
  translated.

13 years agoUpdate NEWS about improved support for ARM architecture.
William Cohen [Thu, 21 Jul 2011 14:54:54 +0000 (10:54 -0400)]
Update NEWS about improved support for ARM architecture.

13 years agoMake loc2c-runtime.h treat ARM architecture as a 32-bit architecture
William Cohen [Thu, 21 Jul 2011 14:29:00 +0000 (10:29 -0400)]
Make loc2c-runtime.h treat ARM architecture as a 32-bit architecture

The arm is a 32-bit architecture it should be doing the kread()
and kwrite operations in the same manner as other 32-bit architecture
such as the i386.

13 years agoAvoid "unknown type" errors on unused parameters.
David Smith [Thu, 21 Jul 2011 13:34:30 +0000 (08:34 -0500)]
Avoid "unknown type" errors on unused parameters.

* tapset/arm/aux_syscalls.stp:  Help the translator out by specifying
  types on '_ptrace_return_arch_prctl_addr' unused parameters.
* tapset/i386/aux_syscalls.stp: Ditto.
* tapset/ia64/aux_syscalls.stp: Ditto.
* tapset/powerpc/aux_syscalls.stp: Ditto.

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