提交 c0b0ae8a 编写于 作者: R Richard Guy Briggs 提交者: Paul Moore

audit: use inline function to set audit context

Recognizing that the audit context is an internal audit value, use an
access function to set the audit context pointer for the task
rather than reaching directly into the task struct to set it.
Signed-off-by: NRichard Guy Briggs <rgb@redhat.com>
[PM: merge fuzz in audit.h]
Signed-off-by: NPaul Moore <paul@paul-moore.com>
上级 cdfb6b34
...@@ -237,6 +237,11 @@ extern void audit_seccomp_actions_logged(const char *names, ...@@ -237,6 +237,11 @@ extern void audit_seccomp_actions_logged(const char *names,
const char *old_names, int res); const char *old_names, int res);
extern void __audit_ptrace(struct task_struct *t); extern void __audit_ptrace(struct task_struct *t);
static inline void audit_set_context(struct task_struct *task, struct audit_context *ctx)
{
task->audit_context = ctx;
}
static inline struct audit_context *audit_context(void) static inline struct audit_context *audit_context(void)
{ {
return current->audit_context; return current->audit_context;
...@@ -469,6 +474,8 @@ static inline bool audit_dummy_context(void) ...@@ -469,6 +474,8 @@ static inline bool audit_dummy_context(void)
{ {
return true; return true;
} }
static inline void audit_set_context(struct task_struct *task, struct audit_context *ctx)
{ }
static inline struct audit_context *audit_context(void) static inline struct audit_context *audit_context(void)
{ {
return NULL; return NULL;
......
...@@ -865,7 +865,7 @@ static inline struct audit_context *audit_take_context(struct task_struct *tsk, ...@@ -865,7 +865,7 @@ static inline struct audit_context *audit_take_context(struct task_struct *tsk,
audit_filter_inodes(tsk, context); audit_filter_inodes(tsk, context);
} }
tsk->audit_context = NULL; audit_set_context(tsk, NULL);
return context; return context;
} }
...@@ -952,7 +952,7 @@ int audit_alloc(struct task_struct *tsk) ...@@ -952,7 +952,7 @@ int audit_alloc(struct task_struct *tsk)
} }
context->filterkey = key; context->filterkey = key;
tsk->audit_context = context; audit_set_context(tsk, context);
set_tsk_thread_flag(tsk, TIF_SYSCALL_AUDIT); set_tsk_thread_flag(tsk, TIF_SYSCALL_AUDIT);
return 0; return 0;
} }
...@@ -1554,7 +1554,6 @@ void __audit_syscall_entry(int major, unsigned long a1, unsigned long a2, ...@@ -1554,7 +1554,6 @@ void __audit_syscall_entry(int major, unsigned long a1, unsigned long a2,
*/ */
void __audit_syscall_exit(int success, long return_code) void __audit_syscall_exit(int success, long return_code)
{ {
struct task_struct *tsk = current;
struct audit_context *context; struct audit_context *context;
if (success) if (success)
...@@ -1589,7 +1588,7 @@ void __audit_syscall_exit(int success, long return_code) ...@@ -1589,7 +1588,7 @@ void __audit_syscall_exit(int success, long return_code)
kfree(context->filterkey); kfree(context->filterkey);
context->filterkey = NULL; context->filterkey = NULL;
} }
tsk->audit_context = context; audit_set_context(current, context);
} }
static inline void handle_one(const struct inode *inode) static inline void handle_one(const struct inode *inode)
......
...@@ -1713,7 +1713,7 @@ static __latent_entropy struct task_struct *copy_process( ...@@ -1713,7 +1713,7 @@ static __latent_entropy struct task_struct *copy_process(
p->start_time = ktime_get_ns(); p->start_time = ktime_get_ns();
p->real_start_time = ktime_get_boot_ns(); p->real_start_time = ktime_get_boot_ns();
p->io_context = NULL; p->io_context = NULL;
p->audit_context = NULL; audit_set_context(p, NULL);
cgroup_fork(p); cgroup_fork(p);
#ifdef CONFIG_NUMA #ifdef CONFIG_NUMA
p->mempolicy = mpol_dup(p->mempolicy); p->mempolicy = mpol_dup(p->mempolicy);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册