Commit 01277258 authored by Hou Tao's avatar Hou Tao Committed by Alexei Starovoitov

bpf: Add missed maybe_wait_bpf_programs() for htab of maps

When doing batched lookup and deletion operations on htab of maps,
maybe_wait_bpf_programs() is needed to ensure all programs don't use the
inner map after the bpf syscall returns.

Instead of adding the wait in __htab_map_lookup_and_delete_batch(),
adding the wait in bpf_map_do_batch() and also removing the calling of
maybe_wait_bpf_programs() from generic_map_{delete,update}_batch().
Signed-off-by: default avatarHou Tao <houtao1@huawei.com>
Link: https://lore.kernel.org/r/20231208102355.2628918-4-houtao@huaweicloud.comSigned-off-by: default avatarAlexei Starovoitov <ast@kernel.org>
parent 37ba5b59
...@@ -1758,7 +1758,6 @@ int generic_map_delete_batch(struct bpf_map *map, ...@@ -1758,7 +1758,6 @@ int generic_map_delete_batch(struct bpf_map *map,
kvfree(key); kvfree(key);
maybe_wait_bpf_programs(map);
return err; return err;
} }
...@@ -1817,7 +1816,6 @@ int generic_map_update_batch(struct bpf_map *map, struct file *map_file, ...@@ -1817,7 +1816,6 @@ int generic_map_update_batch(struct bpf_map *map, struct file *map_file,
kvfree(value); kvfree(value);
kvfree(key); kvfree(key);
maybe_wait_bpf_programs(map);
return err; return err;
} }
...@@ -5031,8 +5029,10 @@ static int bpf_map_do_batch(const union bpf_attr *attr, ...@@ -5031,8 +5029,10 @@ static int bpf_map_do_batch(const union bpf_attr *attr,
else else
BPF_DO_BATCH(map->ops->map_delete_batch, map, attr, uattr); BPF_DO_BATCH(map->ops->map_delete_batch, map, attr, uattr);
err_put: err_put:
if (has_write) if (has_write) {
maybe_wait_bpf_programs(map);
bpf_map_write_active_dec(map); bpf_map_write_active_dec(map);
}
fdput(f); fdput(f);
return err; return err;
} }
......
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