|
@@ -587,6 +587,19 @@ static inline void security_free_mnt_opts(struct security_mnt_opts *opts)
|
|
* @new points to the new credentials.
|
|
* @new points to the new credentials.
|
|
* @old points to the original credentials.
|
|
* @old points to the original credentials.
|
|
* Install a new set of credentials.
|
|
* Install a new set of credentials.
|
|
|
|
+ * @kernel_act_as:
|
|
|
|
+ * Set the credentials for a kernel service to act as (subjective context).
|
|
|
|
+ * @new points to the credentials to be modified.
|
|
|
|
+ * @secid specifies the security ID to be set
|
|
|
|
+ * The current task must be the one that nominated @secid.
|
|
|
|
+ * Return 0 if successful.
|
|
|
|
+ * @kernel_create_files_as:
|
|
|
|
+ * Set the file creation context in a set of credentials to be the same as
|
|
|
|
+ * the objective context of the specified inode.
|
|
|
|
+ * @new points to the credentials to be modified.
|
|
|
|
+ * @inode points to the inode to use as a reference.
|
|
|
|
+ * The current task must be the one that nominated @inode.
|
|
|
|
+ * Return 0 if successful.
|
|
* @task_setuid:
|
|
* @task_setuid:
|
|
* Check permission before setting one or more of the user identity
|
|
* Check permission before setting one or more of the user identity
|
|
* attributes of the current process. The @flags parameter indicates
|
|
* attributes of the current process. The @flags parameter indicates
|
|
@@ -1381,6 +1394,8 @@ struct security_operations {
|
|
int (*cred_prepare)(struct cred *new, const struct cred *old,
|
|
int (*cred_prepare)(struct cred *new, const struct cred *old,
|
|
gfp_t gfp);
|
|
gfp_t gfp);
|
|
void (*cred_commit)(struct cred *new, const struct cred *old);
|
|
void (*cred_commit)(struct cred *new, const struct cred *old);
|
|
|
|
+ int (*kernel_act_as)(struct cred *new, u32 secid);
|
|
|
|
+ int (*kernel_create_files_as)(struct cred *new, struct inode *inode);
|
|
int (*task_setuid) (uid_t id0, uid_t id1, uid_t id2, int flags);
|
|
int (*task_setuid) (uid_t id0, uid_t id1, uid_t id2, int flags);
|
|
int (*task_fix_setuid) (struct cred *new, const struct cred *old,
|
|
int (*task_fix_setuid) (struct cred *new, const struct cred *old,
|
|
int flags);
|
|
int flags);
|
|
@@ -1632,6 +1647,8 @@ int security_task_create(unsigned long clone_flags);
|
|
void security_cred_free(struct cred *cred);
|
|
void security_cred_free(struct cred *cred);
|
|
int security_prepare_creds(struct cred *new, const struct cred *old, gfp_t gfp);
|
|
int security_prepare_creds(struct cred *new, const struct cred *old, gfp_t gfp);
|
|
void security_commit_creds(struct cred *new, const struct cred *old);
|
|
void security_commit_creds(struct cred *new, const struct cred *old);
|
|
|
|
+int security_kernel_act_as(struct cred *new, u32 secid);
|
|
|
|
+int security_kernel_create_files_as(struct cred *new, struct inode *inode);
|
|
int security_task_setuid(uid_t id0, uid_t id1, uid_t id2, int flags);
|
|
int security_task_setuid(uid_t id0, uid_t id1, uid_t id2, int flags);
|
|
int security_task_fix_setuid(struct cred *new, const struct cred *old,
|
|
int security_task_fix_setuid(struct cred *new, const struct cred *old,
|
|
int flags);
|
|
int flags);
|
|
@@ -2151,6 +2168,17 @@ static inline void security_commit_creds(struct cred *new,
|
|
{
|
|
{
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+static inline int security_kernel_act_as(struct cred *cred, u32 secid)
|
|
|
|
+{
|
|
|
|
+ return 0;
|
|
|
|
+}
|
|
|
|
+
|
|
|
|
+static inline int security_kernel_create_files_as(struct cred *cred,
|
|
|
|
+ struct inode *inode)
|
|
|
|
+{
|
|
|
|
+ return 0;
|
|
|
|
+}
|
|
|
|
+
|
|
static inline int security_task_setuid(uid_t id0, uid_t id1, uid_t id2,
|
|
static inline int security_task_setuid(uid_t id0, uid_t id1, uid_t id2,
|
|
int flags)
|
|
int flags)
|
|
{
|
|
{
|