]> CyberLeo.Net >> Repos - FreeBSD/stable/9.git/commit
MFC r251238:
authormarkj <markj@ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f>
Sat, 6 Jul 2013 02:49:56 +0000 (02:49 +0000)
committermarkj <markj@ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f>
Sat, 6 Jul 2013 02:49:56 +0000 (02:49 +0000)
commitce4e66f06d420e7cd52418be9ca017f252a987ce
tree90958790303927388dfc261941ca4dd40d7acdb5
parent72958cebaee088d5c59e713ef675a2cd921650d2
MFC r251238:
SDT probes can directly pass up to five arguments as arguments to
dtrace_probe(). Arguments beyond these five must be obtained in an
architecture-specific way; this can be done through the getargval provider
method, and through dtrace_getarg() if getargval isn't overridden.

This change fixes two off-by-one bugs in the way these arguments are fetched
in FreeBSD's DTrace implementation. First, the SDT provider must set the
aframes parameter to 1 when creating a probe. The aframes parameter controls
the number of frames that dtrace_getarg() will step over in order to find
the frame containing the extra arguments. On FreeBSD, dtrace_getarg() is
called in SDT probe context via

dtrace_probe()->dtrace_dif_emulate()->dtrace_dif_variable->dtrace_getarg()

so aframes must be 3 since the arguments are in dtrace_probe()'s frame; it
was previously being called with a value of 2 instead. illumos uses a
different aframes value for SDT probes, but this is because illumos SDT
probes fire by triggering the #UD fault handler rather than calling
dtrace_probe() directly.

The second bug has to do with the way arguments are grabbed out
dtrace_probe()'s frame on amd64. The code currently jumps over the first
stack argument and retrieves the rest of them using a pointer into the
stack. This works on i386 because all of dtrace_probe()'s arguments will be
on the stack and the first argument is the probe ID, which should be
ignored. However, it is incorrect to ignore the first stack argument on
amd64, so we correct the pointer used to access the arguments.

git-svn-id: svn://svn.freebsd.org/base/stable/9@252858 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f
sys/cddl/dev/dtrace/amd64/dtrace_isa.c
sys/cddl/dev/sdt/sdt.c