/openbmc/linux/kernel/ |
H A D | groups.c | 29 void groups_free(struct group_info *group_info) in groups_free() argument 31 kvfree(group_info); in groups_free() 38 const struct group_info *group_info) in groups_to_user() argument 54 static int groups_from_user(struct group_info *group_info, in groups_from_user() argument 84 void groups_sort(struct group_info *group_info) in groups_sort() argument 86 sort(group_info->gid, group_info->ngroups, sizeof(*group_info->gid), in groups_sort() 96 if (!group_info) in groups_search() 118 void set_groups(struct cred *new, struct group_info *group_info) in set_groups() argument 122 new->group_info = group_info; in set_groups() 134 int set_current_groups(struct group_info *group_info) in set_current_groups() argument [all …]
|
H A D | uid16.c | 115 struct group_info *group_info) in groups16_to_user() argument 123 kgid = group_info->gid[i]; in groups16_to_user() 132 static int groups16_from_user(struct group_info *group_info, in groups16_from_user() argument 148 group_info->gid[i] = kgid; in groups16_from_user() 162 i = cred->group_info->ngroups; in SYSCALL_DEFINE2() 179 struct group_info *group_info; in SYSCALL_DEFINE2() local 187 group_info = groups_alloc(gidsetsize); in SYSCALL_DEFINE2() 188 if (!group_info) in SYSCALL_DEFINE2() 192 put_group_info(group_info); in SYSCALL_DEFINE2() 196 groups_sort(group_info); in SYSCALL_DEFINE2() [all …]
|
H A D | cred.c | 39 static struct group_info init_groups = { .usage = ATOMIC_INIT(2) }; 61 .group_info = &init_groups, 83 if (cred->group_info) in put_cred_rcu() 84 put_group_info(cred->group_info); in put_cred_rcu() 218 get_group_info(new->group_info); in prepare_creds() 542 struct group_info *ga, *gb; in cred_fscmp() 557 ga = a->group_info; in cred_fscmp() 558 gb = b->group_info; in cred_fscmp() 647 get_group_info(new->group_info); in prepare_kernel_cred()
|
H A D | auditsc.c | 520 result = groups_search(cred->group_info, f->gid); in audit_filter_rules() 523 result = !groups_search(cred->group_info, f->gid); in audit_filter_rules() 530 result = groups_search(cred->group_info, f->gid); in audit_filter_rules() 533 result = !groups_search(cred->group_info, f->gid); in audit_filter_rules()
|
/openbmc/linux/include/linux/ |
H A D | cred.h | 25 struct group_info { struct 40 static inline struct group_info *get_group_info(struct group_info *gi) in get_group_info() 50 #define put_group_info(group_info) \ argument 53 groups_free(group_info); \ 57 extern struct group_info *groups_alloc(int); 58 extern void groups_free(struct group_info *); 67 extern void groups_sort(struct group_info *); 69 static inline void groups_free(struct group_info *group_info) in groups_free() argument 81 static inline int groups_search(const struct group_info *group_info, kgid_t grp) in groups_search() argument 140 struct group_info *group_info; /* supplementary groups for euid/fsgid */ member [all …]
|
H A D | nfs_fs.h | 65 struct group_info *group_info; member
|
/openbmc/linux/net/sunrpc/ |
H A D | auth_unix.c | 91 if (acred->cred->group_info != NULL) in unx_match() 92 groups = acred->cred->group_info->ngroups; in unx_match() 95 if (cred->cr_cred->group_info == NULL) in unx_match() 97 if (groups != cred->cr_cred->group_info->ngroups) in unx_match() 101 if (!gid_eq(cred->cr_cred->group_info->gid[i], acred->cred->group_info->gid[i])) in unx_match() 117 struct group_info *gi = cred->cr_cred->group_info; in unx_marshal()
|
H A D | svcauth_unix.c | 411 struct group_info *gi; 642 static struct group_info *unix_gid_find(kuid_t uid, struct svc_rqst *rqstp) in unix_gid_find() 645 struct group_info *gi; in unix_gid_find() 674 struct group_info *gi; in svcauth_unix_set_client()
|
/openbmc/linux/security/safesetid/ |
H A D | lsm.c | 246 get_group_info(new->group_info); in safesetid_task_fix_setgroups() 247 for (i = 0; i < new->group_info->ngroups; i++) { in safesetid_task_fix_setgroups() 248 if (!id_permitted_for_cred(old, (kid_t){.gid = new->group_info->gid[i]}, GID)) { in safesetid_task_fix_setgroups() 249 put_group_info(new->group_info); in safesetid_task_fix_setgroups() 260 put_group_info(new->group_info); in safesetid_task_fix_setgroups()
|
/openbmc/linux/fs/nfsd/ |
H A D | filecache.c | 89 if (c1->group_info == NULL || c2->group_info == NULL) in nfsd_match_cred() 90 return c1->group_info == c2->group_info; in nfsd_match_cred() 91 if (c1->group_info->ngroups != c2->group_info->ngroups) in nfsd_match_cred() 93 for (i = 0; i < c1->group_info->ngroups; i++) { in nfsd_match_cred() 94 if (!gid_eq(c1->group_info->gid[i], c2->group_info->gid[i])) in nfsd_match_cred()
|
H A D | auth.c | 23 struct group_info *rqgi; in nfsd_setuser() 24 struct group_info *gi; in nfsd_setuser()
|
/openbmc/linux/net/netfilter/ |
H A D | xt_owner.c | 102 struct group_info *gi = filp->f_cred->group_info; in owner_mt()
|
/openbmc/linux/fs/proc/ |
H A D | array.c | 152 struct group_info *group_info; in task_state() local 200 group_info = cred->group_info; in task_state() 201 for (g = 0; g < group_info->ngroups; g++) in task_state() 203 from_kgid_munged(user_ns, group_info->gid[g])); in task_state()
|
/openbmc/linux/security/keys/ |
H A D | permission.c | 67 ret = groups_search(cred->group_info, key->gid); in key_task_permission()
|
H A D | process_keys.c | 939 new->group_info = get_group_info(old->group_info); in key_change_session_keyring()
|
/openbmc/linux/io_uring/ |
H A D | fdinfo.c | 23 struct group_info *gi; in io_uring_show_cred() 37 gi = cred->group_info; in io_uring_show_cred()
|
/openbmc/linux/include/linux/sunrpc/ |
H A D | svcauth.h | 24 struct group_info *cr_group_info;
|
/openbmc/linux/net/ipv4/ |
H A D | ping.c | 256 struct group_info *group_info; in ping_init_sock() local 268 group_info = get_current_groups(); in ping_init_sock() 269 for (i = 0; i < group_info->ngroups; i++) { in ping_init_sock() 270 kgid_t gid = group_info->gid[i]; in ping_init_sock() 279 put_group_info(group_info); in ping_init_sock()
|
/openbmc/linux/fs/nfs/ |
H A D | dir.c | 2795 put_group_info(entry->group_info); in nfs_access_free_entry() 2923 struct group_info *ga, *gb; in access_cmp() 2936 ga = a->group_info; in access_cmp() 2937 gb = b->group_info; in access_cmp() 3135 cache->group_info = get_group_info(cred->group_info); in nfs_access_add_cache()
|
/openbmc/linux/fs/ext4/ |
H A D | mballoc.c | 3384 struct ext4_group_info ***group_info; in ext4_mb_add_groupinfo() local 3387 group_info = rcu_dereference(sbi->s_group_info); in ext4_mb_add_groupinfo() 3388 kfree(group_info[idx]); in ext4_mb_add_groupinfo() 3389 group_info[idx] = NULL; in ext4_mb_add_groupinfo() 3402 struct ext4_group_info ***group_info; in ext4_mb_init_backend() local 3471 group_info = rcu_dereference(sbi->s_group_info); in ext4_mb_init_backend() 3473 kfree(group_info[i]); in ext4_mb_init_backend() 3765 struct ext4_group_info *grinfo, ***group_info; in ext4_mb_release() local 3797 group_info = rcu_dereference(sbi->s_group_info); in ext4_mb_release() 3799 kfree(group_info[i]); in ext4_mb_release() [all …]
|
/openbmc/linux/fs/smb/server/ |
H A D | smb_common.c | 744 struct group_info *gi; in __ksmbd_override_fsids()
|
/openbmc/linux/sound/pci/asihpi/ |
H A D | hpifunc.c | 823 *poutstream_map = hr.u.d.u.group_info.outstream_group_map; in hpi_outstream_group_get_map() 825 *pinstream_map = hr.u.d.u.group_info.instream_group_map; in hpi_outstream_group_get_map() 1181 *poutstream_map = hr.u.d.u.group_info.outstream_group_map; in hpi_instream_group_get_map() 1183 *pinstream_map = hr.u.d.u.group_info.instream_group_map; in hpi_instream_group_get_map()
|
H A D | hpi_internal.h | 761 } group_info; member
|
/openbmc/linux/Documentation/security/ |
H A D | credentials.rst | 260 2. the reference count on the group_info struct it points to may be changed; 348 struct group_info *get_current_groups(void);
|
/openbmc/linux/net/core/ |
H A D | sock.c | 1590 static int groups_to_user(sockptr_t dst, const struct group_info *src) in groups_to_user() 1820 n = cred->group_info->ngroups; in sk_getsockopt() 1828 ret = groups_to_user(optval, cred->group_info); in sk_getsockopt()
|