All of lore.kernel.org
 help / color / mirror / Atom feed
From: Mark Rutland <mark.rutland@arm.com>
To: linux-arm-kernel@lists.infradead.org
Cc: linux-kernel@vger.kernel.org, catalin.marinas@arm.com,
	dave.martin@arm.com, james.morse@arm.com,
	linux@dominikbrodowski.net, linux-fsdevel@vger.kernel.org,
	marc.zyngier@arm.com, mark.rutland@arm.com,
	viro@zeniv.linux.org.uk, will.deacon@arm.com
Subject: [PATCH 00/18] arm64: invoke syscalls with pt_regs
Date: Mon, 14 May 2018 10:46:22 +0100	[thread overview]
Message-ID: <20180514094640.27569-1-mark.rutland@arm.com> (raw)

This series reworks arm64's syscall handling to minimize the propagation
of user-controlled register values into speculated code paths. As with
x86 [1], a wrapper is generated for each syscall, which extracts the
argument from a struct pt_regs. During kernel entry from userspace,
registers are zeroed.

The arm64 kernel code directly invokes some syscalls which the x86 code
doesn't, so I've added ksys_* wrappers for these, following the x86
example. The rest of the series is arm64-specific.

I've pushed the series out to my arm64/syscall-regs branch [2] on
kernel.org.

Thanks,
Mark.

[1] https://lkml.kernel.org/r/20180330093720.6780-1-linux@dominikbrodowski.net
[2] git://git.kernel.org/pub/scm/linux/kernel/git/mark/linux.git

Mark Rutland (18):
  arm64: consistently use unsigned long for thread flags
  arm64: move SCTLR_EL{1,2} assertions to <asm/sysreg.h>
  arm64: introduce sysreg_clear_set()
  arm64: kill config_sctlr_el1()
  arm64: kill change_cpacr()
  arm64: move sve_user_{enable,disable} to <asm/fpsimd.h>
  arm64: remove sigreturn wrappers
  arm64: convert raw syscall invocation to C
  arm64: convert syscall trace logic to C
  arm64: convert native/compat syscall entry to C
  arm64: zero GPRs upon entry from EL0
  kernel: add ksys_personality()
  kernel: add kcompat_sys_{f,}statfs64()
  arm64: remove in-kernel call to sys_personality()
  arm64: use {COMPAT,}SYSCALL_DEFINE0 for sigreturn
  arm64: use SYSCALL_DEFINE6() for mmap
  arm64: convert compat wrappers to C
  arm64: implement syscall wrappers

 arch/arm64/Kconfig                       |   1 +
 arch/arm64/include/asm/fpsimd.h          |  17 ++++-
 arch/arm64/include/asm/syscall_wrapper.h |  80 ++++++++++++++++++++
 arch/arm64/include/asm/sysreg.h          |  33 ++++----
 arch/arm64/include/asm/unistd32.h        |  26 +++----
 arch/arm64/kernel/Makefile               |   5 +-
 arch/arm64/kernel/armv8_deprecated.c     |   8 +-
 arch/arm64/kernel/cpu_errata.c           |   3 +-
 arch/arm64/kernel/entry.S                | 126 +++----------------------------
 arch/arm64/kernel/entry32.S              | 121 -----------------------------
 arch/arm64/kernel/fpsimd.c               |  20 -----
 arch/arm64/kernel/signal.c               |   5 +-
 arch/arm64/kernel/signal32.c             |   6 +-
 arch/arm64/kernel/sys.c                  |  19 +++--
 arch/arm64/kernel/sys32.c                | 116 ++++++++++++++++++++++++----
 arch/arm64/kernel/syscall.c              | 113 +++++++++++++++++++++++++++
 arch/arm64/kernel/traps.c                |   4 +-
 arch/arm64/mm/fault.c                    |   2 +-
 fs/statfs.c                              |  14 +++-
 include/linux/syscalls.h                 |   9 +++
 kernel/exec_domain.c                     |   7 +-
 21 files changed, 411 insertions(+), 324 deletions(-)
 create mode 100644 arch/arm64/include/asm/syscall_wrapper.h
 delete mode 100644 arch/arm64/kernel/entry32.S
 create mode 100644 arch/arm64/kernel/syscall.c

