Lines Matching refs:iface

149 	struct netlbl_unlhsh_iface *iface;
157 iface = container_of(entry, struct netlbl_unlhsh_iface, rcu);
162 netlbl_af4list_foreach_safe(iter4, tmp4, &iface->addr4_list) {
167 netlbl_af6list_foreach_safe(iter6, tmp6, &iface->addr6_list) {
172 kfree(iface);
220 * @iface: the associated interface entry
227 * interface entry specified by @iface. On success zero is returned, otherwise
231 static int netlbl_unlhsh_add_addr4(struct netlbl_unlhsh_iface *iface,
249 ret_val = netlbl_af4list_add(&entry->list, &iface->addr4_list);
260 * @iface: the associated interface entry
267 * interface entry specified by @iface. On success zero is returned, otherwise
271 static int netlbl_unlhsh_add_addr6(struct netlbl_unlhsh_iface *iface,
293 ret_val = netlbl_af6list_add(&entry->list, &iface->addr6_list);
315 struct netlbl_unlhsh_iface *iface;
317 iface = kzalloc(sizeof(*iface), GFP_ATOMIC);
318 if (iface == NULL)
321 iface->ifindex = ifindex;
322 INIT_LIST_HEAD(&iface->addr4_list);
323 INIT_LIST_HEAD(&iface->addr6_list);
324 iface->valid = 1;
331 list_add_tail_rcu(&iface->list,
334 INIT_LIST_HEAD(&iface->list);
337 rcu_assign_pointer(netlbl_unlhsh_def, iface);
341 return iface;
345 kfree(iface);
375 struct netlbl_unlhsh_iface *iface;
392 iface = netlbl_unlhsh_search_iface(ifindex);
395 iface = rcu_dereference(netlbl_unlhsh_def);
397 if (iface == NULL) {
398 iface = netlbl_unlhsh_add_iface(ifindex);
399 if (iface == NULL) {
411 ret_val = netlbl_unlhsh_add_addr4(iface, addr4, mask4, secid);
424 ret_val = netlbl_unlhsh_add_addr6(iface, addr6, mask6, secid);
456 * @iface: interface entry
467 struct netlbl_unlhsh_iface *iface,
481 &iface->addr4_list);
491 dev = dev_get_by_index(net, iface->ifindex);
518 * @iface: interface entry
529 struct netlbl_unlhsh_iface *iface,
542 list_entry = netlbl_af6list_remove(addr, mask, &iface->addr6_list);
552 dev = dev_get_by_index(net, iface->ifindex);
578 * @iface: the interface entry
586 static void netlbl_unlhsh_condremove_iface(struct netlbl_unlhsh_iface *iface)
594 netlbl_af4list_foreach_rcu(iter4, &iface->addr4_list)
597 netlbl_af6list_foreach_rcu(iter6, &iface->addr6_list)
600 iface->valid = 0;
601 if (iface->ifindex > 0)
602 list_del_rcu(&iface->list);
607 call_rcu(&iface->rcu, netlbl_unlhsh_free_iface);
637 struct netlbl_unlhsh_iface *iface;
650 iface = netlbl_unlhsh_search_iface(dev->ifindex);
652 iface = rcu_dereference(netlbl_unlhsh_def);
653 if (iface == NULL) {
660 iface, addr, mask,
666 iface, addr, mask,
674 netlbl_unlhsh_condremove_iface(iface);
703 struct netlbl_unlhsh_iface *iface = NULL;
711 iface = netlbl_unlhsh_search_iface(dev->ifindex);
712 if (iface != NULL && iface->valid) {
713 iface->valid = 0;
714 list_del_rcu(&iface->list);
716 iface = NULL;
720 if (iface != NULL)
721 call_rcu(&iface->rcu, netlbl_unlhsh_free_iface);
1052 * @iface: the interface entry
1066 const struct netlbl_unlhsh_iface *iface,
1085 if (iface->ifindex > 0) {
1086 dev = dev_get_by_index(&init_net, iface->ifindex);
1171 struct netlbl_unlhsh_iface *iface;
1188 list_for_each_entry_rcu(iface, iter_list, list) {
1189 if (!iface->valid ||
1193 &iface->addr4_list) {
1198 iface,
1211 &iface->addr6_list) {
1216 iface,
1257 struct netlbl_unlhsh_iface *iface;
1269 iface = rcu_dereference(netlbl_unlhsh_def);
1270 if (iface == NULL || !iface->valid)
1273 netlbl_af4list_foreach_rcu(addr4, &iface->addr4_list) {
1277 iface,
1286 netlbl_af6list_foreach_rcu(addr6, &iface->addr6_list) {
1290 iface,
1463 struct netlbl_unlhsh_iface *iface;
1466 iface = netlbl_unlhsh_search_iface(skb->skb_iif);
1467 if (iface == NULL)
1468 iface = rcu_dereference(netlbl_unlhsh_def);
1469 if (iface == NULL || !iface->valid)
1488 &iface->addr4_list);
1501 &iface->addr6_list);