Lines Matching refs:stab

29 	struct bpf_stab *stab;  in sock_map_alloc()  local
42 stab = kzalloc(sizeof(*stab), GFP_USER); in sock_map_alloc()
43 if (!stab) in sock_map_alloc()
46 bpf_map_init_from_attr(&stab->map, attr); in sock_map_alloc()
47 raw_spin_lock_init(&stab->lock); in sock_map_alloc()
50 cost = (u64) stab->map.max_entries * sizeof(struct sock *); in sock_map_alloc()
51 err = bpf_map_charge_init(&stab->map.memory, cost); in sock_map_alloc()
55 stab->sks = bpf_map_area_alloc(stab->map.max_entries * in sock_map_alloc()
57 stab->map.numa_node); in sock_map_alloc()
58 if (stab->sks) in sock_map_alloc()
59 return &stab->map; in sock_map_alloc()
61 bpf_map_charge_finish(&stab->map.memory); in sock_map_alloc()
63 kfree(stab); in sock_map_alloc()
158 struct bpf_stab *stab = container_of(map, struct bpf_stab, in sock_map_del_link() local
160 if (psock->parser.enabled && stab->progs.skb_parser) in sock_map_del_link()
162 if (psock->parser.enabled && stab->progs.skb_verdict) in sock_map_del_link()
347 struct bpf_stab *stab = container_of(map, struct bpf_stab, map); in sock_map_free() local
355 for (i = 0; i < stab->map.max_entries; i++) { in sock_map_free()
356 struct sock **psk = &stab->sks[i]; in sock_map_free()
372 bpf_map_area_free(stab->sks); in sock_map_free()
373 kfree(stab); in sock_map_free()
383 struct bpf_stab *stab = container_of(map, struct bpf_stab, map); in __sock_map_lookup_elem() local
389 return READ_ONCE(stab->sks[key]); in __sock_map_lookup_elem()
419 static int __sock_map_delete(struct bpf_stab *stab, struct sock *sk_test, in __sock_map_delete() argument
425 raw_spin_lock_bh(&stab->lock); in __sock_map_delete()
435 raw_spin_unlock_bh(&stab->lock); in __sock_map_delete()
442 struct bpf_stab *stab = container_of(map, struct bpf_stab, map); in sock_map_delete_from_link() local
444 __sock_map_delete(stab, sk, link_raw); in sock_map_delete_from_link()
449 struct bpf_stab *stab = container_of(map, struct bpf_stab, map); in sock_map_delete_elem() local
456 psk = &stab->sks[i]; in sock_map_delete_elem()
457 return __sock_map_delete(stab, NULL, psk); in sock_map_delete_elem()
462 struct bpf_stab *stab = container_of(map, struct bpf_stab, map); in sock_map_get_next_key() local
466 if (i == stab->map.max_entries - 1) in sock_map_get_next_key()
468 if (i >= stab->map.max_entries) in sock_map_get_next_key()
480 struct bpf_stab *stab = container_of(map, struct bpf_stab, map); in sock_map_update_common() local
501 ret = sock_map_link(map, &stab->progs, sk); in sock_map_update_common()
510 raw_spin_lock_bh(&stab->lock); in sock_map_update_common()
511 osk = stab->sks[idx]; in sock_map_update_common()
520 sock_map_add_link(psock, link, map, &stab->sks[idx]); in sock_map_update_common()
521 stab->sks[idx] = sk; in sock_map_update_common()
523 sock_map_unref(osk, &stab->sks[idx]); in sock_map_update_common()
524 raw_spin_unlock_bh(&stab->lock); in sock_map_update_common()
527 raw_spin_unlock_bh(&stab->lock); in sock_map_update_common()