Function report |
Source Code:kernel\bpf\hashtab.c |
Create Date:2022-07-28 13:10:11 |
Last Modify:2022-05-23 09:15:29 | Copyright©Brick |
home page | Tree |
Annotation kernel can get tool activity | Download SCCT | Chinese |
Name:__htab_lru_percpu_map_update_elem
Proto:static int __htab_lru_percpu_map_update_elem(struct bpf_map *map, void *key, void *value, u64 map_flags, bool onallcpus)
Type:int
Parameter:
Type | Parameter | Name |
---|---|---|
struct bpf_map * | map | |
void * | key | |
void * | value | |
u64 | map_flags | |
bool | onallcpus |
1040 | If Value for the false possibility is greater at compile time(map_flags > update existing element ) Then Return -EINVAL |
1044 | WARN_ON_ONCE(!_read_lock_held() - might we be in RCU read-side critical section?* If CONFIG_DEBUG_LOCK_ALLOC is selected, returns nonzero iff in an RCU* read-side critical section) |
1048 | hash = htab_map_hash(key, key_size, hashrnd) |
1050 | b = __select_bucket(htab, hash) |
1058 | If map_flags != update existing element Then |
1065 | raw_spin_lock_irqsave( & lock, flags) |
1069 | ret = check_flags(htab, l_old, map_flags) |
1073 | If l_old Then |
1074 | bpf_lru_node_set_ref( & lru_node) |
1077 | pcpu_copy_value(htab, htab_elem_get_ptr(l_old, key_size), value, onallcpus) |
1079 | Else |
1080 | pcpu_copy_value(htab, htab_elem_get_ptr(l_new, key_size), value, onallcpus) |
1083 | l_new = NULL |
1085 | ret = 0 |
1086 | err : |
1087 | raw_spin_unlock_irqrestore( & lock, flags) |
1088 | If l_new Then bpf_lru_push_free( & lru, & lru_node) |
1090 | Return ret |
Name | Describe |
---|---|
htab_lru_percpu_map_update_elem | |
bpf_percpu_hash_update |
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 |