mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-01 10:45:49 +00:00
bpf: Enable bpf_cgrp_storage for cgroup1 non-attach case
In the current cgroup1 environment, associating operations between cgroups and applications in a BPF program requires storing a mapping of cgroup_id to application either in a hash map or maintaining it in userspace. However, by enabling bpf_cgrp_storage for cgroup1, it becomes possible to conveniently store application-specific information in cgroup-local storage and utilize it within BPF programs. Furthermore, enabling this feature for cgroup1 involves minor modifications for the non-attach case, streamlining the process. However, when it comes to enabling this functionality for the cgroup1 attach case, it presents challenges. Therefore, the decision is to focus on enabling it solely for the cgroup1 non-attach case at present. If attempting to attach to a cgroup1 fd, the operation will simply fail with the error code -EBADF. Signed-off-by: Yafang Shao <laoar.shao@gmail.com> Acked-by: Tejun Heo <tj@kernel.org> Acked-by: Yonghong Song <yonghong.song@linux.dev> Link: https://lore.kernel.org/r/20231206115326.4295-2-laoar.shao@gmail.com Signed-off-by: Martin KaFai Lau <martin.lau@kernel.org>
This commit is contained in:
parent
1720c42b90
commit
73d9eb340d
@ -82,7 +82,7 @@ static void *bpf_cgrp_storage_lookup_elem(struct bpf_map *map, void *key)
|
||||
int fd;
|
||||
|
||||
fd = *(int *)key;
|
||||
cgroup = cgroup_get_from_fd(fd);
|
||||
cgroup = cgroup_v1v2_get_from_fd(fd);
|
||||
if (IS_ERR(cgroup))
|
||||
return ERR_CAST(cgroup);
|
||||
|
||||
@ -101,7 +101,7 @@ static long bpf_cgrp_storage_update_elem(struct bpf_map *map, void *key,
|
||||
int fd;
|
||||
|
||||
fd = *(int *)key;
|
||||
cgroup = cgroup_get_from_fd(fd);
|
||||
cgroup = cgroup_v1v2_get_from_fd(fd);
|
||||
if (IS_ERR(cgroup))
|
||||
return PTR_ERR(cgroup);
|
||||
|
||||
@ -131,7 +131,7 @@ static long bpf_cgrp_storage_delete_elem(struct bpf_map *map, void *key)
|
||||
int err, fd;
|
||||
|
||||
fd = *(int *)key;
|
||||
cgroup = cgroup_get_from_fd(fd);
|
||||
cgroup = cgroup_v1v2_get_from_fd(fd);
|
||||
if (IS_ERR(cgroup))
|
||||
return PTR_ERR(cgroup);
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user