From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from mail-yb1-f196.google.com ([209.85.219.196]:46953 "EHLO mail-yb1-f196.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1731091AbeITXlN (ORCPT ); Thu, 20 Sep 2018 19:41:13 -0400 Received: by mail-yb1-f196.google.com with SMTP id y20-v6so4278911ybi.13 for ; Thu, 20 Sep 2018 10:56:34 -0700 (PDT) Received: from mail-yw1-f45.google.com (mail-yw1-f45.google.com. [209.85.161.45]) by smtp.gmail.com with ESMTPSA id w6-v6sm3454174ywg.3.2018.09.20.10.56.30 for (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Thu, 20 Sep 2018 10:56:31 -0700 (PDT) Received: by mail-yw1-f45.google.com with SMTP id n21-v6so4112115ywh.5 for ; Thu, 20 Sep 2018 10:56:30 -0700 (PDT) MIME-Version: 1.0 In-Reply-To: <8ef63a94-c7b6-226d-2d60-a05f79406819@schaufler-ca.com> References: <748c61cb-b6fa-c36d-a7b3-2315ff6292af@schaufler-ca.com> <8ef63a94-c7b6-226d-2d60-a05f79406819@schaufler-ca.com> From: Kees Cook Date: Thu, 20 Sep 2018 10:56:30 -0700 Message-ID: Subject: Re: [PATCH v3 16/16] LSM: Blob sharing support for S.A.R.A and LandLock To: Casey Schaufler Cc: LSM , James Morris , SE Linux , LKLM , John Johansen , Tetsuo Handa , Paul Moore , Stephen Smalley , "linux-fsdevel@vger.kernel.org" , Alexey Dobriyan , =?UTF-8?B?TWlja2HDq2wgU2FsYcO8bg==?= , Salvatore Mesoraca Content-Type: text/plain; charset="UTF-8" Sender: linux-fsdevel-owner@vger.kernel.org List-ID: On Wed, Sep 19, 2018 at 5:21 PM, Casey Schaufler wrote: > diff --git a/security/smack/smack_lsm.c b/security/smack/smack_lsm.c > index 8f3b809d7c26..0156ffea7f8c 100644 > --- a/security/smack/smack_lsm.c > +++ b/security/smack/smack_lsm.c > @@ -3475,18 +3475,16 @@ static int smack_getprocattr(struct task_struct *p, char *name, char **value) > { > struct smack_known *skp = smk_of_task_struct(p); > char *cp; > - int slen; > > - if (strcmp(name, "current") != 0) > + if (strcmp(name, "current") == 0) { > + cp = kstrdup(skp->smk_known, GFP_KERNEL); > + if (cp == NULL) > + return -ENOMEM; > + } else > return -EINVAL; > > - cp = kstrdup(skp->smk_known, GFP_KERNEL); > - if (cp == NULL) > - return -ENOMEM; > - > - slen = strlen(cp); > *value = cp; > - return slen; > + return strlen(cp); > } This should be separate: it looks like unrelated refactoring? (I mentioned this before, I think?) > diff --git a/security/tomoyo/common.h b/security/tomoyo/common.h > index 0110bebe86e2..f386f92c57c5 100644 > --- a/security/tomoyo/common.h > +++ b/security/tomoyo/common.h > @@ -1216,8 +1221,13 @@ static inline struct tomoyo_domain_info **tomoyo_cred(const struct cred *cred) > */ > static inline struct tomoyo_domain_info *tomoyo_domain(void) > { > - struct tomoyo_domain_info **blob = tomoyo_cred(current_cred()); > + const struct cred *cred = current_cred(); > + struct tomoyo_domain_info **blob; > + > + if (cred->security == NULL) > + return NULL; > > + blob = tomoyo_cred(cred); > return *blob; > } I think this is another lost hunk? -Kees -- Kees Cook Pixel Security