| .. | .. |
|---|
| 8 | 8 | #include <linux/netdevice.h> |
|---|
| 9 | 9 | #include <uapi/linux/bpf.h> |
|---|
| 10 | 10 | #include <linux/version.h> |
|---|
| 11 | | -#include "bpf_helpers.h" |
|---|
| 11 | +#include <bpf/bpf_helpers.h> |
|---|
| 12 | +#include <bpf/bpf_tracing.h> |
|---|
| 12 | 13 | |
|---|
| 13 | | -#define _(P) ({typeof(P) val = 0; bpf_probe_read(&val, sizeof(val), &P); val;}) |
|---|
| 14 | +#define _(P) \ |
|---|
| 15 | + ({ \ |
|---|
| 16 | + typeof(P) val = 0; \ |
|---|
| 17 | + bpf_probe_read_kernel(&val, sizeof(val), &(P)); \ |
|---|
| 18 | + val; \ |
|---|
| 19 | + }) |
|---|
| 14 | 20 | |
|---|
| 15 | 21 | /* kprobe is NOT a stable ABI |
|---|
| 16 | 22 | * kernel functions can be removed, renamed or completely change semantics. |
|---|
| .. | .. |
|---|
| 33 | 39 | dev = _(skb->dev); |
|---|
| 34 | 40 | len = _(skb->len); |
|---|
| 35 | 41 | |
|---|
| 36 | | - bpf_probe_read(devname, sizeof(devname), dev->name); |
|---|
| 42 | + bpf_probe_read_kernel(devname, sizeof(devname), dev->name); |
|---|
| 37 | 43 | |
|---|
| 38 | 44 | if (devname[0] == 'l' && devname[1] == 'o') { |
|---|
| 39 | 45 | char fmt[] = "skb %p len %d\n"; |
|---|