Commit ec7c0260 authored by Michal Schmidt's avatar Michal Schmidt Committed by James Toy

When process accounting is enabled, every exiting process writes a log to

the account file.  In addition, every once in a while one of the exiting
processes checks whether there's enough free space for the log.

SELinux policy may or may not allow the exiting process to stat the fs. 
So unsuspecting processes start generating AVC denials just because
someone enabled process accounting.

For these filesystem operations, the exiting process's credentials should
be temporarily switched to that of the process which enabled accounting,
because it's really that process which wanted to have the accounting
information logged.
Signed-off-by: default avatarMichal Schmidt <mschmidt@redhat.com>
Acked-by: default avatarDavid Howells <dhowells@redhat.com>
Cc: James Morris <jmorris@namei.org>
Cc: Serge Hallyn <serue@us.ibm.com>
Cc: Stephen Smalley <sds@tycho.nsa.gov>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
parent f778a859
...@@ -491,13 +491,17 @@ static void do_acct_process(struct bsd_acct_struct *acct, ...@@ -491,13 +491,17 @@ static void do_acct_process(struct bsd_acct_struct *acct,
u64 run_time; u64 run_time;
struct timespec uptime; struct timespec uptime;
struct tty_struct *tty; struct tty_struct *tty;
const struct cred *orig_cred;
/* Perform file operations on behalf of whoever enabled accounting */
orig_cred = override_creds(file->f_cred);
/* /*
* First check to see if there is enough free_space to continue * First check to see if there is enough free_space to continue
* the process accounting system. * the process accounting system.
*/ */
if (!check_free_space(acct, file)) if (!check_free_space(acct, file))
return; goto out;
/* /*
* Fill the accounting struct with the needed info as recorded * Fill the accounting struct with the needed info as recorded
...@@ -578,6 +582,8 @@ static void do_acct_process(struct bsd_acct_struct *acct, ...@@ -578,6 +582,8 @@ static void do_acct_process(struct bsd_acct_struct *acct,
sizeof(acct_t), &file->f_pos); sizeof(acct_t), &file->f_pos);
current->signal->rlim[RLIMIT_FSIZE].rlim_cur = flim; current->signal->rlim[RLIMIT_FSIZE].rlim_cur = flim;
set_fs(fs); set_fs(fs);
out:
revert_creds(orig_cred);
} }
/** /**
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment