From: Ingo Molnar <mingo@kernel.org>
To: Andy Lutomirski <luto@amacapital.net>
Cc: Brian Gerst <brgerst@gmail.com>,
Andy Lutomirski <luto@kernel.org>,
Peter Zijlstra <peterz@infradead.org>,
Steven Rostedt <rostedt@goodmis.org>,
"security@kernel.org" <security@kernel.org>,
X86 ML <x86@kernel.org>, Borislav Petkov <bp@alien8.de>,
Sasha Levin <sasha.levin@oracle.com>,
Linux Kernel Mailing List <linux-kernel@vger.kernel.org>,
Konrad Rzeszutek Wilk <konrad.wilk@oracle.com>,
Boris Ostrovsky <boris.ostrovsky@oracle.com>
Subject: Re: [PATCH v2 2/3] x86/ldt: Make modify_ldt optional
Date: Wed, 22 Jul 2015 08:06:43 +0200 [thread overview]
Message-ID: <20150722060643.GA25466@gmail.com> (raw)
In-Reply-To: <CALCETrVtqMtHPhh+sBxagz4vhWUHKL8HHswY-bxxsadhte6TqQ@mail.gmail.com>
* Andy Lutomirski <luto@amacapital.net> wrote:
> On Tue, Jul 21, 2015 at 1:28 PM, Brian Gerst <brgerst@gmail.com> wrote:
> > On Tue, Jul 21, 2015 at 3:59 PM, Andy Lutomirski <luto@kernel.org> wrote:
> >>
> >> The modify_ldt syscall exposes a large attack surface and is unnecessary for
> >> modern userspace. Make it optional.
> >>
> >> Signed-off-by: Andy Lutomirski <luto@kernel.org>
> >> ---
> >> arch/x86/Kconfig | 17 +++++++++++++++++
> >> arch/x86/include/asm/mmu.h | 2 ++
> >> arch/x86/include/asm/mmu_context.h | 31 +++++++++++++++++++++++--------
> >> arch/x86/kernel/Makefile | 3 ++-
> >> arch/x86/kernel/cpu/perf_event.c | 4 ++++
> >> arch/x86/kernel/process_64.c | 2 ++
> >> arch/x86/kernel/step.c | 2 ++
> >> kernel/sys_ni.c | 1 +
> >> 8 files changed, 53 insertions(+), 9 deletions(-)
> >>
> >> diff --git a/arch/x86/Kconfig b/arch/x86/Kconfig
> >> index 55bced17dc95..a7ff3980bd65 100644
> >> --- a/arch/x86/Kconfig
> >> +++ b/arch/x86/Kconfig
> >> @@ -1009,6 +1009,7 @@ config VM86
> >> config X86_16BIT
> >> bool "Enable support for 16-bit segments" if EXPERT
> >> default y
> >> + depends on MODIFY_LDT_SYSCALL
> >> ---help---
> >> This option is required by programs like Wine to run 16-bit
> >> protected mode legacy code on x86 processors. Disabling
> >> @@ -2047,6 +2048,22 @@ config CMDLINE_OVERRIDE
> >> This is used to work around broken boot loaders. This should
> >> be set to 'N' under normal conditions.
> >>
> >> +config MODIFY_LDT_SYSCALL
> >> + bool "Enable the LDT (local descriptor table)" if EXPERT
> >> + default y
> >> + ---help---
> >> + Linux can allow user programs to install a per-process x86
> >> + Local Descriptor Table (LDT) using the modify_ldt(2) system
> >> + call. This is required to run 16-bit or segmented code such as
> >> + DOSEMU or some Wine programs. It is also used by some very old
> >> + threading libraries.
> >> +
> >> + Enabling this feature adds a small amount of overhead to
> >> + context switches and increases the low-level kernel attack
> >> + surface. Disabling it removes the modify_ldt(2) system call.
> >> +
> >> + Saying 'N' here may make sense for embedded or server kernels.
> >> +
> >
> > I believe Wine still uses the LDT for thread-local data, even for 32
> > and 64-bit programs. This is separate from the Linux runtime TLS.
> >
>
> Really? I thought the whole reason we had three set_thread_area slots
> was for Wine.
Too bad we have to guess, if only we had the Wine source code under a nicely
accessible Git archive or so to check?
git clone git://source.winehq.org/git/wine.git
;-)
Thanks,
Ingo
next prev parent reply other threads:[~2015-07-22 6:06 UTC|newest]
Thread overview: 40+ messages / expand[flat|nested] mbox.gz Atom feed top
2015-07-21 19:59 [PATCH v2 0/3] x86: modify_ldt improvement, test, and config option Andy Lutomirski
2015-07-21 19:59 ` [PATCH v2 1/3] x86/ldt: Make modify_ldt synchronous Andy Lutomirski
2015-07-21 21:53 ` Boris Ostrovsky
2015-07-21 23:38 ` Andrew Cooper
2015-07-21 23:38 ` Andrew Cooper
2015-07-22 0:07 ` Andy Lutomirski
2015-07-22 0:21 ` Andrew Cooper
2015-07-22 0:21 ` Andrew Cooper
2015-07-22 0:28 ` Andy Lutomirski
2015-07-22 0:49 ` Andrew Cooper
2015-07-22 1:06 ` Andy Lutomirski
2015-07-22 1:06 ` Andy Lutomirski
2015-07-22 2:04 ` Boris Ostrovsky
2015-07-22 2:04 ` [Xen-devel] " Boris Ostrovsky
2015-07-22 2:13 ` Andy Lutomirski
2015-07-22 2:13 ` [Xen-devel] " Andy Lutomirski
2015-07-22 0:49 ` Andrew Cooper
2015-07-22 0:28 ` Andy Lutomirski
2015-07-22 0:07 ` Andy Lutomirski
2015-07-21 21:53 ` Boris Ostrovsky
2015-07-22 2:01 ` Brian Gerst
2015-07-22 2:12 ` Andy Lutomirski
2015-07-22 2:53 ` Brian Gerst
2015-07-22 4:22 ` Andy Lutomirski
2015-07-21 19:59 ` [PATCH v2 2/3] x86/ldt: Make modify_ldt optional Andy Lutomirski
2015-07-21 20:20 ` Sasha Levin
2015-07-21 20:27 ` Andy Lutomirski
2015-07-21 20:28 ` Brian Gerst
2015-07-21 20:34 ` Andy Lutomirski
2015-07-21 20:54 ` Brian Gerst
2015-07-22 6:06 ` Ingo Molnar [this message]
2015-07-22 6:23 ` Andy Lutomirski
2015-07-22 6:27 ` Ingo Molnar
2015-07-22 18:49 ` Andy Lutomirski
2015-07-22 12:34 ` Willy Tarreau
2015-07-21 19:59 ` [PATCH v2 3/3] selftests/x86, x86/ldt: Add a selftest for modify_ldt Andy Lutomirski
2015-07-21 22:02 ` Boris Ostrovsky
2015-07-21 22:34 ` Andy Lutomirski
2015-07-21 23:36 ` Willy Tarreau
2015-07-21 23:40 ` Andy Lutomirski
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=20150722060643.GA25466@gmail.com \
--to=mingo@kernel.org \
--cc=boris.ostrovsky@oracle.com \
--cc=bp@alien8.de \
--cc=brgerst@gmail.com \
--cc=konrad.wilk@oracle.com \
--cc=linux-kernel@vger.kernel.org \
--cc=luto@amacapital.net \
--cc=luto@kernel.org \
--cc=peterz@infradead.org \
--cc=rostedt@goodmis.org \
--cc=sasha.levin@oracle.com \
--cc=security@kernel.org \
--cc=x86@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.