diff options
author | rwatson <rwatson@FreeBSD.org> | 2006-02-02 00:37:05 +0000 |
---|---|---|
committer | rwatson <rwatson@FreeBSD.org> | 2006-02-02 00:37:05 +0000 |
commit | 36f0dbe4c4a6e71238a0fec882dc0eb92eb8fa31 (patch) | |
tree | 06e8087c98c48dc1fdd380468a6f21c616f39390 /sys/security | |
parent | b560f9379f23dae19bdbf6195acd34565323560a (diff) | |
download | FreeBSD-src-36f0dbe4c4a6e71238a0fec882dc0eb92eb8fa31.zip FreeBSD-src-36f0dbe4c4a6e71238a0fec882dc0eb92eb8fa31.tar.gz |
Add new fields to process-related data structures:
- td_ar to struct thread, which holds the in-progress audit record during
a system call.
- p_au to struct proc, which holds per-process audit state, such as the
audit identifier, audit terminal, and process audit masks.
In the earlier implementation, td_ar was added to the zero'd section of
struct thread. In order to facilitate merging to RELENG_6, it has been
moved to the end of the data structure, requiring explicit
initalization in the thread constructor.
Much help from: wsalamon
Obtained from: TrustedBSD Project
Diffstat (limited to 'sys/security')
-rw-r--r-- | sys/security/audit/audit.c | 10 | ||||
-rw-r--r-- | sys/security/audit/audit.h | 1 |
2 files changed, 11 insertions, 0 deletions
diff --git a/sys/security/audit/audit.c b/sys/security/audit/audit.c index b2f1143..1d3c3e6 100644 --- a/sys/security/audit/audit.c +++ b/sys/security/audit/audit.c @@ -1015,6 +1015,16 @@ audit_proc_alloc(struct proc *p) //printf("audit_proc_alloc: pid %d p_au %p\n", p->p_pid, p->p_au); } +/* + * Allocate storage for a new thread. + */ +void +audit_thread_alloc(struct thread *td) +{ + + td->td_ar = NULL; +} + /* * Initialize the audit information for the a process, presumably the first * process in the system. diff --git a/sys/security/audit/audit.h b/sys/security/audit/audit.h index 3dbabcd..f889f3b 100644 --- a/sys/security/audit/audit.h +++ b/sys/security/audit/audit.h @@ -180,6 +180,7 @@ void audit_proc_init(struct proc *p); void audit_proc_fork(struct proc *parent, struct proc *child); void audit_proc_free(struct proc *p); +void audit_thread_alloc(struct thread *td); /* * Define a macro to wrap the audit_arg_* calls by checking the global |