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
569461de
Commit
569461de
authored
Dec 15, 2017
by
4ast
Committed by
GitHub
Dec 15, 2017
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #1485 from iovisor/yhs_dev
add examples for including additional header files
parents
7c1c804c
f4470dc2
Changes
4
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
45 additions
and
5 deletions
+45
-5
tools/argdist.py
tools/argdist.py
+10
-1
tools/argdist_example.txt
tools/argdist_example.txt
+9
-1
tools/trace.py
tools/trace.py
+14
-2
tools/trace_example.txt
tools/trace_example.txt
+12
-1
No files found.
tools/argdist.py
View file @
569461de
...
@@ -590,6 +590,13 @@ argdist -p 2780 -z 120 \\
...
@@ -590,6 +590,13 @@ argdist -p 2780 -z 120 \\
-C 'p:c:write(int fd, char* buf, size_t len):char*:buf:fd==1'
-C 'p:c:write(int fd, char* buf, size_t len):char*:buf:fd==1'
Spy on writes to STDOUT performed by process 2780, up to a string size
Spy on writes to STDOUT performed by process 2780, up to a string size
of 120 characters
of 120 characters
argdist -I 'kernel/sched/sched.h'
\
\
-C 'p::__account_cfs_rq_runtime(struct cfs_rq *cfs_rq):s64:cfs_rq->runtime_remaining'
Trace on the cfs scheduling runqueue remaining runtime. The struct cfs_rq is defined
in kernel/sched/sched.h which is in kernel source tree and not in kernel-devel
package. So this command needs to run at the kernel source tree root directory
so that the added header file can be found by the compiler.
"""
"""
def __init__(self):
def __init__(self):
...
@@ -625,7 +632,9 @@ argdist -p 2780 -z 120 \\
...
@@ -625,7 +632,9 @@ argdist -p 2780 -z 120 \\
parser.add_argument("
-
I
", "
--
include
", action="
append
",
parser.add_argument("
-
I
", "
--
include
", action="
append
",
metavar="
header
",
metavar="
header
",
help="
additional
header
files
to
include
in
the
BPF
program
"
help="
additional
header
files
to
include
in
the
BPF
program
"
"
as
either
full
path
,
or
relative
to
'/usr/include'")
"
as
either
full
path
,
"
"
or
relative
to
relative
to
current
working
directory
,
"
"
or
relative
to
default
kernel
header
search
path
")
self.args = parser.parse_args()
self.args = parser.parse_args()
self.usdt_ctx = None
self.usdt_ctx = None
...
...
tools/argdist_example.txt
View file @
569461de
...
@@ -363,7 +363,8 @@ optional arguments:
...
@@ -363,7 +363,8 @@ optional arguments:
below)
below)
-I header, --include header
-I header, --include header
additional header files to include in the BPF program
additional header files to include in the BPF program
as either full path, or relative to '/usr/include'
as either full path, or relative to current working directory,
or relative to default kernel header search path
Probe specifier syntax:
Probe specifier syntax:
{p,r,t,u}:{[library],category}:function(signature)[:type[,type...]:expr[,expr...][:filter]][#label]
{p,r,t,u}:{[library],category}:function(signature)[:type[,type...]:expr[,expr...][:filter]][#label]
...
@@ -439,3 +440,10 @@ argdist -p 2780 -z 120 \
...
@@ -439,3 +440,10 @@ argdist -p 2780 -z 120 \
-C 'p:c:write(int fd, char* buf, size_t len):char*:buf:fd==1'
-C 'p:c:write(int fd, char* buf, size_t len):char*:buf:fd==1'
Spy on writes to STDOUT performed by process 2780, up to a string size
Spy on writes to STDOUT performed by process 2780, up to a string size
of 120 characters
of 120 characters
argdist -I 'kernel/sched/sched.h' \
-C 'p::__account_cfs_rq_runtime(struct cfs_rq *cfs_rq):s64:cfs_rq->runtime_remaining'
Trace on the cfs scheduling runqueue remaining runtime. The struct cfs_rq is defined
in kernel/sched/sched.h which is in kernel source tree and not in kernel-devel
package. So this command needs to run at the kernel source tree root directory
so that the added header file can be found by the compiler.
tools/trace.py
View file @
569461de
...
@@ -576,6 +576,16 @@ trace 'u:pthread:pthread_create (arg4 != 0)'
...
@@ -576,6 +576,16 @@ trace 'u:pthread:pthread_create (arg4 != 0)'
Trace the USDT probe pthread_create when its 4th argument is non-zero
Trace the USDT probe pthread_create when its 4th argument is non-zero
trace 'p::SyS_nanosleep(struct timespec *ts) "sleep for %lld ns", ts->tv_nsec'
trace 'p::SyS_nanosleep(struct timespec *ts) "sleep for %lld ns", ts->tv_nsec'
Trace the nanosleep syscall and print the sleep duration in ns
Trace the nanosleep syscall and print the sleep duration in ns
trace -I 'linux/fs.h'
\
\
'p::uprobe_register(struct inode *inode) "a_ops = %llx", inode->i_mapping->a_ops'
Trace the uprobe_register inode mapping ops, and the symbol can be found
in /proc/kallsyms
trace -I 'kernel/sched/sched.h'
\
\
'p::__account_cfs_rq_runtime(struct cfs_rq *cfs_rq) "%d", cfs_rq->runtime_remaining'
Trace the cfs scheduling runqueue remaining runtime. The struct cfs_rq is defined
in kernel/sched/sched.h which is in kernel source tree and not in kernel-devel
package. So this command needs to run at the kernel source tree root directory
so that the added header file can be found by the compiler.
"""
"""
def
__init__
(
self
):
def
__init__
(
self
):
...
@@ -615,10 +625,12 @@ trace 'p::SyS_nanosleep(struct timespec *ts) "sleep for %lld ns", ts->tv_nsec'
...
@@ -615,10 +625,12 @@ trace 'p::SyS_nanosleep(struct timespec *ts) "sleep for %lld ns", ts->tv_nsec'
parser
.
add_argument
(
"-I"
,
"--include"
,
action
=
"append"
,
parser
.
add_argument
(
"-I"
,
"--include"
,
action
=
"append"
,
metavar
=
"header"
,
metavar
=
"header"
,
help
=
"additional header files to include in the BPF program "
help
=
"additional header files to include in the BPF program "
"as either full path, or relative to '/usr/include'"
)
"as either full path, "
"or relative to current working directory, "
"or relative to default kernel header search path"
)
self
.
args
=
parser
.
parse_args
()
self
.
args
=
parser
.
parse_args
()
if
self
.
args
.
tgid
and
self
.
args
.
pid
:
if
self
.
args
.
tgid
and
self
.
args
.
pid
:
parser
.
error
(
"only one of -p and -
t
may be specified"
)
parser
.
error
(
"only one of -p and -
L
may be specified"
)
def
_create_probes
(
self
):
def
_create_probes
(
self
):
Probe
.
configure
(
self
.
args
)
Probe
.
configure
(
self
.
args
)
...
...
tools/trace_example.txt
View file @
569461de
...
@@ -249,7 +249,8 @@ optional arguments:
...
@@ -249,7 +249,8 @@ optional arguments:
-U, --user-stack output user stack trace
-U, --user-stack output user stack trace
-I header, --include header
-I header, --include header
additional header files to include in the BPF program
additional header files to include in the BPF program
as either full path, or relative to '/usr/include'
as either full path, or relative to current working directory,
or relative to default kernel header search path
EXAMPLES:
EXAMPLES:
...
@@ -277,3 +278,13 @@ trace 'u:pthread:pthread_create (arg4 != 0)'
...
@@ -277,3 +278,13 @@ trace 'u:pthread:pthread_create (arg4 != 0)'
Trace the USDT probe pthread_create when its 4th argument is non-zero
Trace the USDT probe pthread_create when its 4th argument is non-zero
trace 'p::SyS_nanosleep(struct timespec *ts) "sleep for %lld ns", ts->tv_nsec'
trace 'p::SyS_nanosleep(struct timespec *ts) "sleep for %lld ns", ts->tv_nsec'
Trace the nanosleep syscall and print the sleep duration in ns
Trace the nanosleep syscall and print the sleep duration in ns
trace -I 'linux/fs.h' \
'p::uprobe_register(struct inode *inode) "a_ops = %llx", inode->i_mapping->a_ops'
Trace the uprobe_register inode mapping ops, and the symbol can be found
in /proc/kallsyms
trace -I 'kernel/sched/sched.h' \
'p::__account_cfs_rq_runtime(struct cfs_rq *cfs_rq) "%d", cfs_rq->runtime_remaining'
Trace the cfs scheduling runqueue remaining runtime. The struct cfs_rq is defined
in kernel/sched/sched.h which is in kernel source tree and not in kernel-devel
package. So this command needs to run at the kernel source tree root directory
so that the added header file can be found by the compiler.
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