-- 
2.11.0

WARNING: multiple messages have this Message-ID (diff)
From: mark.rutland@arm.com (Mark Rutland)
To: linux-arm-kernel@lists.infradead.org
Subject: [PATCH 00/18] arm64: invoke syscalls with pt_regs
Date: Mon, 14 May 2018 10:46:22 +0100	[thread overview]
Message-ID: <20180514094640.27569-1-mark.rutland@arm.com> (raw)

This series reworks arm64's syscall handling to minimize the propagation
of user-controlled register values into speculated code paths. As with
x86 [1], a wrapper is generated for each syscall, which extracts the
argument from a struct pt_regs. During kernel entry from userspace,
registers are zeroed.

The arm64 kernel code directly invokes some syscalls which the x86 code
doesn't, so I've added ksys_* wrappers for these, following the x86
example. The rest of the series is arm64-specific.

I've pushed the series out to my arm64/syscall-regs branch [2] on
kernel.org.

Thanks,
Mark.

[1] https://lkml.kernel.org/r/20180330093720.6780-1-linux at dominikbrodowski.net
[2] git://git.kernel.org/pub/scm/linux/kernel/git/mark/linux.git

Mark Rutland (18):
  arm64: consistently use unsigned long for thread flags
  arm64: move SCTLR_EL{1,2} assertions to <asm/sysreg.h>
  arm64: introduce sysreg_clear_set()
  arm64: kill config_sctlr_el1()
  arm64: kill change_cpacr()
  arm64: move sve_user_{enable,disable} to <asm/fpsimd.h>
  arm64: remove sigreturn wrappers
  arm64: convert raw syscall invocation to C
  arm64: convert syscall trace logic to C
  arm64: convert native/compat syscall entry to C
  arm64: zero GPRs upon entry from EL0
  kernel: add ksys_personality()
  kernel: add kcompat_sys_{f,}statfs64()
  arm64: remove in-kernel call to sys_personality()
  arm64: use {COMPAT,}SYSCALL_DEFINE0 for sigreturn
  arm64: use SYSCALL_DEFINE6() for mmap
  arm64: convert compat wrappers to C
  arm64: implement syscall wrappers

 arch/arm64/Kconfig                       |   1 +
 arch/arm64/include/asm/fpsimd.h          |  17 ++++-
 arch/arm64/include/asm/syscall_wrapper.h |  80 ++++++++++++++++++++
 arch/arm64/include/asm/sysreg.h          |  33 ++++----
 arch/arm64/include/asm/unistd32.h        |  26 +++----
 arch/arm64/kernel/Makefile               |   5 +-
 arch/arm64/kernel/armv8_deprecated.c     |   8 +-
 arch/arm64/kernel/cpu_errata.c           |   3 +-
 arch/arm64/kernel/entry.S                | 126 +++----------------------------
 arch/arm64/kernel/entry32.S              | 121 -----------------------------
 arch/arm64/kernel/fpsimd.c               |  20 -----
 arch/arm64/kernel/signal.c               |   5 +-
 arch/arm64/kernel/signal32.c             |   6 +-
 arch/arm64/kernel/sys.c                  |  19 +++--
 arch/arm64/kernel/sys32.c                | 116 ++++++++++++++++++++++++----
 arch/arm64/kernel/syscall.c              | 113 +++++++++++++++++++++++++++
 arch/arm64/kernel/traps.c                |   4 +-
 arch/arm64/mm/fault.c                    |   2 +-
 fs/statfs.c                              |  14 +++-
 include/linux/syscalls.h                 |   9 +++
 kernel/exec_domain.c                     |   7 +-
 21 files changed, 411 insertions(+), 324 deletions(-)
 create mode 100644 arch/arm64/include/asm/syscall_wrapper.h
 delete mode 100644 arch/arm64/kernel/entry32.S
 create mode 100644 arch/arm64/kernel/syscall.c

-- 
2.11.0

             reply	other threads:[~2018-05-14  9:46 UTC|newest]

