From: Kees Cook <keescook@chromium.org>
To: Michal Hocko <mhocko@suse.com>
Cc: Greg Kroah-Hartman <gregkh@linuxfoundation.org>,
Andrew Morton <akpm@linux-foundation.org>,
"Rafael J. Wysocki" <rafael@kernel.org>,
Alexey Dobriyan <adobriyan@gmail.com>,
Lee Duncan <lduncan@suse.com>, Chris Leech <cleech@redhat.com>,
Adam Nichols <adam@grimm-co.com>,
linux-fsdevel@vger.kernel.org, linux-hardening@vger.kernel.org,
linux-kernel@vger.kernel.org
Subject: Re: [PATCH v3] sysfs: Unconditionally use vmalloc for buffer
Date: Thu, 1 Apr 2021 00:37:09 -0700 [thread overview]
Message-ID: <202104010030.42B460AB12@keescook> (raw)
In-Reply-To: <YGVy0WUG1OEFfjhx@dhcp22.suse.cz>
On Thu, Apr 01, 2021 at 09:14:25AM +0200, Michal Hocko wrote:
> On Wed 31-03-21 19:21:45, Kees Cook wrote:
> > The sysfs interface to seq_file continues to be rather fragile
> > (seq_get_buf() should not be used outside of seq_file), as seen with
> > some recent exploits[1]. Move the seq_file buffer to the vmap area
> > (while retaining the accounting flag), since it has guard pages that
> > will catch and stop linear overflows.
>
> I thought the previous discussion has led to a conclusion that the
> preferred way is to disallow direct seq_file buffer usage. But this is
> obviously up to sysfs maintainers. I am happy you do not want to spread
> this out to all seq_file users anymore.
Yeah; I still want to remove external seq_get_buf(), but that'll take
time. I'll be doing the work, though, since I still need access to
f_cred for show() access control checks.
> > This seems justified given that
> > sysfs's use of seq_file already uses kvmalloc(), is almost always using
> > a PAGE_SIZE or larger allocation, has normally short-lived allocations,
> > and is not normally on a performance critical path.
>
> Let me clarify on this, because this is not quite right. kvmalloc vs
> vmalloc (both with GFP_KERNEL) on PAGE_SIZE are two different beasts.
> The first one is almost always going to use kmalloc because the page
> allocator almost never fails those requests.
Yes, good point. I will adjust my changelog.
Thanks!
-Kees
>
> > Once seq_get_buf() has been removed (and all sysfs callbacks using
> > seq_file directly), this change can also be removed.
> >
> > [1] https://blog.grimm-co.com/2021/03/new-old-bugs-in-linux-kernel.html
> >
> > Signed-off-by: Kees Cook <keescook@chromium.org>
> > ---
> > v3:
> > - Limit to only sysfs (instead of all of seq_file).
> > v2: https://lore.kernel.org/lkml/20210315174851.622228-1-keescook@chromium.org/
> > v1: https://lore.kernel.org/lkml/20210312205558.2947488-1-keescook@chromium.org/
> > ---
> > fs/sysfs/file.c | 23 +++++++++++++++++++++++
> > 1 file changed, 23 insertions(+)
> >
> > diff --git a/fs/sysfs/file.c b/fs/sysfs/file.c
> > index 9aefa7779b29..70e7a450e5d1 100644
> > --- a/fs/sysfs/file.c
> > +++ b/fs/sysfs/file.c
> > @@ -16,6 +16,7 @@
> > #include <linux/mutex.h>
> > #include <linux/seq_file.h>
> > #include <linux/mm.h>
> > +#include <linux/vmalloc.h>
> >
> > #include "sysfs.h"
> >
> > @@ -32,6 +33,25 @@ static const struct sysfs_ops *sysfs_file_ops(struct kernfs_node *kn)
> > return kobj->ktype ? kobj->ktype->sysfs_ops : NULL;
> > }
> >
> > +/*
> > + * To be proactively defensive against sysfs show() handlers that do not
> > + * correctly stay within their PAGE_SIZE buffer, use the vmap area to gain
> > + * the trailing guard page which will stop linear buffer overflows.
> > + */
> > +static void *sysfs_kf_seq_start(struct seq_file *sf, loff_t *ppos)
> > +{
> > + struct kernfs_open_file *of = sf->private;
> > + struct kernfs_node *kn = of->kn;
> > +
> > + WARN_ON_ONCE(sf->buf);
> > + sf->buf = __vmalloc(kn->attr.size, GFP_KERNEL_ACCOUNT);
> > + if (!sf->buf)
> > + return ERR_PTR(-ENOMEM);
> > + sf->size = kn->attr.size;
> > +
> > + return NULL + !*ppos;
> > +}
> > +
> > /*
> > * Reads on sysfs are handled through seq_file, which takes care of hairy
> > * details like buffering and seeking. The following function pipes
> > @@ -206,14 +226,17 @@ static const struct kernfs_ops sysfs_file_kfops_empty = {
> > };
> >
> > static const struct kernfs_ops sysfs_file_kfops_ro = {
> > + .seq_start = sysfs_kf_seq_start,
> > .seq_show = sysfs_kf_seq_show,
> > };
> >
> > static const struct kernfs_ops sysfs_file_kfops_wo = {
> > + .seq_start = sysfs_kf_seq_start,
> > .write = sysfs_kf_write,
> > };
> >
> > static const struct kernfs_ops sysfs_file_kfops_rw = {
> > + .seq_start = sysfs_kf_seq_start,
> > .seq_show = sysfs_kf_seq_show,
> > .write = sysfs_kf_write,
> > };
> > --
> > 2.25.1
>
> --
> Michal Hocko
> SUSE Labs
--
Kees Cook
prev parent reply other threads:[~2021-04-01 7:38 UTC|newest]
Thread overview: 15+ messages / expand[flat|nested] mbox.gz Atom feed top
2021-04-01 2:21 [PATCH v3] sysfs: Unconditionally use vmalloc for buffer Kees Cook
2021-04-01 5:16 ` Greg Kroah-Hartman
2021-04-01 6:52 ` Kees Cook
2021-04-01 7:10 ` Greg Kroah-Hartman
2021-04-01 7:30 ` Kees Cook
2021-04-01 6:41 ` kernel test robot
2021-04-01 6:41 ` kernel test robot
2021-04-01 6:47 ` Nathan Chancellor
2021-04-01 6:47 ` Nathan Chancellor
2021-04-01 6:59 ` Kees Cook
2021-04-01 6:59 ` Kees Cook
2021-04-01 7:08 ` Greg Kroah-Hartman
2021-04-01 7:08 ` Greg Kroah-Hartman
2021-04-01 7:14 ` Michal Hocko
2021-04-01 7:37 ` Kees Cook [this message]
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=202104010030.42B460AB12@keescook \
--to=keescook@chromium.org \
--cc=adam@grimm-co.com \
--cc=adobriyan@gmail.com \
--cc=akpm@linux-foundation.org \
--cc=cleech@redhat.com \
--cc=gregkh@linuxfoundation.org \
--cc=lduncan@suse.com \
--cc=linux-fsdevel@vger.kernel.org \
--cc=linux-hardening@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=mhocko@suse.com \
--cc=rafael@kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.