Function report |
Source Code:kernel\bpf\xskmap.c |
Create Date:2022-07-28 13:24:51 |
| Last Modify:2020-03-12 14:18:49 | Copyright©Brick |
| home page | Tree |
| Annotation kernel can get tool activity | Download SCCT | Chinese |
Name:xsk_map_update_elem
Proto:static int xsk_map_update_elem(struct bpf_map *map, void *key, void *value, u64 map_flags)
Type:int
Parameter:
| Type | Parameter | Name |
|---|---|---|
| struct bpf_map * | map | |
| void * | key | |
| void * | value | |
| u64 | map_flags |
| 182 | If Value for the false possibility is greater at compile time(map_flags > update existing element ) Then Return -EINVAL |
| 184 | If Value for the false possibility is greater at compile time(i >= max_entries) Then Return -E2BIG |
| 187 | sock = sockfd_lookup(fd, & err) |
| 192 | sockfd_put(sock) |
| 193 | Return -EOPNOTSUPP |
| 198 | If Not xsk_is_setup_for_bpf_map(xs) Then |
| 199 | sockfd_put(sock) |
| 200 | Return -EOPNOTSUPP |
| 204 | node = xsk_map_node_alloc(m, map_entry) |
| 206 | sockfd_put(sock) |
| 210 | spin_lock_bh( & Synchronize map updates ) |
| 215 | Else if old_xs && map_flags == create new element if it didn't exist Then |
| 218 | Else if Not old_xs && map_flags == update existing element Then |
| 222 | xsk_map_sock_add(xs, node) |
| 223 | WRITE_ONCE( * map_entry, xs) |
| 224 | If old_xs Then xsk_map_sock_delete(old_xs, map_entry) |
| 226 | spin_unlock_bh( & Synchronize map updates ) |
| 227 | sockfd_put(sock) |
| 228 | Return 0 |
| 230 | out : |
| 231 | spin_unlock_bh( & Synchronize map updates ) |
| 232 | sockfd_put(sock) |
| 233 | xsk_map_node_free(node) |
| 234 | 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 |