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
447ad500
Commit
447ad500
authored
Nov 08, 2017
by
4ast
Committed by
GitHub
Nov 08, 2017
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #1418 from zoidbergwill/master
Consistently use spaces in C in Python tutorial
parents
6fc8d15c
44ad8a1e
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
49 additions
and
49 deletions
+49
-49
docs/tutorial_bcc_python_developer.md
docs/tutorial_bcc_python_developer.md
+49
-49
No files found.
docs/tutorial_bcc_python_developer.md
View file @
447ad500
...
@@ -67,8 +67,8 @@ from bcc import BPF
...
@@ -67,8 +67,8 @@ from bcc import BPF
# define BPF program
# define BPF program
prog = """
prog = """
int hello(void *ctx) {
int hello(void *ctx) {
bpf_trace_printk("Hello, World!\\n");
bpf_trace_printk("Hello, World!\\n");
return 0;
return 0;
}
}
"""
"""
...
@@ -126,21 +126,21 @@ BPF_HASH(last);
...
@@ -126,21 +126,21 @@ BPF_HASH(last);
int do_trace(struct pt_regs *ctx) {
int do_trace(struct pt_regs *ctx) {
u64 ts, *tsp, delta, key = 0;
u64 ts, *tsp, delta, key = 0;
// attempt to read stored timestamp
// attempt to read stored timestamp
tsp = last.lookup(&key);
tsp = last.lookup(&key);
if (tsp != 0) {
if (tsp != 0) {
delta = bpf_ktime_get_ns() - *tsp;
delta = bpf_ktime_get_ns() - *tsp;
if (delta < 1000000000) {
if (delta < 1000000000) {
// output if time is less than 1 second
// output if time is less than 1 second
bpf_trace_printk("%d\\n", delta / 1000000);
bpf_trace_printk("%d\\n", delta / 1000000);
}
}
last.delete(&key);
last.delete(&key);
}
}
// update stored timestamp
// update stored timestamp
ts = bpf_ktime_get_ns();
ts = bpf_ktime_get_ns();
last.update(&key, &ts);
last.update(&key, &ts);
return 0;
return 0;
}
}
""")
""")
...
@@ -211,7 +211,7 @@ void trace_completion(struct pt_regs *ctx, struct request *req) {
...
@@ -211,7 +211,7 @@ void trace_completion(struct pt_regs *ctx, struct request *req) {
if (tsp != 0) {
if (tsp != 0) {
delta = bpf_ktime_get_ns() - *tsp;
delta = bpf_ktime_get_ns() - *tsp;
bpf_trace_printk("%d %x %d\\n", req->__data_len,
bpf_trace_printk("%d %x %d\\n", req->__data_len,
req->cmd_flags, delta / 1000);
req->cmd_flags, delta / 1000);
start.delete(&req);
start.delete(&req);
}
}
}
}
...
@@ -258,22 +258,22 @@ prog = """
...
@@ -258,22 +258,22 @@ prog = """
// define output data structure in C
// define output data structure in C
struct data_t {
struct data_t {
u32 pid;
u32 pid;
u64 ts;
u64 ts;
char comm[TASK_COMM_LEN];
char comm[TASK_COMM_LEN];
};
};
BPF_PERF_OUTPUT(events);
BPF_PERF_OUTPUT(events);
int hello(struct pt_regs *ctx) {
int hello(struct pt_regs *ctx) {
struct data_t data = {};
struct data_t data = {};
data.pid = bpf_get_current_pid_tgid();
data.pid = bpf_get_current_pid_tgid();
data.ts = bpf_ktime_get_ns();
data.ts = bpf_ktime_get_ns();
bpf_get_current_comm(&data.comm, sizeof(data.comm));
bpf_get_current_comm(&data.comm, sizeof(data.comm));
events.perf_submit(ctx, &data, sizeof(data));
events.perf_submit(ctx, &data, sizeof(data));
return 0;
return 0;
}
}
"""
"""
...
@@ -371,9 +371,9 @@ print("Tracing... Hit Ctrl-C to end.")
...
@@ -371,9 +371,9 @@ print("Tracing... Hit Ctrl-C to end.")
# trace until Ctrl-C
# trace until Ctrl-C
try:
try:
sleep(99999999)
sleep(99999999)
except KeyboardInterrupt:
except KeyboardInterrupt:
print
print
# output
# output
b["dist"].print_log2_hist("kbytes")
b["dist"].print_log2_hist("kbytes")
...
@@ -467,9 +467,9 @@ from bcc import BPF
...
@@ -467,9 +467,9 @@ from bcc import BPF
# load BPF program
# load BPF program
b = BPF(text="""
b = BPF(text="""
TRACEPOINT_PROBE(random, urandom_read) {
TRACEPOINT_PROBE(random, urandom_read) {
// args is from /sys/kernel/debug/tracing/events/random/urandom_read/format
// args is from /sys/kernel/debug/tracing/events/random/urandom_read/format
bpf_trace_printk("%d\\n", args->got_bits);
bpf_trace_printk("%d\\n", args->got_bits);
return 0;
return 0;
};
};
""")
""")
...
@@ -552,21 +552,21 @@ b = BPF(text="""
...
@@ -552,21 +552,21 @@ b = BPF(text="""
#include <uapi/linux/ptrace.h>
#include <uapi/linux/ptrace.h>
struct key_t {
struct key_t {
char c[80];
char c[80];
};
};
BPF_HASH(counts, struct key_t);
BPF_HASH(counts, struct key_t);
int count(struct pt_regs *ctx) {
int count(struct pt_regs *ctx) {
if (!PT_REGS_PARM1(ctx))
if (!PT_REGS_PARM1(ctx))
return 0;
return 0;
struct key_t key = {};
struct key_t key = {};
u64 zero = 0, *val;
u64 zero = 0, *val;
bpf_probe_read(&key.c, sizeof(key.c), (void *)PT_REGS_PARM1(ctx));
bpf_probe_read(&key.c, sizeof(key.c), (void *)PT_REGS_PARM1(ctx));
val = counts.lookup_or_init(&key, &zero);
val = counts.lookup_or_init(&key, &zero);
(*val)++;
(*val)++;
return 0;
return 0;
};
};
""")
""")
b.attach_uprobe(name="c", sym="strlen", fn_name="count")
b.attach_uprobe(name="c", sym="strlen", fn_name="count")
...
@@ -608,20 +608,20 @@ Relevant code from [examples/tracing/nodejs_http_server.py](../examples/tracing/
...
@@ -608,20 +608,20 @@ Relevant code from [examples/tracing/nodejs_http_server.py](../examples/tracing/
```
Python
```
Python
if len(sys.argv) < 2:
if len(sys.argv) < 2:
print("USAGE: nodejs_http_server PID")
print("USAGE: nodejs_http_server PID")
exit()
exit()
pid = sys.argv[1]
pid = sys.argv[1]
# load BPF program
# load BPF program
bpf_text = """
bpf_text = """
#include <uapi/linux/ptrace.h>
#include <uapi/linux/ptrace.h>
int do_trace(struct pt_regs *ctx) {
int do_trace(struct pt_regs *ctx) {
uint64_t addr;
uint64_t addr;
char path[128];
char path[128];
bpf_usdt_readarg(6, ctx, &addr);
bpf_usdt_readarg(6, ctx, &addr);
bpf_probe_read(&path, sizeof(path), (void *)addr);
bpf_probe_read(&path, sizeof(path), (void *)addr);
bpf_trace_printk("path:%s\\n", path);
bpf_trace_printk("path:%s\\n", path);
return 0;
return 0;
};
};
"""
"""
...
...
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