Skip to content

Commit

Permalink
update(helpers): add an example for bpf_probe_write_user
Browse files Browse the repository at this point in the history
Signed-off-by: Andrea Terzolo <[email protected]>
  • Loading branch information
Andreagit97 committed Oct 12, 2024
1 parent 3446ae8 commit e17c49f
Showing 1 changed file with 26 additions and 2 deletions.
28 changes: 26 additions & 2 deletions docs/linux/helper-function/bpf_probe_write_user.md
Original file line number Diff line number Diff line change
Expand Up @@ -50,5 +50,29 @@ This helper call can be used in the following program types:

### Example

!!! example "Docs could be improved"
This part of the docs is incomplete, contributions are very welcome
```c
#include <vmlinux.h>
#include <bpf/bpf_helpers.h>
#include <bpf/bpf_tracing.h>
#include <bpf/bpf_core_read.h>

// We do it in the exit to not alter the syscall behavior. The userspace program
// will see the new filename only after the syscall execution.
SEC("fexit/__x64_sys_open")
int BPF_PROG(p_open, struct pt_regs *regs, long ret) {
// If it is our example program overwrite the open path.
struct task_struct *task = (struct task_struct *)bpf_get_current_task_btf();
if (bpf_strncmp(task->comm, TASK_COMM_LEN, "example") != 0) {
return 0;
}

// SYSCALL_DEFINE3(open, const char __user *, filename, int, flags, umode_t, mode)
// first param is the pointer to filename.
void *filename_ptr = (void *)PT_REGS_PARM1_CORE_SYSCALL(regs);
const char filename[16] = "/tmp/new";
if (bpf_probe_write_user(filename_ptr, filename, 16)) {
bpf_printk("Failed to write new filename\n");
}
return 0;
}
```

0 comments on commit e17c49f

Please sign in to comment.