Function report |
Source Code:kernel\bpf\syscall.c |
Create Date:2022-07-28 12:52:28 |
| Last Modify:2022-05-19 18:06:12 | Copyright©Brick |
| home page | Tree |
| Annotation kernel can get tool activity | Download SCCT | Chinese |
Name:map_lookup_elem
Proto:static int map_lookup_elem(union bpf_attr *attr)
Type:int
Parameter:
| Type | Parameter | Name |
|---|---|---|
| union bpf_attr * | attr |
| 814 | __user * ukey = u64_to_user_ptr(key) |
| 815 | __user * uvalue = u64_to_user_ptr(value) |
| 823 | If helper macro to check that unused fields 'union bpf_attr' are zero (BPF_MAP_LOOKUP_ELEM) Then Return -EINVAL |
| 826 | If flags & ~spin_lock-ed map_lookup/map_update Then Return -EINVAL |
| 830 | map = error is returned, fd is released.* On success caller should complete fd access with matching fdput() |
| 833 | If Not (map_get_sys_perms(map, f) & Has read method(s) ) Then |
| 838 | If flags & spin_lock-ed map_lookup/map_update && Not map_value_has_spin_lock(map) Then |
| 844 | key = __bpf_copy_key(ukey, key_size) |
| 855 | Else if IS_FD_MAP(map) Then value_size = sizeof(u32) |
| 857 | Else value_size = value_size |
| 861 | value = Allocation memory |
| 865 | If bpf_map_is_dev_bound(map) Then |
| 872 | If map_type == BPF_MAP_TYPE_PERCPU_HASH || map_type == BPF_MAP_TYPE_LRU_PERCPU_HASH Then |
| 874 | err = bpf_percpu_hash_copy(map, key, value) |
| 875 | Else if map_type == BPF_MAP_TYPE_PERCPU_ARRAY Then |
| 876 | err = bpf_percpu_array_copy(map, key, value) |
| 877 | Else if map_type == BPF_MAP_TYPE_PERCPU_CGROUP_STORAGE Then |
| 878 | err = bpf_percpu_cgroup_storage_copy(map, key, value) |
| 879 | Else if map_type == BPF_MAP_TYPE_STACK_TRACE Then |
| 880 | err = bpf_stackmap_copy(map, key, value) |
| 881 | Else if IS_FD_ARRAY(map) || IS_FD_PROG_ARRAY(map) Then |
| 882 | err = ly called from syscall |
| 883 | Else if IS_FD_HASH(map) Then |
| 884 | err = ly called from syscall |
| 885 | Else if map_type == BPF_MAP_TYPE_REUSEPORT_SOCKARRAY Then |
| 886 | err = bpf_fd_reuseport_array_lookup_elem(map, key, value) |
| 887 | Else if map_type == BPF_MAP_TYPE_QUEUE || map_type == BPF_MAP_TYPE_STACK Then |
| 889 | err = map_peek_elem(map, value) |
| 890 | Else |
| 892 | If map_lookup_elem_sys_only Then ptr = map_lookup_elem_sys_only(map, key) |
| 894 | Else ptr = map_lookup_elem(map, key) |
| 898 | Else if Not ptr Then |
| 900 | Else |
| 901 | err = 0 |
| 902 | If flags & spin_lock-ed map_lookup/map_update Then copy_map_value_locked(map, value, ptr, true) |
| 905 | Else py everything but bpf_spin_lock |
| 908 | check_and_init_map_lock(map, value) |
| 913 | preempt_enable() |
| 915 | done : |
| 916 | If err Then Go to free_value |
| 920 | If copy_to_user(uvalue, value, value_size) != 0 Then Go to free_value |
| 923 | err = 0 |
| 925 | free_value : |
| 927 | free_key : |
| 929 | err_put : |
| 931 | Return err |
| Source code conversion tool public plug-in interface | X |
|---|---|
| Support c/c++/esqlc/java Oracle/Informix/Mysql Plug-in can realize: logical Report Code generation and batch code conversion |