Lines Matching refs:entry
64 static void netlbl_domhsh_free_entry(struct rcu_head *entry) in netlbl_domhsh_free_entry() argument
74 ptr = container_of(entry, struct netlbl_dom_map, rcu); in netlbl_domhsh_free_entry()
173 struct netlbl_dom_map *entry; in netlbl_domhsh_search_def() local
175 entry = netlbl_domhsh_search(domain, family); in netlbl_domhsh_search_def()
176 if (entry != NULL) in netlbl_domhsh_search_def()
177 return entry; in netlbl_domhsh_search_def()
179 entry = netlbl_domhsh_rcu_deref(netlbl_domhsh_def_ipv4); in netlbl_domhsh_search_def()
180 if (entry != NULL && entry->valid) in netlbl_domhsh_search_def()
181 return entry; in netlbl_domhsh_search_def()
184 entry = netlbl_domhsh_rcu_deref(netlbl_domhsh_def_ipv6); in netlbl_domhsh_search_def()
185 if (entry != NULL && entry->valid) in netlbl_domhsh_search_def()
186 return entry; in netlbl_domhsh_search_def()
206 static void netlbl_domhsh_audit_add(struct netlbl_dom_map *entry, in netlbl_domhsh_audit_add() argument
220 entry->domain ? entry->domain : "(default)"); in netlbl_domhsh_audit_add()
238 type = entry->def.type; in netlbl_domhsh_audit_add()
239 cipsov4 = entry->def.cipso; in netlbl_domhsh_audit_add()
240 calipso = entry->def.calipso; in netlbl_domhsh_audit_add()
272 static int netlbl_domhsh_validate(const struct netlbl_dom_map *entry) in netlbl_domhsh_validate() argument
281 if (entry == NULL) in netlbl_domhsh_validate()
284 if (entry->family != AF_INET && entry->family != AF_INET6 && in netlbl_domhsh_validate()
285 (entry->family != AF_UNSPEC || in netlbl_domhsh_validate()
286 entry->def.type != NETLBL_NLTYPE_UNLABELED)) in netlbl_domhsh_validate()
289 switch (entry->def.type) { in netlbl_domhsh_validate()
291 if (entry->def.cipso != NULL || entry->def.calipso != NULL || in netlbl_domhsh_validate()
292 entry->def.addrsel != NULL) in netlbl_domhsh_validate()
296 if (entry->family != AF_INET || in netlbl_domhsh_validate()
297 entry->def.cipso == NULL) in netlbl_domhsh_validate()
301 if (entry->family != AF_INET6 || in netlbl_domhsh_validate()
302 entry->def.calipso == NULL) in netlbl_domhsh_validate()
306 netlbl_af4list_foreach(iter4, &entry->def.addrsel->list4) { in netlbl_domhsh_validate()
322 netlbl_af6list_foreach(iter6, &entry->def.addrsel->list6) { in netlbl_domhsh_validate()
403 int netlbl_domhsh_add(struct netlbl_dom_map *entry, in netlbl_domhsh_add() argument
415 ret_val = netlbl_domhsh_validate(entry); in netlbl_domhsh_add()
425 if (entry->domain != NULL) in netlbl_domhsh_add()
426 entry_old = netlbl_domhsh_search(entry->domain, entry->family); in netlbl_domhsh_add()
428 entry_old = netlbl_domhsh_search_def(entry->domain, in netlbl_domhsh_add()
429 entry->family); in netlbl_domhsh_add()
431 entry->valid = 1; in netlbl_domhsh_add()
433 if (entry->domain != NULL) { in netlbl_domhsh_add()
434 u32 bkt = netlbl_domhsh_hash(entry->domain); in netlbl_domhsh_add()
435 list_add_tail_rcu(&entry->list, in netlbl_domhsh_add()
438 INIT_LIST_HEAD(&entry->list); in netlbl_domhsh_add()
439 switch (entry->family) { in netlbl_domhsh_add()
442 entry); in netlbl_domhsh_add()
446 entry); in netlbl_domhsh_add()
449 if (entry->def.type != in netlbl_domhsh_add()
462 entry->family = AF_INET; in netlbl_domhsh_add()
464 entry); in netlbl_domhsh_add()
476 if (entry->def.type == NETLBL_NLTYPE_ADDRSELECT) { in netlbl_domhsh_add()
478 &entry->def.addrsel->list4) in netlbl_domhsh_add()
479 netlbl_domhsh_audit_add(entry, iter4, NULL, in netlbl_domhsh_add()
483 &entry->def.addrsel->list6) in netlbl_domhsh_add()
484 netlbl_domhsh_audit_add(entry, NULL, iter6, in netlbl_domhsh_add()
488 netlbl_domhsh_audit_add(entry, NULL, NULL, in netlbl_domhsh_add()
491 entry->def.type == NETLBL_NLTYPE_ADDRSELECT) { in netlbl_domhsh_add()
500 netlbl_af4list_foreach_rcu(iter4, &entry->def.addrsel->list4) in netlbl_domhsh_add()
508 netlbl_af6list_foreach_rcu(iter6, &entry->def.addrsel->list6) in netlbl_domhsh_add()
518 &entry->def.addrsel->list4) { in netlbl_domhsh_add()
529 &entry->def.addrsel->list6) { in netlbl_domhsh_add()
559 int netlbl_domhsh_add_default(struct netlbl_dom_map *entry, in netlbl_domhsh_add_default() argument
562 return netlbl_domhsh_add(entry, audit_info); in netlbl_domhsh_add_default()
577 int netlbl_domhsh_remove_entry(struct netlbl_dom_map *entry, in netlbl_domhsh_remove_entry() argument
583 if (entry == NULL) in netlbl_domhsh_remove_entry()
587 if (entry->valid) { in netlbl_domhsh_remove_entry()
588 entry->valid = 0; in netlbl_domhsh_remove_entry()
589 if (entry == rcu_dereference(netlbl_domhsh_def_ipv4)) in netlbl_domhsh_remove_entry()
591 else if (entry == rcu_dereference(netlbl_domhsh_def_ipv6)) in netlbl_domhsh_remove_entry()
594 list_del_rcu(&entry->list); in netlbl_domhsh_remove_entry()
603 entry->domain ? entry->domain : "(default)", in netlbl_domhsh_remove_entry()
616 switch (entry->def.type) { in netlbl_domhsh_remove_entry()
619 &entry->def.addrsel->list4) { in netlbl_domhsh_remove_entry()
625 &entry->def.addrsel->list6) { in netlbl_domhsh_remove_entry()
632 cipso_v4_doi_putdef(entry->def.cipso); in netlbl_domhsh_remove_entry()
636 calipso_doi_putdef(entry->def.calipso); in netlbl_domhsh_remove_entry()
640 call_rcu(&entry->rcu, netlbl_domhsh_free_entry); in netlbl_domhsh_remove_entry()
670 struct netlbl_domaddr4_map *entry; in netlbl_domhsh_remove_af4() local
704 entry = netlbl_domhsh_addr4_entry(entry_addr); in netlbl_domhsh_remove_af4()
705 cipso_v4_doi_putdef(entry->def.cipso); in netlbl_domhsh_remove_af4()
706 kfree(entry); in netlbl_domhsh_remove_af4()
737 struct netlbl_domaddr6_map *entry; in netlbl_domhsh_remove_af6() local
769 entry = netlbl_domhsh_addr6_entry(entry_addr); in netlbl_domhsh_remove_af6()
770 calipso_doi_putdef(entry->def.calipso); in netlbl_domhsh_remove_af6()
771 kfree(entry); in netlbl_domhsh_remove_af6()
797 struct netlbl_dom_map *entry; in netlbl_domhsh_remove() local
803 entry = netlbl_domhsh_search(domain, AF_INET); in netlbl_domhsh_remove()
805 entry = netlbl_domhsh_search_def(domain, AF_INET); in netlbl_domhsh_remove()
806 ret_val = netlbl_domhsh_remove_entry(entry, audit_info); in netlbl_domhsh_remove()
814 entry = netlbl_domhsh_search(domain, AF_INET6); in netlbl_domhsh_remove()
816 entry = netlbl_domhsh_search_def(domain, AF_INET6); in netlbl_domhsh_remove()
817 ret_val2 = netlbl_domhsh_remove_entry(entry, audit_info); in netlbl_domhsh_remove()
940 int (*callback) (struct netlbl_dom_map *entry, void *arg), in netlbl_domhsh_walk()