Lines Matching defs: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;
391 iface = netlbl_unlhsh_search_iface(ifindex);
394 iface = rcu_dereference(netlbl_unlhsh_def);
396 if (iface == NULL) {
397 iface = netlbl_unlhsh_add_iface(ifindex);
398 if (iface == NULL) {
410 ret_val = netlbl_unlhsh_add_addr4(iface, addr4, mask4, secid);
423 ret_val = netlbl_unlhsh_add_addr6(iface, addr6, mask6, secid);
453 * @iface: interface entry
464 struct netlbl_unlhsh_iface *iface,
477 &iface->addr4_list);
487 dev = dev_get_by_index(net, iface->ifindex);
512 * @iface: interface entry
523 struct netlbl_unlhsh_iface *iface,
535 list_entry = netlbl_af6list_remove(addr, mask, &iface->addr6_list);
545 dev = dev_get_by_index(net, iface->ifindex);
569 * @iface: the interface entry
577 static void netlbl_unlhsh_condremove_iface(struct netlbl_unlhsh_iface *iface)
585 netlbl_af4list_foreach_rcu(iter4, &iface->addr4_list)
588 netlbl_af6list_foreach_rcu(iter6, &iface->addr6_list)
591 iface->valid = 0;
592 if (iface->ifindex > 0)
593 list_del_rcu(&iface->list);
598 call_rcu(&iface->rcu, netlbl_unlhsh_free_iface);
628 struct netlbl_unlhsh_iface *iface;
641 iface = netlbl_unlhsh_search_iface(dev->ifindex);
643 iface = rcu_dereference(netlbl_unlhsh_def);
644 if (iface == NULL) {
651 iface, addr, mask,
657 iface, addr, mask,
665 netlbl_unlhsh_condremove_iface(iface);
694 struct netlbl_unlhsh_iface *iface = NULL;
702 iface = netlbl_unlhsh_search_iface(dev->ifindex);
703 if (iface != NULL && iface->valid) {
704 iface->valid = 0;
705 list_del_rcu(&iface->list);
707 iface = NULL;
711 if (iface != NULL)
712 call_rcu(&iface->rcu, netlbl_unlhsh_free_iface);
1043 * @iface: the interface entry
1057 const struct netlbl_unlhsh_iface *iface,
1075 if (iface->ifindex > 0) {
1076 dev = dev_get_by_index(&init_net, iface->ifindex);
1161 struct netlbl_unlhsh_iface *iface;
1178 list_for_each_entry_rcu(iface, iter_list, list) {
1179 if (!iface->valid ||
1183 &iface->addr4_list) {
1188 iface,
1201 &iface->addr6_list) {
1206 iface,
1247 struct netlbl_unlhsh_iface *iface;
1259 iface = rcu_dereference(netlbl_unlhsh_def);
1260 if (iface == NULL || !iface->valid)
1263 netlbl_af4list_foreach_rcu(addr4, &iface->addr4_list) {
1267 iface,
1276 netlbl_af6list_foreach_rcu(addr6, &iface->addr6_list) {
1280 iface,
1454 struct netlbl_unlhsh_iface *iface;
1457 iface = netlbl_unlhsh_search_iface(skb->skb_iif);
1458 if (iface == NULL)
1459 iface = rcu_dereference(netlbl_unlhsh_def);
1460 if (iface == NULL || !iface->valid)
1479 &iface->addr4_list);
1492 &iface->addr6_list);