aboutsummaryrefslogtreecommitdiffstats
path: root/include
diff options
context:
space:
mode:
Diffstat (limited to 'include')
-rw-r--r--include/linux/cred.h6
-rw-r--r--include/linux/security.h28
2 files changed, 34 insertions, 0 deletions
diff --git a/include/linux/cred.h b/include/linux/cred.h
index 55a9c995d694..26c1ab179946 100644
--- a/include/linux/cred.h
+++ b/include/linux/cred.h
@@ -18,6 +18,7 @@
18 18
19struct user_struct; 19struct user_struct;
20struct cred; 20struct cred;
21struct inode;
21 22
22/* 23/*
23 * COW Supplementary groups list 24 * COW Supplementary groups list
@@ -148,6 +149,11 @@ extern int commit_creds(struct cred *);
148extern void abort_creds(struct cred *); 149extern void abort_creds(struct cred *);
149extern const struct cred *override_creds(const struct cred *); 150extern const struct cred *override_creds(const struct cred *);
150extern void revert_creds(const struct cred *); 151extern void revert_creds(const struct cred *);
152extern struct cred *prepare_kernel_cred(struct task_struct *);
153extern int change_create_files_as(struct cred *, struct inode *);
154extern int set_security_override(struct cred *, u32);
155extern int set_security_override_from_ctx(struct cred *, const char *);
156extern int set_create_files_as(struct cred *, struct inode *);
151extern void __init cred_init(void); 157extern void __init cred_init(void);
152 158
153/** 159/**
diff --git a/include/linux/security.h b/include/linux/security.h
index 56a0eed65673..59a11e19b617 100644
--- a/include/linux/security.h
+++ b/include/linux/security.h
@@ -587,6 +587,19 @@ static inline void security_free_mnt_opts(struct security_mnt_opts *opts)
587 * @new points to the new credentials. 587 * @new points to the new credentials.
588 * @old points to the original credentials. 588 * @old points to the original credentials.
589 * Install a new set of credentials. 589 * Install a new set of credentials.
590 * @kernel_act_as:
591 * Set the credentials for a kernel service to act as (subjective context).
592 * @new points to the credentials to be modified.
593 * @secid specifies the security ID to be set
594 * The current task must be the one that nominated @secid.
595 * Return 0 if successful.
596 * @kernel_create_files_as:
597 * Set the file creation context in a set of credentials to be the same as
598 * the objective context of the specified inode.
599 * @new points to the credentials to be modified.
600 * @inode points to the inode to use as a reference.
601 * The current task must be the one that nominated @inode.
602 * Return 0 if successful.
590 * @task_setuid: 603 * @task_setuid:
591 * Check permission before setting one or more of the user identity 604 * Check permission before setting one or more of the user identity
592 * attributes of the current process. The @flags parameter indicates 605 * attributes of the current process. The @flags parameter indicates
@@ -1381,6 +1394,8 @@ struct security_operations {
1381 int (*cred_prepare)(struct cred *new, const struct cred *old, 1394 int (*cred_prepare)(struct cred *new, const struct cred *old,
1382 gfp_t gfp); 1395 gfp_t gfp);
1383 void (*cred_commit)(struct cred *new, const struct cred *old); 1396 void (*cred_commit)(struct cred *new, const struct cred *old);
1397 int (*kernel_act_as)(struct cred *new, u32 secid);
1398 int (*kernel_create_files_as)(struct cred *new, struct inode *inode);
1384 int (*task_setuid) (uid_t id0, uid_t id1, uid_t id2, int flags); 1399 int (*task_setuid) (uid_t id0, uid_t id1, uid_t id2, int flags);
1385 int (*task_fix_setuid) (struct cred *new, const struct cred *old, 1400 int (*task_fix_setuid) (struct cred *new, const struct cred *old,
1386 int flags); 1401 int flags);
@@ -1632,6 +1647,8 @@ int security_task_create(unsigned long clone_flags);
1632void security_cred_free(struct cred *cred); 1647void security_cred_free(struct cred *cred);
1633int security_prepare_creds(struct cred *new, const struct cred *old, gfp_t gfp); 1648int security_prepare_creds(struct cred *new, const struct cred *old, gfp_t gfp);
1634void security_commit_creds(struct cred *new, const struct cred *old); 1649void security_commit_creds(struct cred *new, const struct cred *old);
1650int security_kernel_act_as(struct cred *new, u32 secid);
1651int security_kernel_create_files_as(struct cred *new, struct inode *inode);
1635int security_task_setuid(uid_t id0, uid_t id1, uid_t id2, int flags); 1652int security_task_setuid(uid_t id0, uid_t id1, uid_t id2, int flags);
1636int security_task_fix_setuid(struct cred *new, const struct cred *old, 1653int security_task_fix_setuid(struct cred *new, const struct cred *old,
1637 int flags); 1654 int flags);
@@ -2151,6 +2168,17 @@ static inline void security_commit_creds(struct cred *new,
2151{ 2168{
2152} 2169}
2153 2170
2171static inline int security_kernel_act_as(struct cred *cred, u32 secid)
2172{
2173 return 0;
2174}
2175
2176static inline int security_kernel_create_files_as(struct cred *cred,
2177 struct inode *inode)
2178{
2179 return 0;
2180}
2181
2154static inline int security_task_setuid(uid_t id0, uid_t id1, uid_t id2, 2182static inline int security_task_setuid(uid_t id0, uid_t id1, uid_t id2,
2155 int flags) 2183 int flags)
2156{ 2184{