From: Andy Lutomirski <luto@kernel.org>
To: X86 ML <x86@kernel.org>
Cc: Borislav Petkov <bpetkov@suse.de>,
"linux-kernel@vger.kernel.org" <linux-kernel@vger.kernel.org>,
Brian Gerst <brgerst@gmail.com>,
Dave Hansen <dave.hansen@intel.com>,
Linus Torvalds <torvalds@linux-foundation.org>,
Josh Poimboeuf <jpoimboe@redhat.com>,
Andy Lutomirski <luto@kernel.org>
Subject: [PATCH 00/16] Entry stuff, in decent shape now
Date: Mon, 20 Nov 2017 09:07:31 -0800 [thread overview]
Message-ID: <cover.1511195781.git.luto@kernel.org> (raw)
This sets up stack switching, including for SYSCALL. I think it's
in decent shape.
Known issues:
- KASAN is likely to be busted. This could be fixed either by teaching
KASAN that cpu_entry_area contains valid stacks (I have no clue how
to go about doing this) or by rigging up the IST entry code to switch
RSP to point to the direct-mapped copy of the stacks before calling
into non-KASAN-excluded C code.
- 32-bit kernels are failing the sigreturn_32 test. But they're also
failing without the patches, so I'm not sure this is a bug in the
series per se. Needs further investigation. (Off the top of my head,
this could be further fallout from Thomas's IDT rework.)
- I think we're going to want a way to turn the stack switching on and
off either at boot time or at runtime. It should be fairly straightforward
to make it work.
- I think the ORC unwinder isn't so good at dealing with stack overflows.
It bails too early (I think), resulting in lots of ? entries. This
isn't a regression with this series -- it's just something that could
be improved.
Changes:
- This is quite massively changed from last time.
- 32-bit seems to build and mostly work
- KASAN is less broken now
Andy Lutomirski (16):
x86/asm/64: Allocate and enable the SYSENTER stack
x86/dumpstack: Add get_stack_info() support for the SYSENTER stack
x86/gdt: Put per-cpu GDT remaps in ascending order
x86/fixmap: Generalize the GDT fixmap mechanism
x86/asm: Fix assumptions that the HW TSS is at the beginning of
cpu_tss
x86/dumpstack: Handle stack overflow on all stacks
x86/asm: Move SYSENTER_stack to the beginning of struct tss_struct
x86/asm: Remap the TSS into the cpu entry area
x86/asm/64: Separate cpu_current_top_of_stack from TSS.sp0
x86/espfix/64: Stop assuming that pt_regs is on the entry stack
x86/asm/64: Use a percpu trampoline stack for IDT entries
x86/asm/64: Return to userspace from the trampoline stack
x86/entry/64: Create a percpu SYSCALL entry trampoline
x86/irq: Remove an old outdated comment about context tracking races
x86/irq/64: In the stack overflow warning, print the offending IP
x86/entry/64: Move the IST stacks into cpu_entry_area
arch/x86/entry/entry_32.S | 6 +-
arch/x86/entry/entry_64.S | 177 +++++++++++++++++++++++++++++++++----
arch/x86/entry/entry_64_compat.S | 6 +-
arch/x86/include/asm/desc.h | 11 +--
arch/x86/include/asm/fixmap.h | 55 +++++++++++-
arch/x86/include/asm/processor.h | 49 ++++++----
arch/x86/include/asm/stacktrace.h | 3 +
arch/x86/include/asm/switch_to.h | 2 +-
arch/x86/include/asm/thread_info.h | 2 +-
arch/x86/include/asm/traps.h | 1 -
arch/x86/kernel/asm-offsets.c | 9 ++
arch/x86/kernel/asm-offsets_32.c | 5 --
arch/x86/kernel/asm-offsets_64.c | 1 +
arch/x86/kernel/cpu/common.c | 136 +++++++++++++++++++++-------
arch/x86/kernel/doublefault.c | 36 ++++----
arch/x86/kernel/dumpstack.c | 46 +++++++---
arch/x86/kernel/dumpstack_32.c | 6 ++
arch/x86/kernel/dumpstack_64.c | 6 ++
arch/x86/kernel/irq.c | 12 ---
arch/x86/kernel/irq_64.c | 4 +-
arch/x86/kernel/process.c | 12 ++-
arch/x86/kernel/process_64.c | 1 +
arch/x86/kernel/traps.c | 25 +++---
arch/x86/kernel/vmlinux.lds.S | 10 +++
arch/x86/power/cpu.c | 16 ++--
arch/x86/xen/mmu_pv.c | 2 +-
26 files changed, 487 insertions(+), 152 deletions(-)
--
2.13.6
next reply other threads:[~2017-11-20 17:07 UTC|newest]
Thread overview: 52+ messages / expand[flat|nested] mbox.gz Atom feed top
2017-11-20 17:07 Andy Lutomirski [this message]
2017-11-20 17:07 ` [PATCH 01/16] x86/asm/64: Allocate and enable the SYSENTER stack Andy Lutomirski
2017-11-20 21:55 ` Thomas Gleixner
2017-11-21 10:47 ` Borislav Petkov
2017-11-20 17:07 ` [PATCH 02/16] x86/dumpstack: Add get_stack_info() support for " Andy Lutomirski
2017-11-20 20:42 ` Josh Poimboeuf
2017-11-20 20:46 ` Andy Lutomirski
2017-11-20 21:00 ` Josh Poimboeuf
2017-11-20 21:07 ` Andy Lutomirski
2017-11-20 21:27 ` Josh Poimboeuf
2017-11-20 21:30 ` Andy Lutomirski
2017-11-20 21:55 ` Josh Poimboeuf
2017-11-21 1:39 ` Andy Lutomirski
2017-11-21 2:29 ` Josh Poimboeuf
2017-11-20 17:07 ` [PATCH 03/16] x86/gdt: Put per-cpu GDT remaps in ascending order Andy Lutomirski
2017-11-20 21:56 ` Thomas Gleixner
2017-11-21 17:16 ` Borislav Petkov
2017-11-20 17:07 ` [PATCH 04/16] x86/fixmap: Generalize the GDT fixmap mechanism Andy Lutomirski
2017-11-20 22:01 ` Thomas Gleixner
2017-11-21 1:21 ` Andy Lutomirski
2017-11-21 8:29 ` Thomas Gleixner
2017-11-20 17:07 ` [PATCH 05/16] x86/asm: Fix assumptions that the HW TSS is at the beginning of cpu_tss Andy Lutomirski
2017-11-20 22:22 ` Thomas Gleixner
2017-11-20 17:07 ` [PATCH 06/16] x86/dumpstack: Handle stack overflow on all stacks Andy Lutomirski
2017-11-20 17:07 ` [PATCH 07/16] x86/asm: Move SYSENTER_stack to the beginning of struct tss_struct Andy Lutomirski
2017-11-20 23:37 ` Thomas Gleixner
2017-11-21 1:25 ` Andy Lutomirski
2017-11-20 17:07 ` [PATCH 08/16] x86/asm: Remap the TSS into the cpu entry area Andy Lutomirski
2017-11-20 17:07 ` [PATCH 09/16] x86/asm/64: Separate cpu_current_top_of_stack from TSS.sp0 Andy Lutomirski
2017-11-20 17:07 ` [PATCH 10/16] x86/espfix/64: Stop assuming that pt_regs is on the entry stack Andy Lutomirski
2017-11-20 17:07 ` [PATCH 11/16] x86/asm/64: Use a percpu trampoline stack for IDT entries Andy Lutomirski
2017-11-21 7:20 ` Ingo Molnar
2017-11-21 15:36 ` Andy Lutomirski
2017-11-21 18:57 ` Dave Hansen
2017-11-22 3:45 ` Andy Lutomirski
2017-11-20 17:07 ` [PATCH 12/16] x86/asm/64: Return to userspace from the trampoline stack Andy Lutomirski
2017-11-20 17:07 ` [PATCH 13/16] x86/entry/64: Create a percpu SYSCALL entry trampoline Andy Lutomirski
2017-11-21 2:34 ` Josh Poimboeuf
2017-11-21 3:20 ` Andy Lutomirski
2017-11-20 17:07 ` [PATCH 14/16] x86/irq: Remove an old outdated comment about context tracking races Andy Lutomirski
2017-11-21 6:25 ` Ingo Molnar
2017-11-20 17:07 ` [PATCH 15/16] x86/irq/64: In the stack overflow warning, print the offending IP Andy Lutomirski
2017-11-21 6:26 ` Ingo Molnar
2017-11-20 17:07 ` [PATCH 16/16] x86/entry/64: Move the IST stacks into cpu_entry_area Andy Lutomirski
2017-11-21 7:38 ` Ingo Molnar
2017-11-21 14:45 ` Andrey Ryabinin
2017-11-23 15:25 ` Andy Lutomirski
2017-11-21 15:33 ` Andy Lutomirski
2017-11-20 18:48 ` [PATCH 00/16] Entry stuff, in decent shape now Andy Lutomirski
2017-11-21 7:33 ` Ingo Molnar
2017-11-21 15:59 ` Andy Lutomirski
2017-11-21 16:12 ` 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=cover.1511195781.git.luto@kernel.org \
--to=luto@kernel.org \
--cc=bpetkov@suse.de \
--cc=brgerst@gmail.com \
--cc=dave.hansen@intel.com \
--cc=jpoimboe@redhat.com \
--cc=linux-kernel@vger.kernel.org \
--cc=torvalds@linux-foundation.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.