Lines Matching refs:ex

64 	struct dev_exception_item *ex, *tmp, *new;  in dev_exceptions_copy()  local
68 list_for_each_entry(ex, orig, list) { in dev_exceptions_copy()
69 new = kmemdup(ex, sizeof(*ex), GFP_KERNEL); in dev_exceptions_copy()
78 list_for_each_entry_safe(ex, tmp, dest, list) { in dev_exceptions_copy()
79 list_del(&ex->list); in dev_exceptions_copy()
80 kfree(ex); in dev_exceptions_copy()
87 struct dev_exception_item *ex, *tmp; in dev_exceptions_move() local
91 list_for_each_entry_safe(ex, tmp, orig, list) { in dev_exceptions_move()
92 list_move_tail(&ex->list, dest); in dev_exceptions_move()
100 struct dev_exception_item *ex) in dev_exception_add() argument
106 excopy = kmemdup(ex, sizeof(*ex), GFP_KERNEL); in dev_exception_add()
111 if (walk->type != ex->type) in dev_exception_add()
113 if (walk->major != ex->major) in dev_exception_add()
115 if (walk->minor != ex->minor) in dev_exception_add()
118 walk->access |= ex->access; in dev_exception_add()
132 struct dev_exception_item *ex) in dev_exception_rm() argument
139 if (walk->type != ex->type) in dev_exception_rm()
141 if (walk->major != ex->major) in dev_exception_rm()
143 if (walk->minor != ex->minor) in dev_exception_rm()
146 walk->access &= ~ex->access; in dev_exception_rm()
156 struct dev_exception_item *ex, *tmp; in __dev_exception_clean() local
158 list_for_each_entry_safe(ex, tmp, &dev_cgroup->exceptions, list) { in __dev_exception_clean()
159 list_del_rcu(&ex->list); in __dev_exception_clean()
160 kfree_rcu(ex, rcu); in __dev_exception_clean()
284 struct dev_exception_item *ex; in devcgroup_seq_show() local
301 list_for_each_entry_rcu(ex, &devcgroup->exceptions, list) { in devcgroup_seq_show()
302 set_access(acc, ex->access); in devcgroup_seq_show()
303 set_majmin(maj, ex->major); in devcgroup_seq_show()
304 set_majmin(min, ex->minor); in devcgroup_seq_show()
305 seq_printf(m, "%c %s:%s %s\n", type_to_char(ex->type), in devcgroup_seq_show()
330 struct dev_exception_item *ex; in match_exception() local
332 list_for_each_entry_rcu(ex, exceptions, list) { in match_exception()
333 if ((type & DEVCG_DEV_BLOCK) && !(ex->type & DEVCG_DEV_BLOCK)) in match_exception()
335 if ((type & DEVCG_DEV_CHAR) && !(ex->type & DEVCG_DEV_CHAR)) in match_exception()
337 if (ex->major != ~0 && ex->major != major) in match_exception()
339 if (ex->minor != ~0 && ex->minor != minor) in match_exception()
342 if (access & (~ex->access)) in match_exception()
367 struct dev_exception_item *ex; in match_exception_partial() local
369 list_for_each_entry_rcu(ex, exceptions, list, in match_exception_partial()
371 if ((type & DEVCG_DEV_BLOCK) && !(ex->type & DEVCG_DEV_BLOCK)) in match_exception_partial()
373 if ((type & DEVCG_DEV_CHAR) && !(ex->type & DEVCG_DEV_CHAR)) in match_exception_partial()
379 if (ex->major != ~0 && major != ~0 && ex->major != major) in match_exception_partial()
381 if (ex->minor != ~0 && minor != ~0 && ex->minor != minor) in match_exception_partial()
388 if (!(access & ex->access)) in match_exception_partial()
463 struct dev_exception_item *ex) in parent_has_perm() argument
469 return verify_new_ex(parent, ex, childcg->behavior); in parent_has_perm()
484 struct dev_exception_item *ex) in parent_allows_removal() argument
499 return !match_exception_partial(&parent->exceptions, ex->type, in parent_allows_removal()
500 ex->major, ex->minor, ex->access); in parent_allows_removal()
531 struct dev_exception_item *ex; in revalidate_active_exceptions() local
535 ex = container_of(this, struct dev_exception_item, list); in revalidate_active_exceptions()
536 if (!parent_has_perm(devcg, ex)) in revalidate_active_exceptions()
537 dev_exception_rm(devcg, ex); in revalidate_active_exceptions()
549 struct dev_exception_item *ex) in propagate_exception() argument
576 rc = dev_exception_add(devcg, ex); in propagate_exception()
586 dev_exception_rm(devcg, ex); in propagate_exception()
616 struct dev_exception_item ex; in devcgroup_update_access() local
623 memset(&ex, 0, sizeof(ex)); in devcgroup_update_access()
670 ex.type = DEVCG_DEV_BLOCK; in devcgroup_update_access()
673 ex.type = DEVCG_DEV_CHAR; in devcgroup_update_access()
683 ex.major = ~0; in devcgroup_update_access()
693 rc = kstrtou32(temp, 10, &ex.major); in devcgroup_update_access()
705 ex.minor = ~0; in devcgroup_update_access()
715 rc = kstrtou32(temp, 10, &ex.minor); in devcgroup_update_access()
726 ex.access |= DEVCG_ACC_READ; in devcgroup_update_access()
729 ex.access |= DEVCG_ACC_WRITE; in devcgroup_update_access()
732 ex.access |= DEVCG_ACC_MKNOD; in devcgroup_update_access()
752 if (!parent_allows_removal(devcgroup, &ex)) in devcgroup_update_access()
754 dev_exception_rm(devcgroup, &ex); in devcgroup_update_access()
758 if (!parent_has_perm(devcgroup, &ex)) in devcgroup_update_access()
760 rc = dev_exception_add(devcgroup, &ex); in devcgroup_update_access()
769 dev_exception_rm(devcgroup, &ex); in devcgroup_update_access()
771 rc = dev_exception_add(devcgroup, &ex); in devcgroup_update_access()
776 rc = propagate_exception(devcgroup, &ex); in devcgroup_update_access()