Lines Matching refs:vmap
106 struct vrf_map vmap; member
179 return &nn_vrf->vmap; in netns_vrf_map()
225 static struct vrf_map_elem *vrf_map_lookup_elem(struct vrf_map *vmap, in vrf_map_lookup_elem() argument
232 hash_for_each_possible(vmap->ht, me, hnode, key) { in vrf_map_lookup_elem()
240 static void vrf_map_add_elem(struct vrf_map *vmap, struct vrf_map_elem *me) in vrf_map_add_elem() argument
246 hash_add(vmap->ht, &me->hnode, key); in vrf_map_add_elem()
254 static void vrf_map_lock(struct vrf_map *vmap) __acquires(&vmap->vmap_lock) in vrf_map_lock() argument
256 spin_lock(&vmap->vmap_lock); in vrf_map_lock()
259 static void vrf_map_unlock(struct vrf_map *vmap) __releases(&vmap->vmap_lock) in vrf_map_unlock() argument
261 spin_unlock(&vmap->vmap_lock); in vrf_map_unlock()
268 struct vrf_map *vmap = netns_vrf_map_by_dev(dev); in vrf_map_register_dev() local
285 vrf_map_lock(vmap); in vrf_map_register_dev()
287 me = vrf_map_lookup_elem(vmap, table_id); in vrf_map_register_dev()
290 vrf_map_add_elem(vmap, me); in vrf_map_register_dev()
298 if (vmap->strict_mode) { in vrf_map_register_dev()
308 ++vmap->shared_tables; in vrf_map_register_dev()
315 vrf_map_unlock(vmap); in vrf_map_register_dev()
327 struct vrf_map *vmap = netns_vrf_map_by_dev(dev); in vrf_map_unregister_dev() local
333 vrf_map_lock(vmap); in vrf_map_unregister_dev()
335 me = vrf_map_lookup_elem(vmap, table_id); in vrf_map_unregister_dev()
343 --vmap->shared_tables; in vrf_map_unregister_dev()
352 vrf_map_unlock(vmap); in vrf_map_unregister_dev()
358 struct vrf_map *vmap = netns_vrf_map(net); in vrf_ifindex_lookup_by_table_id() local
362 vrf_map_lock(vmap); in vrf_ifindex_lookup_by_table_id()
364 if (!vmap->strict_mode) { in vrf_ifindex_lookup_by_table_id()
369 me = vrf_map_lookup_elem(vmap, table_id); in vrf_ifindex_lookup_by_table_id()
378 vrf_map_unlock(vmap); in vrf_ifindex_lookup_by_table_id()
1809 static int vrf_map_init(struct vrf_map *vmap) in vrf_map_init() argument
1811 spin_lock_init(&vmap->vmap_lock); in vrf_map_init()
1812 hash_init(vmap->ht); in vrf_map_init()
1814 vmap->strict_mode = false; in vrf_map_init()
1820 static bool vrf_strict_mode(struct vrf_map *vmap) in vrf_strict_mode() argument
1824 vrf_map_lock(vmap); in vrf_strict_mode()
1825 strict_mode = vmap->strict_mode; in vrf_strict_mode()
1826 vrf_map_unlock(vmap); in vrf_strict_mode()
1831 static int vrf_strict_mode_change(struct vrf_map *vmap, bool new_mode) in vrf_strict_mode_change() argument
1836 vrf_map_lock(vmap); in vrf_strict_mode_change()
1838 cur_mode = &vmap->strict_mode; in vrf_strict_mode_change()
1846 if (vmap->shared_tables) { in vrf_strict_mode_change()
1861 vrf_map_unlock(vmap); in vrf_strict_mode_change()
1870 struct vrf_map *vmap = netns_vrf_map(net); in vrf_shared_table_handler() local
1883 proc_strict_mode = vrf_strict_mode(vmap); in vrf_shared_table_handler()
1888 ret = vrf_strict_mode_change(vmap, (bool)proc_strict_mode); in vrf_shared_table_handler()
1952 vrf_map_init(&nn_vrf->vmap); in vrf_netns_init()