On Fri, Apr 19, 2019 at 10:34 AM Yang YingliangI'm not sure you got my point.
<yangyingliang@xxxxxxxxxx> wrote:
On 2019/4/19 21:24, Paul Moore wrote:I would expect that; real_cred is the task's objective DAC
On Thu, Apr 18, 2019 at 10:42 PM Yang YingliangIn do_acct_process(), file->f_cred may equal to current->real_cred, I
<yangyingliang@xxxxxxxxxx> wrote:
On 2019/4/19 10:04, Paul Moore wrote:Both task_struct.cred and task_struct.real_cred are pointer values,
On Wed, Apr 17, 2019 at 10:50 PM Yang YingliangIt's possible the new cred is equal to current->real_cred and
<yangyingliang@xxxxxxxxxx> wrote:
On 2019/4/18 8:24, Casey Schaufler wrote:I'm sorry, you've lost me. After override_creds() returns
On 4/17/2019 4:39 PM, Paul Moore wrote:The cred != real_cred checking is not enough.
Since it looks like all three LSMs which implement the setprocattrI'm fine with the change going into proc_pid_attr_write().
hook are vulnerable I'm open to the idea that proc_pid_attr_write() is
a better choice for the cred != read_cred check, but I would want to
make sure John and Casey are okay with that.
John?
Casey?
Consider this situation, when doing override, cred, real_cred and
new_cred are all same:
after override_creds() cred == real_cred == new1_cred
current->cred and current->real_cred are not going to be the same,
yes?
current->cred,
so after overrides_creds(), they have the same value.
assuming that one uses prepare_creds() to allocate/initialize a new
cred struct for use with override_creds() then the newly created cred
should never be equal to task_struct.real_cred. Am I missing
something, or are you thinking of something else?
confirm
it by adding some debug message in do_acct_process() like this:
credentials, so using it for f_cred makes sense.
What we are now talking about is the task's subjective credentials,
which can be overridden via override_creds(), and are what the LSMs
change via proc_pid_attr_write().
--- a/kernel/acct.c
+++ b/kernel/acct.c
@@ -481,6 +481,7 @@ static void do_acct_process(struct bsd_acct_struct
*acct)
flim = current->signal->rlim[RLIMIT_FSIZE].rlim_cur;
current->signal->rlim[RLIMIT_FSIZE].rlim_cur = RLIM_INFINITY;
/* Perform file operations on behalf of whoever enabled
accounting */
+ pr_info("task:%px new cred:%px real cred:%px cred:%px\n",
current, file->f_cred, current->real_cred, current->cred);
orig_cred = override_creds(file->f_cred);