Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
B
bcc
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
bcc
Commits
cc27edfd
Commit
cc27edfd
authored
Feb 14, 2016
by
Sasha Goldshtein
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Fixed bug with labels, added support for tuples in hash
parent
7983d6b6
Changes
3
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
215 additions
and
98 deletions
+215
-98
man/man8/argdist.8
man/man8/argdist.8
+9
-5
tools/argdist.py
tools/argdist.py
+155
-73
tools/argdist_examples.txt
tools/argdist_examples.txt
+51
-20
No files found.
man/man8/argdist.8
View file @
cc27edfd
...
@@ -49,7 +49,7 @@ include in the BPF program, e.g. 'linux/blkdev.h' or 'linux/time.h'.
...
@@ -49,7 +49,7 @@ include in the BPF program, e.g. 'linux/blkdev.h' or 'linux/time.h'.
.SH SPECIFIER SYNTAX
.SH SPECIFIER SYNTAX
The general specifier syntax is as follows:
The general specifier syntax is as follows:
.B {p,r}:[library]:function(signature)[:type
:expr
[:filter]][#label]
.B {p,r}:[library]:function(signature)[:type
[,type...]:expr[,expr...]
[:filter]][#label]
.TP
.TP
.B {p,r}
.B {p,r}
Probe type \- "p" for function entry, "r" for function return;
Probe type \- "p" for function entry, "r" for function return;
...
@@ -74,13 +74,13 @@ on the other hand, is only required if you plan to collect parameter values
...
@@ -74,13 +74,13 @@ on the other hand, is only required if you plan to collect parameter values
based on that signature. For example, if you only want to collect the first
based on that signature. For example, if you only want to collect the first
parameter, you don't have to specify the rest of the parameters in the signature.
parameter, you don't have to specify the rest of the parameters in the signature.
.TP
.TP
.B [type]
.B [type
[,type...]
]
The type
of the expression
to capture.
The type
(s) of the expression(s)
to capture.
This is the type of the keys in the histogram or raw event collection that are
This is the type of the keys in the histogram or raw event collection that are
collected by the probes.
collected by the probes.
.TP
.TP
.B [expr]
.B [expr
[,expr...]
]
The expression to capture.
The expression
(s)
to capture.
These are the values that are assigned to the histogram or raw event collection.
These are the values that are assigned to the histogram or raw event collection.
You may use the parameters directly, or valid C expressions that involve the
You may use the parameters directly, or valid C expressions that involve the
parameters, such as "size % 10".
parameters, such as "size % 10".
...
@@ -143,6 +143,10 @@ Print histograms of sleep() and nanosleep() parameter values:
...
@@ -143,6 +143,10 @@ Print histograms of sleep() and nanosleep() parameter values:
Spy on writes to STDOUT performed by process 2780, up to a string size of 120 characters:
Spy on writes to STDOUT performed by process 2780, up to a string size of 120 characters:
#
#
.B argdist.py -p 2780 -z 120 -C 'p:c:write(int fd, char* buf, size_t len):char*:buf:fd==1'
.B argdist.py -p 2780 -z 120 -C 'p:c:write(int fd, char* buf, size_t len):char*:buf:fd==1'
.TP
Group files being read from and the read sizes from __vfs_read:
#
.B argdist.py -I 'linux/fs.h' -C 'p::__vfs_read(struct file *file, void *buf, size_t count):char*,size_t:file->f_path.dentry->d_iname,count:file->f_path.dentry->d_iname[0]!=0'
.SH SOURCE
.SH SOURCE
This is from bcc.
This is from bcc.
.IP
.IP
...
...
tools/argdist.py
View file @
cc27edfd
This diff is collapsed.
Click to expand it.
tools/argdist_examples.txt
View file @
cc27edfd
...
@@ -156,13 +156,13 @@ What about reads? You could trace gets() across the system and print the
...
@@ -156,13 +156,13 @@ What about reads? You could trace gets() across the system and print the
strings input by the user (note how "r" is used instead of "p" to attach a
strings input by the user (note how "r" is used instead of "p" to attach a
probe to the function's return):
probe to the function's return):
# ./argdist.py -i 10 -n 1 -C 'r:c:gets():char*:$retval:$retval!=0'
# ./argdist.py -i 10 -n 1 -C 'r:c:gets():char*:
(char*)
$retval:$retval!=0'
[02:12:23]
[02:12:23]
r:c:gets():char*:$retval:$retval!=0
r:c:gets():char*:$retval:$retval!=0
COUNT EVENT
COUNT EVENT
1 (char*)
ctx->ax
= hi there
1 (char*)
$retval
= hi there
3 (char*)
ctx->ax
= sasha
3 (char*)
$retval
= sasha
8 (char*)
ctx->ax
= hello
8 (char*)
$retval
= hello
Similarly, we could get a histogram of the error codes returned by read():
Similarly, we could get a histogram of the error codes returned by read():
...
@@ -192,18 +192,16 @@ longer than 0.1ms (100,000ns):
...
@@ -192,18 +192,16 @@ longer than 0.1ms (100,000ns):
[01:08:48]
[01:08:48]
r::__vfs_read():u32:$PID:$latency > 100000
r::__vfs_read():u32:$PID:$latency > 100000
COUNT EVENT
COUNT EVENT
1
bpf_get_current_pid_tgid()
= 10457
1
$PID
= 10457
21
bpf_get_current_pid_tgid()
= 2780
21
$PID
= 2780
[01:08:49]
[01:08:49]
r::__vfs_read():u32:$PID:$latency > 100000
r::__vfs_read():u32:$PID:$latency > 100000
COUNT EVENT
COUNT EVENT
1
bpf_get_current_pid_tgid()
= 10457
1
$PID
= 10457
21
bpf_get_current_pid_tgid()
= 2780
21
$PID
= 2780
^C
^C
As you see, the $PID alias is expanded to the BPF function bpf_get_current_pid_tgid(),
It looks like process 2780 performed 21 slow reads.
which returns the current process' pid. It looks like process 2780 performed
21 slow reads.
Occasionally, entry parameter values are also interesting. For example, you
Occasionally, entry parameter values are also interesting. For example, you
might be curious how long it takes malloc() to allocate memory -- nanoseconds
might be curious how long it takes malloc() to allocate memory -- nanoseconds
...
@@ -231,6 +229,39 @@ and take 2-15 nanoseconds per byte. Other allocations are slower, and take
...
@@ -231,6 +229,39 @@ and take 2-15 nanoseconds per byte. Other allocations are slower, and take
64-127 nanoseconds per byte. And some allocations are slower still, and take
64-127 nanoseconds per byte. And some allocations are slower still, and take
multiple microseconds per byte.
multiple microseconds per byte.
You could also group results by more than one field. For example, __kmalloc
takes an additional flags parameter that describes how to allocate memory:
# ./argdist.py -I 'linux/slab.h' -C 'p::__kmalloc(size_t size, gfp_t flags):gfp_t,size_t:flags,size'
[03:42:29]
p::__kmalloc(size_t size, gfp_t flags):gfp_t,size_t:flags,size
COUNT EVENT
1 flags = 16, size = 152
2 flags = 131280, size = 8
7 flags = 131280, size = 16
[03:42:30]
p::__kmalloc(size_t size, gfp_t flags):gfp_t,size_t:flags,size
COUNT EVENT
1 flags = 16, size = 152
6 flags = 131280, size = 8
19 flags = 131280, size = 16
[03:42:31]
p::__kmalloc(size_t size, gfp_t flags):gfp_t,size_t:flags,size
COUNT EVENT
2 flags = 16, size = 152
10 flags = 131280, size = 8
31 flags = 131280, size = 16
[03:42:32]
p::__kmalloc(size_t size, gfp_t flags):gfp_t,size_t:flags,size
COUNT EVENT
2 flags = 16, size = 152
14 flags = 131280, size = 8
43 flags = 131280, size = 16
^C
The flags value must be expanded by hand, but it's still helpful to eliminate
certain kinds of allocations or visually group them together.
Here's a final example that finds how many write() system calls are performed
Here's a final example that finds how many write() system calls are performed
by each process on the system:
by each process on the system:
...
@@ -238,15 +269,15 @@ by each process on the system:
...
@@ -238,15 +269,15 @@ by each process on the system:
[06:47:18]
[06:47:18]
write by process
write by process
COUNT EVENT
COUNT EVENT
3
bpf_get_current_pid_tgid()
= 8889
3
$PID
= 8889
7
bpf_get_current_pid_tgid()
= 7615
7
$PID
= 7615
7
bpf_get_current_pid_tgid()
= 2480
7
$PID
= 2480
[06:47:19]
[06:47:19]
write by process
write by process
COUNT EVENT
COUNT EVENT
9
bpf_get_current_pid_tgid()
= 8889
9
$PID
= 8889
23
bpf_get_current_pid_tgid()
= 7615
23
$PID
= 7615
23
bpf_get_current_pid_tgid()
= 2480
23
$PID
= 2480
USAGE message:
USAGE message:
...
@@ -280,7 +311,7 @@ optional arguments:
...
@@ -280,7 +311,7 @@ optional arguments:
additional header files to include in the BPF program
additional header files to include in the BPF program
Probe specifier syntax:
Probe specifier syntax:
{p,r}:[library]:function(signature)[:type
:expr
[:filter]][#label]
{p,r}:[library]:function(signature)[:type
[,type...]:expr[,expr...]
[:filter]][#label]
Where:
Where:
p,r -- probe at function entry or at function exit
p,r -- probe at function entry or at function exit
in exit probes: can use $retval, $entry(param), $latency
in exit probes: can use $retval, $entry(param), $latency
...
@@ -288,8 +319,8 @@ Where:
...
@@ -288,8 +319,8 @@ Where:
(leave empty for kernel functions)
(leave empty for kernel functions)
function -- the function name to trace
function -- the function name to trace
signature -- the function's parameters, as in the C header
signature -- the function's parameters, as in the C header
type -- the type of the expression to collect
type -- the type of the expression to collect
(supports multiple)
expr -- the expression to collect
expr -- the expression to collect
(supports multiple)
filter -- the filter that is applied to collected values
filter -- the filter that is applied to collected values
label -- the label for this probe in the resulting output
label -- the label for this probe in the resulting output
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment