Lines Matching refs:tnode

128 		struct key_vector __rcu *tnode[0];  member
132 struct tnode { struct
141 #define TNODE_SIZE(n) offsetof(struct tnode, kv[0].tnode[n]) argument
187 static inline struct tnode *tn_info(struct key_vector *kv) in tn_info()
189 return container_of(kv, struct tnode, kv[0]); in tn_info()
194 #define get_child(tn, i) rtnl_dereference((tn)->tnode[i])
198 #define get_child_rcu(tn, i) rcu_dereference_rtnl((tn)->tnode[i])
309 struct tnode *n = container_of(head, struct tnode, rcu); in __node_free_rcu()
319 static struct tnode *tnode_alloc(int bits) in tnode_alloc()
355 struct tnode *kv; in leaf_new()
379 struct tnode *tnode; in tnode_new() local
384 tnode = tnode_alloc(bits); in tnode_new()
385 if (!tnode) in tnode_new()
388 pr_debug("AT %p s=%zu %zu\n", tnode, TNODE_SIZE(0), in tnode_new()
392 tnode->full_children = 1; in tnode_new()
394 tnode->empty_children = 1ul << bits; in tnode_new()
396 tn = tnode->kv; in tnode_new()
442 rcu_assign_pointer(tn->tnode[i], n); in put_child()
471 rcu_assign_pointer(tp->tnode[0], n); in put_child_root()
497 tn = container_of(head, struct tnode, rcu)->kv; in tnode_free()
1462 struct key_vector __rcu **cptr = n->tnode; in fib_table_lookup()
1515 cptr = &pn->tnode[cindex]; in fib_table_lookup()
2400 struct key_vector *tnode; member
2408 struct key_vector *pn = iter->tnode; in fib_trie_get_next()
2412 iter->tnode, iter->index, iter->depth); in fib_trie_get_next()
2422 iter->tnode = pn; in fib_trie_get_next()
2426 iter->tnode = n; in fib_trie_get_next()
2442 iter->tnode = pn; in fib_trie_get_next()
2457 n = rcu_dereference(pn->tnode[0]); in fib_trie_get_first()
2462 iter->tnode = n; in fib_trie_get_first()
2466 iter->tnode = pn; in fib_trie_get_first()
2800 struct key_vector *tnode; member
2808 struct key_vector *l, **tp = &iter->tnode; in fib_route_get_idx()
2854 iter->tnode = t->kv; in fib_route_seq_start()
2875 l = leaf_walk_rcu(&iter->tnode, key); in fib_route_seq_next()