Thread overview: 126+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2018-05-14  9:46 Mark Rutland [this message]
2018-05-14  9:46 ` [PATCH 00/18] arm64: invoke syscalls with pt_regs Mark Rutland
2018-05-14  9:46 ` [PATCH 01/18] arm64: consistently use unsigned long for thread flags Mark Rutland
2018-05-14  9:46   ` Mark Rutland
2018-05-14  9:57   ` Dave Martin
2018-05-14  9:57     ` Dave Martin
2018-05-14  9:46 ` [PATCH 02/18] arm64: move SCTLR_EL{1,2} assertions to <asm/sysreg.h> Mark Rutland
2018-05-14  9:46   ` Mark Rutland
2018-05-14 10:00   ` Dave Martin
2018-05-14 10:00     ` Dave Martin
2018-05-14 10:08     ` Mark Rutland
2018-05-14 10:08       ` Mark Rutland
2018-05-14 11:20       ` Dave Martin
2018-05-14 11:20         ` Dave Martin
2018-05-14 11:56         ` Robin Murphy
2018-05-14 11:56           ` Robin Murphy
2018-05-14 12:06           ` Mark Rutland
2018-05-14 12:06             ` Mark Rutland
2018-05-14 12:41             ` Dave Martin
2018-05-14 12:41               ` Dave Martin
2018-05-14 13:10               ` Mark Rutland
2018-05-14 13:10                 ` Mark Rutland
2018-05-14  9:46 ` [PATCH 03/18] arm64: introduce sysreg_clear_set() Mark Rutland
2018-05-14  9:46   ` Mark Rutland
2018-05-14 10:04   ` Dave Martin
2018-05-14 10:04     ` Dave Martin
2018-05-14  9:46 ` [PATCH 04/18] arm64: kill config_sctlr_el1() Mark Rutland
2018-05-14  9:46   ` Mark Rutland
2018-05-14 10:05   ` Dave Martin
2018-05-14 10:05     ` Dave Martin
2018-05-14  9:46 ` [PATCH 05/18] arm64: kill change_cpacr() Mark Rutland
2018-05-14  9:46   ` Mark Rutland
2018-05-14 10:06   ` Dave Martin
2018-05-14 10:06     ` Dave Martin
2018-05-14  9:46 ` [PATCH 06/18] arm64: move sve_user_{enable,disable} to <asm/fpsimd.h> Mark Rutland
2018-05-14  9:46   ` [PATCH 06/18] arm64: move sve_user_{enable, disable} " Mark Rutland
2018-05-14 11:06   ` Dave Martin
2018-05-14 11:06     ` Dave Martin
2018-05-15 10:39     ` Mark Rutland
2018-05-15 10:39       ` Mark Rutland
2018-05-15 12:19       ` Dave Martin
2018-05-15 12:19         ` Dave Martin
2018-05-15 16:33         ` Mark Rutland
2018-05-15 16:33           ` Mark Rutland
2018-05-16  9:01           ` Dave Martin
2018-05-16  9:01             ` Dave Martin
2018-06-01 10:29             ` Mark Rutland
2018-06-01 10:29               ` Mark Rutland
2018-06-01 10:42               ` Dave Martin
2018-06-01 10:42                 ` Dave Martin
2018-05-14  9:46 ` [PATCH 07/18] arm64: remove sigreturn wrappers Mark Rutland
2018-05-14  9:46   ` Mark Rutland
2018-05-14 11:07   ` Dave Martin
2018-05-14 11:07     ` Dave Martin
2018-05-14  9:46 ` [PATCH 08/18] arm64: convert raw syscall invocation to C Mark Rutland
2018-05-14  9:46   ` Mark Rutland
2018-05-14 11:07   ` Dave Martin
2018-05-14 11:07     ` Dave Martin
2018-05-14 11:41     ` Mark Rutland
2018-05-14 11:41       ` Mark Rutland
2018-05-14 12:53       ` Dave Martin
2018-05-14 12:53         ` Dave Martin
2018-05-14 20:24       ` Dominik Brodowski
2018-05-14 20:24         ` Dominik Brodowski
2018-05-15  8:22         ` Mark Rutland
2018-05-15  8:22           ` Mark Rutland
2018-05-15 10:01           ` Dominik Brodowski
2018-05-15 10:01             ` Dominik Brodowski
2018-05-15 10:13             ` Mark Rutland
2018-05-15 10:13               ` Mark Rutland
2018-05-14 18:00   ` Dominik Brodowski
2018-05-14 18:00     ` Dominik Brodowski
2018-05-15  8:18     ` Mark Rutland
2018-05-15  8:18       ` Mark Rutland
2018-05-14  9:46 ` [PATCH 09/18] arm64: convert syscall trace logic " Mark Rutland
2018-05-14  9:46   ` Mark Rutland
2018-05-14  9:46 ` [PATCH 10/18] arm64: convert native/compat syscall entry " Mark Rutland
2018-05-14  9:46   ` Mark Rutland
2018-05-14 11:07   ` Dave Martin
2018-05-14 11:07     ` Dave Martin
2018-05-14 11:58     ` Mark Rutland
2018-05-14 11:58       ` Mark Rutland
2018-05-14 14:43       ` Dave Martin
2018-05-14 14:43         ` Dave Martin
2018-05-14 15:01         ` Mark Rutland
2018-05-14 15:01           ` Mark Rutland
2018-05-14  9:46 ` [PATCH 11/18] arm64: zero GPRs upon entry from EL0 Mark Rutland
2018-05-14  9:46   ` Mark Rutland
2018-05-14 11:07   ` Dave Martin
2018-05-14 11:07     ` Dave Martin
2018-05-14  9:46 ` [PATCH 12/18] kernel: add ksys_personality() Mark Rutland
2018-05-14  9:46   ` Mark Rutland
2018-05-14 11:08   ` Dave Martin
2018-05-14 11:08     ` Dave Martin
2018-05-14 12:07   ` Christoph Hellwig
2018-05-14 12:07     ` Christoph Hellwig
2018-05-15  9:56     ` Mark Rutland
2018-05-15  9:56       ` Mark Rutland
2018-05-14  9:46 ` [PATCH 13/18] kernel: add kcompat_sys_{f,}statfs64() Mark Rutland
2018-05-14  9:46   ` Mark Rutland
2018-05-14 17:14   ` Mark Rutland
2018-05-14 17:14     ` Mark Rutland
2018-05-14 20:34     ` Dominik Brodowski
2018-05-14 20:34       ` Dominik Brodowski
2018-05-15  9:53       ` Mark Rutland
2018-05-15  9:53         ` Mark Rutland
2018-05-15  9:58         ` Dominik Brodowski
2018-05-15  9:58           ` Dominik Brodowski
2018-05-14  9:46 ` [PATCH 14/18] arm64: remove in-kernel call to sys_personality() Mark Rutland
2018-05-14  9:46   ` Mark Rutland
2018-05-14  9:46 ` [PATCH 15/18] arm64: use {COMPAT,}SYSCALL_DEFINE0 for sigreturn Mark Rutland
2018-05-14  9:46   ` Mark Rutland
2018-05-14  9:46 ` [PATCH 16/18] arm64: use SYSCALL_DEFINE6() for mmap Mark Rutland
2018-05-14  9:46   ` Mark Rutland
2018-05-14  9:46 ` [PATCH 17/18] arm64: convert compat wrappers to C Mark Rutland
2018-05-14  9:46   ` Mark Rutland
2018-05-14 12:10   ` Christoph Hellwig
2018-05-14 12:10     ` Christoph Hellwig
2018-05-14 12:43     ` Mark Rutland
2018-05-14 12:43       ` Mark Rutland
2018-05-14  9:46 ` [PATCH 18/18] arm64: implement syscall wrappers Mark Rutland
2018-05-14  9:46   ` Mark Rutland
2018-05-14 20:57   ` Dominik Brodowski
2018-05-14 20:57     ` Dominik Brodowski
2018-05-15  8:37     ` Mark Rutland
2018-05-15  8:37       ` Mark Rutland

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=20180514094640.27569-1-mark.rutland@arm.com \
    --to=mark.rutland@arm.com \
    --cc=catalin.marinas@arm.com \
    --cc=dave.martin@arm.com \
    --cc=james.morse@arm.com \
    --cc=linux-arm-kernel@lists.infradead.org \
    --cc=linux-fsdevel@vger.kernel.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=linux@dominikbrodowski.net \
    --cc=marc.zyngier@arm.com \
    --cc=viro@zeniv.linux.org.uk \
    --cc=will.deacon@arm.com \
    /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.