/linux-6.6.21/kernel/ |
D | ucount.c | 11 struct ucounts init_ucounts = { 131 static struct ucounts *find_ucounts(struct user_namespace *ns, kuid_t uid, struct hlist_head *hashe… in find_ucounts() 133 struct ucounts *ucounts; in find_ucounts() local 135 hlist_for_each_entry(ucounts, hashent, node) { in find_ucounts() 136 if (uid_eq(ucounts->uid, uid) && (ucounts->ns == ns)) in find_ucounts() 137 return ucounts; in find_ucounts() 142 static void hlist_add_ucounts(struct ucounts *ucounts) in hlist_add_ucounts() argument 144 struct hlist_head *hashent = ucounts_hashentry(ucounts->ns, ucounts->uid); in hlist_add_ucounts() 146 hlist_add_head(&ucounts->node, hashent); in hlist_add_ucounts() 150 static inline bool get_ucounts_or_wrap(struct ucounts *ucounts) in get_ucounts_or_wrap() argument [all …]
|
D | utsname.c | 20 static struct ucounts *inc_uts_namespaces(struct user_namespace *ns) in inc_uts_namespaces() 25 static void dec_uts_namespaces(struct ucounts *ucounts) in dec_uts_namespaces() argument 27 dec_ucount(ucounts, UCOUNT_UTS_NAMESPACES); in dec_uts_namespaces() 49 struct ucounts *ucounts; in clone_uts_ns() local 53 ucounts = inc_uts_namespaces(user_ns); in clone_uts_ns() 54 if (!ucounts) in clone_uts_ns() 66 ns->ucounts = ucounts; in clone_uts_ns() 78 dec_uts_namespaces(ucounts); in clone_uts_ns() 108 dec_uts_namespaces(ns->ucounts); in free_uts_ns()
|
D | pid_namespace.c | 62 static struct ucounts *inc_pid_namespaces(struct user_namespace *ns) in inc_pid_namespaces() 67 static void dec_pid_namespaces(struct ucounts *ucounts) in dec_pid_namespaces() argument 69 dec_ucount(ucounts, UCOUNT_PID_NAMESPACES); in dec_pid_namespaces() 77 struct ucounts *ucounts; in create_pid_namespace() local 87 ucounts = inc_pid_namespaces(user_ns); in create_pid_namespace() 88 if (!ucounts) in create_pid_namespace() 111 ns->ucounts = ucounts; in create_pid_namespace() 122 dec_pid_namespaces(ucounts); in create_pid_namespace() 131 dec_pid_namespaces(ns->ucounts); in delayed_free_pidns()
|
D | cred.c | 62 .ucounts = &init_ucounts, 86 if (cred->ucounts) in put_cred_rcu() 87 put_ucounts(cred->ucounts); in put_cred_rcu() 233 new->ucounts = get_ucounts(new->ucounts); in prepare_creds() 234 if (!new->ucounts) in prepare_creds() 433 inc_rlimit_ucounts(new->ucounts, UCOUNT_RLIMIT_NPROC, 1); in commit_creds() 437 dec_rlimit_ucounts(old->ucounts, UCOUNT_RLIMIT_NPROC, 1); in commit_creds() 582 struct ucounts *new_ucounts, *old_ucounts = new->ucounts; in set_cred_ucounts() 594 new->ucounts = new_ucounts; in set_cred_ucounts() 660 new->ucounts = get_ucounts(new->ucounts); in prepare_kernel_cred() [all …]
|
D | user_namespace.c | 33 static struct ucounts *inc_user_namespaces(struct user_namespace *ns, kuid_t uid) in inc_user_namespaces() 38 static void dec_user_namespaces(struct ucounts *ucounts) in dec_user_namespaces() argument 40 return dec_ucount(ucounts, UCOUNT_USER_NAMESPACES); in dec_user_namespaces() 87 struct ucounts *ucounts; in create_user_ns() local 94 ucounts = inc_user_namespaces(parent_ns, owner); in create_user_ns() 95 if (!ucounts) in create_user_ns() 146 ns->ucounts = ucounts; in create_user_ns() 171 dec_user_namespaces(ucounts); in create_user_ns() 202 struct ucounts *ucounts = ns->ucounts; in free_user_ns() local 220 dec_user_namespaces(ucounts); in free_user_ns()
|
/linux-6.6.21/include/linux/ |
D | user_namespace.h | 38 struct ucounts; 102 struct ucounts *ucounts; member 107 struct ucounts { struct 117 extern struct ucounts init_ucounts; argument 121 struct ucounts *inc_ucount(struct user_namespace *ns, kuid_t uid, enum ucount_type type); 122 void dec_ucount(struct ucounts *ucounts, enum ucount_type type); 123 struct ucounts *alloc_ucounts(struct user_namespace *ns, kuid_t uid); 124 struct ucounts * __must_check get_ucounts(struct ucounts *ucounts); 125 void put_ucounts(struct ucounts *ucounts); 127 static inline long get_rlimit_value(struct ucounts *ucounts, enum rlimit_type type) in get_rlimit_value() argument [all …]
|
D | signal_types.h | 16 struct ucounts; 26 struct ucounts *ucounts; member
|
D | cred.h | 139 struct ucounts *ucounts; member 323 #define task_ucounts(task) (task_cred_xxx((task), ucounts)) 340 #define current_ucounts() (current_cred_xxx(ucounts))
|
D | utsname.h | 27 struct ucounts *ucounts; member
|
D | pid_namespace.h | 38 struct ucounts *ucounts; member
|
D | ipc_namespace.h | 76 struct ucounts *ucounts; member
|
D | time_namespace.h | 21 struct ucounts *ucounts; member
|
D | shmem_fs.h | 94 extern int shmem_lock(struct file *file, int lock, struct ucounts *ucounts);
|
D | fsnotify_backend.h | 241 struct ucounts *ucounts; member 253 struct ucounts *ucounts; member
|
/linux-6.6.21/fs/notify/inotify/ |
D | inotify.h | 55 static inline void dec_inotify_instances(struct ucounts *ucounts) in dec_inotify_instances() argument 57 dec_ucount(ucounts, UCOUNT_INOTIFY_INSTANCES); in dec_inotify_instances() 60 static inline struct ucounts *inc_inotify_watches(struct ucounts *ucounts) in inc_inotify_watches() argument 62 return inc_ucount(ucounts->ns, ucounts->uid, UCOUNT_INOTIFY_WATCHES); in inc_inotify_watches() 65 static inline void dec_inotify_watches(struct ucounts *ucounts) in dec_inotify_watches() argument 67 dec_ucount(ucounts, UCOUNT_INOTIFY_WATCHES); in dec_inotify_watches()
|
D | inotify_fsnotify.c | 183 if (group->inotify_data.ucounts) in inotify_free_group_priv() 184 dec_inotify_instances(group->inotify_data.ucounts); in inotify_free_group_priv()
|
D | inotify_user.c | 534 dec_inotify_watches(group->inotify_data.ucounts); in inotify_ignored_and_remove_idr() 614 if (!inc_inotify_watches(group->inotify_data.ucounts)) { in inotify_new_watch() 681 group->inotify_data.ucounts = inc_ucount(current_user_ns(), in inotify_new_group() 685 if (!group->inotify_data.ucounts) { in inotify_new_group()
|
/linux-6.6.21/kernel/cgroup/ |
D | namespace.c | 12 static struct ucounts *inc_cgroup_namespaces(struct user_namespace *ns) in inc_cgroup_namespaces() 17 static void dec_cgroup_namespaces(struct ucounts *ucounts) in dec_cgroup_namespaces() argument 19 dec_ucount(ucounts, UCOUNT_CGROUP_NAMESPACES); in dec_cgroup_namespaces() 43 dec_cgroup_namespaces(ns->ucounts); in free_cgroup_ns() 55 struct ucounts *ucounts; in copy_cgroup_ns() local 69 ucounts = inc_cgroup_namespaces(user_ns); in copy_cgroup_ns() 70 if (!ucounts) in copy_cgroup_ns() 82 dec_cgroup_namespaces(ucounts); in copy_cgroup_ns() 87 new_ns->ucounts = ucounts; in copy_cgroup_ns()
|
/linux-6.6.21/ipc/ |
D | namespace.c | 28 static struct ucounts *inc_ipc_namespaces(struct user_namespace *ns) in inc_ipc_namespaces() 33 static void dec_ipc_namespaces(struct ucounts *ucounts) in dec_ipc_namespaces() argument 35 dec_ucount(ucounts, UCOUNT_IPC_NAMESPACES); in dec_ipc_namespaces() 42 struct ucounts *ucounts; in create_ipc_ns() local 47 ucounts = inc_ipc_namespaces(user_ns); in create_ipc_ns() 48 if (!ucounts) { in create_ipc_ns() 71 ns->ucounts = ucounts; in create_ipc_ns() 102 dec_ipc_namespaces(ucounts); in create_ipc_ns() 160 dec_ipc_namespaces(ns->ucounts); in free_ipc_ns()
|
D | mqueue.c | 148 struct ucounts *ucounts; /* user who created, for accounting */ member 322 info->ucounts = NULL; /* set when all is ok */ in mqueue_get_inode() 372 info->ucounts = get_ucounts(current_ucounts()); in mqueue_get_inode() 373 if (info->ucounts) { in mqueue_get_inode() 377 msgqueue = inc_rlimit_ucounts(info->ucounts, UCOUNT_RLIMIT_MSGQUEUE, mq_bytes); in mqueue_get_inode() 379 dec_rlimit_ucounts(info->ucounts, UCOUNT_RLIMIT_MSGQUEUE, mq_bytes); in mqueue_get_inode() 381 put_ucounts(info->ucounts); in mqueue_get_inode() 382 info->ucounts = NULL; in mqueue_get_inode() 537 if (info->ucounts) { in mqueue_evict_inode() 549 dec_rlimit_ucounts(info->ucounts, UCOUNT_RLIMIT_MSGQUEUE, mq_bytes); in mqueue_evict_inode() [all …]
|
/linux-6.6.21/kernel/time/ |
D | namespace.c | 59 static struct ucounts *inc_time_namespaces(struct user_namespace *ns) in inc_time_namespaces() 64 static void dec_time_namespaces(struct ucounts *ucounts) in dec_time_namespaces() argument 66 dec_ucount(ucounts, UCOUNT_TIME_NAMESPACES); in dec_time_namespaces() 82 struct ucounts *ucounts; in clone_time_ns() local 86 ucounts = inc_time_namespaces(user_ns); in clone_time_ns() 87 if (!ucounts) in clone_time_ns() 105 ns->ucounts = ucounts; in clone_time_ns() 117 dec_time_namespaces(ucounts); in clone_time_ns() 249 dec_time_namespaces(ns->ucounts); in free_time_ns()
|
/linux-6.6.21/mm/ |
D | mlock.c | 751 int user_shm_lock(size_t size, struct ucounts *ucounts) in user_shm_lock() argument 762 memlock = inc_rlimit_ucounts(ucounts, UCOUNT_RLIMIT_MEMLOCK, locked); in user_shm_lock() 765 dec_rlimit_ucounts(ucounts, UCOUNT_RLIMIT_MEMLOCK, locked); in user_shm_lock() 768 if (!get_ucounts(ucounts)) { in user_shm_lock() 769 dec_rlimit_ucounts(ucounts, UCOUNT_RLIMIT_MEMLOCK, locked); in user_shm_lock() 779 void user_shm_unlock(size_t size, struct ucounts *ucounts) in user_shm_unlock() argument 782 dec_rlimit_ucounts(ucounts, UCOUNT_RLIMIT_MEMLOCK, (size + PAGE_SIZE - 1) >> PAGE_SHIFT); in user_shm_unlock() 784 put_ucounts(ucounts); in user_shm_unlock()
|
/linux-6.6.21/net/core/ |
D | net_namespace.c | 395 static struct ucounts *inc_net_namespaces(struct user_namespace *ns) in inc_net_namespaces() 400 static void dec_net_namespaces(struct ucounts *ucounts) in dec_net_namespaces() argument 402 dec_ucount(ucounts, UCOUNT_NET_NAMESPACES); in dec_net_namespaces() 465 struct ucounts *ucounts; in copy_net_ns() local 472 ucounts = inc_net_namespaces(user_ns); in copy_net_ns() 473 if (!ucounts) in copy_net_ns() 484 net->ucounts = ucounts; in copy_net_ns() 503 dec_net_namespaces(ucounts); in copy_net_ns() 630 dec_net_namespaces(net->ucounts); in cleanup_net()
|
/linux-6.6.21/fs/ |
D | mount.h | 19 struct ucounts *ucounts; member
|
/linux-6.6.21/fs/notify/fanotify/ |
D | fanotify_user.c | 1201 struct ucounts *ucounts = group->fanotify_data.ucounts; in fanotify_add_new_mark() local 1211 !inc_ucount(ucounts->ns, ucounts->uid, UCOUNT_FANOTIFY_MARKS)) in fanotify_add_new_mark() 1234 dec_ucount(ucounts, UCOUNT_FANOTIFY_MARKS); in fanotify_add_new_mark() 1482 group->fanotify_data.ucounts = inc_ucount(current_user_ns(), in SYSCALL_DEFINE2() 1485 if (!group->fanotify_data.ucounts) { in SYSCALL_DEFINE2()
|