Commit 6e22ab9d authored by Jiri Olsa's avatar Jiri Olsa Committed by Alexei Starovoitov

bpf: Add d_path helper

Adding d_path helper function that returns full path for
given 'struct path' object, which needs to be the kernel
BTF 'path' object. The path is returned in buffer provided
'buf' of size 'sz' and is zero terminated.

  bpf_d_path(&file->f_path, buf, size);

The helper calls directly d_path function, so there's only
limited set of function it can be called from. Adding just
very modest set for the start.

Updating also bpf.h tools uapi header and adding 'path' to
bpf_helpers_doc.py script.
Signed-off-by: default avatarJiri Olsa <jolsa@kernel.org>
Signed-off-by: default avatarAlexei Starovoitov <ast@kernel.org>
Acked-by: default avatarAndrii Nakryiko <andriin@fb.com>
Acked-by: default avatarKP Singh <kpsingh@google.com>
Link: https://lore.kernel.org/bpf/20200825192124.710397-11-jolsa@kernel.org
parent eae2e83e
...@@ -3513,6 +3513,7 @@ union bpf_attr { ...@@ -3513,6 +3513,7 @@ union bpf_attr {
* *
* **-EPERM** This helper cannot be used under the * **-EPERM** This helper cannot be used under the
* current sock_ops->op. * current sock_ops->op.
*
* void *bpf_inode_storage_get(struct bpf_map *map, void *inode, void *value, u64 flags) * void *bpf_inode_storage_get(struct bpf_map *map, void *inode, void *value, u64 flags)
* Description * Description
* Get a bpf_local_storage from an *inode*. * Get a bpf_local_storage from an *inode*.
...@@ -3548,6 +3549,18 @@ union bpf_attr { ...@@ -3548,6 +3549,18 @@ union bpf_attr {
* 0 on success. * 0 on success.
* *
* **-ENOENT** if the bpf_local_storage cannot be found. * **-ENOENT** if the bpf_local_storage cannot be found.
*
* long bpf_d_path(struct path *path, char *buf, u32 sz)
* Description
* Return full path for given 'struct path' object, which
* needs to be the kernel BTF 'path' object. The path is
* returned in the provided buffer 'buf' of size 'sz' and
* is zero terminated.
*
* Return
* On success, the strictly positive length of the string,
* including the trailing NUL character. On error, a negative
* value.
*/ */
#define __BPF_FUNC_MAPPER(FN) \ #define __BPF_FUNC_MAPPER(FN) \
FN(unspec), \ FN(unspec), \
...@@ -3697,6 +3710,7 @@ union bpf_attr { ...@@ -3697,6 +3710,7 @@ union bpf_attr {
FN(reserve_hdr_opt), \ FN(reserve_hdr_opt), \
FN(inode_storage_get), \ FN(inode_storage_get), \
FN(inode_storage_delete), \ FN(inode_storage_delete), \
FN(d_path), \
/* */ /* */
/* integer value in 'imm' field of BPF_CALL instruction selects which helper /* integer value in 'imm' field of BPF_CALL instruction selects which helper
......
...@@ -1098,6 +1098,52 @@ static const struct bpf_func_proto bpf_send_signal_thread_proto = { ...@@ -1098,6 +1098,52 @@ static const struct bpf_func_proto bpf_send_signal_thread_proto = {
.arg1_type = ARG_ANYTHING, .arg1_type = ARG_ANYTHING,
}; };
BPF_CALL_3(bpf_d_path, struct path *, path, char *, buf, u32, sz)
{
long len;
char *p;
if (!sz)
return 0;
p = d_path(path, buf, sz);
if (IS_ERR(p)) {
len = PTR_ERR(p);
} else {
len = buf + sz - p;
memmove(buf, p, len);
}
return len;
}
BTF_SET_START(btf_allowlist_d_path)
BTF_ID(func, vfs_truncate)
BTF_ID(func, vfs_fallocate)
BTF_ID(func, dentry_open)
BTF_ID(func, vfs_getattr)
BTF_ID(func, filp_close)
BTF_SET_END(btf_allowlist_d_path)
static bool bpf_d_path_allowed(const struct bpf_prog *prog)
{
return btf_id_set_contains(&btf_allowlist_d_path, prog->aux->attach_btf_id);
}
BTF_ID_LIST(bpf_d_path_btf_ids)
BTF_ID(struct, path)
static const struct bpf_func_proto bpf_d_path_proto = {
.func = bpf_d_path,
.gpl_only = false,
.ret_type = RET_INTEGER,
.arg1_type = ARG_PTR_TO_BTF_ID,
.arg2_type = ARG_PTR_TO_MEM,
.arg3_type = ARG_CONST_SIZE_OR_ZERO,
.btf_id = bpf_d_path_btf_ids,
.allowed = bpf_d_path_allowed,
};
const struct bpf_func_proto * const struct bpf_func_proto *
bpf_tracing_func_proto(enum bpf_func_id func_id, const struct bpf_prog *prog) bpf_tracing_func_proto(enum bpf_func_id func_id, const struct bpf_prog *prog)
{ {
...@@ -1579,6 +1625,8 @@ tracing_prog_func_proto(enum bpf_func_id func_id, const struct bpf_prog *prog) ...@@ -1579,6 +1625,8 @@ tracing_prog_func_proto(enum bpf_func_id func_id, const struct bpf_prog *prog)
return prog->expected_attach_type == BPF_TRACE_ITER ? return prog->expected_attach_type == BPF_TRACE_ITER ?
&bpf_seq_write_proto : &bpf_seq_write_proto :
NULL; NULL;
case BPF_FUNC_d_path:
return &bpf_d_path_proto;
default: default:
return raw_tp_prog_func_proto(func_id, prog); return raw_tp_prog_func_proto(func_id, prog);
} }
......
...@@ -432,6 +432,7 @@ class PrinterHelpers(Printer): ...@@ -432,6 +432,7 @@ class PrinterHelpers(Printer):
'struct __sk_buff', 'struct __sk_buff',
'struct sk_msg_md', 'struct sk_msg_md',
'struct xdp_md', 'struct xdp_md',
'struct path',
] ]
known_types = { known_types = {
'...', '...',
...@@ -472,6 +473,7 @@ class PrinterHelpers(Printer): ...@@ -472,6 +473,7 @@ class PrinterHelpers(Printer):
'struct tcp_request_sock', 'struct tcp_request_sock',
'struct udp6_sock', 'struct udp6_sock',
'struct task_struct', 'struct task_struct',
'struct path',
} }
mapped_types = { mapped_types = {
'u8': '__u8', 'u8': '__u8',
......
...@@ -3513,6 +3513,7 @@ union bpf_attr { ...@@ -3513,6 +3513,7 @@ union bpf_attr {
* *
* **-EPERM** This helper cannot be used under the * **-EPERM** This helper cannot be used under the
* current sock_ops->op. * current sock_ops->op.
*
* void *bpf_inode_storage_get(struct bpf_map *map, void *inode, void *value, u64 flags) * void *bpf_inode_storage_get(struct bpf_map *map, void *inode, void *value, u64 flags)
* Description * Description
* Get a bpf_local_storage from an *inode*. * Get a bpf_local_storage from an *inode*.
...@@ -3548,6 +3549,18 @@ union bpf_attr { ...@@ -3548,6 +3549,18 @@ union bpf_attr {
* 0 on success. * 0 on success.
* *
* **-ENOENT** if the bpf_local_storage cannot be found. * **-ENOENT** if the bpf_local_storage cannot be found.
*
* long bpf_d_path(struct path *path, char *buf, u32 sz)
* Description
* Return full path for given 'struct path' object, which
* needs to be the kernel BTF 'path' object. The path is
* returned in the provided buffer 'buf' of size 'sz' and
* is zero terminated.
*
* Return
* On success, the strictly positive length of the string,
* including the trailing NUL character. On error, a negative
* value.
*/ */
#define __BPF_FUNC_MAPPER(FN) \ #define __BPF_FUNC_MAPPER(FN) \
FN(unspec), \ FN(unspec), \
...@@ -3697,6 +3710,7 @@ union bpf_attr { ...@@ -3697,6 +3710,7 @@ union bpf_attr {
FN(reserve_hdr_opt), \ FN(reserve_hdr_opt), \
FN(inode_storage_get), \ FN(inode_storage_get), \
FN(inode_storage_delete), \ FN(inode_storage_delete), \
FN(d_path), \
/* */ /* */
/* integer value in 'imm' field of BPF_CALL instruction selects which helper /* integer value in 'imm' field of BPF_CALL instruction selects which helper
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment