Jann Horn
75045f77f7
x86/extable: Introduce _ASM_EXTABLE_UA for uaccess fixups
...
Currently, most fixups for attempting to access userspace memory are
handled using _ASM_EXTABLE, which is also used for various other types of
fixups (e.g. safe MSR access, IRET failures, and a bunch of other things).
In order to make it possible to add special safety checks to uaccess fixups
(in particular, checking whether the fault address is actually in
userspace), introduce a new exception table handler ex_handler_uaccess()
and wire it up to all the user access fixups (excluding ones that
already use _ASM_EXTABLE_EX).
Signed-off-by: Jann Horn <jannh@google.com>
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Tested-by: Kees Cook <keescook@chromium.org>
Cc: Andy Lutomirski <luto@kernel.org>
Cc: kernel-hardening@lists.openwall.com
Cc: dvyukov@google.com
Cc: Masami Hiramatsu <mhiramat@kernel.org>
Cc: "Naveen N. Rao" <naveen.n.rao@linux.vnet.ibm.com>
Cc: Anil S Keshavamurthy <anil.s.keshavamurthy@intel.com>
Cc: "David S. Miller" <davem@davemloft.net>
Cc: Alexander Viro <viro@zeniv.linux.org.uk>
Cc: linux-fsdevel@vger.kernel.org
Cc: Borislav Petkov <bp@alien8.de>
Link: https://lkml.kernel.org/r/20180828201421.157735-5-jannh@google.com
2018-09-03 15:12:09 +02:00
..
2018-03-03 00:03:35 +08:00
2017-11-02 11:10:55 +01:00
2018-09-03 15:12:09 +02:00
2018-08-19 10:38:36 -07:00
2018-03-28 20:19:45 +02:00
2018-08-20 14:46:18 -04:00
2017-03-02 08:42:37 +01:00
2018-03-12 12:32:57 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2018-03-27 09:47:53 +02:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2018-08-05 09:53:13 +02:00
2017-11-02 11:10:55 +01:00
2018-07-16 17:59:57 +02:00
2017-11-02 11:10:55 +01:00
2017-09-24 11:19:01 +02:00
2018-02-20 09:38:26 +01:00
2018-09-03 15:12:09 +02:00
2018-06-21 14:25:24 +02:00
2018-07-25 11:53:59 +02:00
2018-07-25 11:53:59 +02:00
2018-06-21 16:00:21 +02:00
2017-11-02 11:10:55 +01:00
2018-02-28 15:18:41 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2018-02-15 01:15:50 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2018-05-06 12:49:15 +02:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2018-03-12 12:15:35 +01:00
2018-07-25 11:53:58 +02:00
2018-07-25 11:53:59 +02:00
2018-04-20 16:19:52 +02:00
2017-11-02 11:10:55 +01:00
2017-12-23 21:13:00 +01:00
2017-11-02 11:10:55 +01:00
2018-05-13 21:49:14 +02:00
2018-08-14 09:46:06 -07:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-12-29 17:02:49 -08:00
2018-03-20 10:01:57 +01:00
2018-01-30 15:08:27 +01:00
2017-11-02 11:10:55 +01:00
2018-03-20 10:01:59 +01:00
2018-05-28 12:48:25 +02:00
2017-11-02 11:10:55 +01:00
2018-08-05 09:53:13 +02:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2018-03-12 11:05:05 +01:00
2017-11-16 11:43:11 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2018-01-12 17:33:38 -08:00
2017-12-22 20:13:05 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2018-01-30 15:30:35 +01:00
2016-12-18 09:25:38 +01:00
2017-11-02 11:10:55 +01:00
2018-05-19 13:55:40 +02:00
2018-09-03 15:12:09 +02:00
2017-11-02 11:10:55 +01:00
2018-08-05 09:53:13 +02:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2018-06-26 09:07:58 +02:00
2018-03-28 10:40:55 +02:00
2018-08-19 10:38:36 -07:00
2018-01-14 21:11:54 +01:00
2018-08-15 13:44:10 -07:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-01 21:50:11 +01:00
2017-11-02 11:10:55 +01:00
2017-11-23 20:17:59 +01:00
2018-05-13 19:52:55 +02:00
2017-11-02 11:10:55 +01:00
2018-07-25 11:50:50 +02:00
2018-05-19 14:03:14 +02:00
2018-03-12 12:10:54 +01:00
2017-11-27 13:39:11 +02:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2018-07-03 13:08:20 +02:00
2018-07-03 13:08:21 +02:00
2017-12-22 20:13:04 +01:00
2018-02-17 11:47:45 +01:00
2018-05-18 09:11:26 +02:00
2017-11-02 11:10:55 +01:00
2018-03-20 10:01:56 +01:00
2017-12-04 10:56:53 +10:00
2017-11-02 11:10:55 +01:00
2018-07-06 14:43:47 +02:00
2018-04-26 11:57:57 +02:00
2017-11-02 11:10:55 +01:00
2017-11-07 10:51:10 +01:00
2017-12-29 21:13:04 +01:00
2018-08-30 11:37:09 +02:00
2018-04-23 10:17:28 +02:00
2017-11-02 11:10:55 +01:00
2018-02-06 18:32:43 -08:00
2018-02-14 13:11:13 +01:00
2017-11-02 11:10:55 +01:00
2018-08-22 10:52:47 -07:00
2017-12-17 13:59:52 +01:00
2018-04-13 17:10:27 -07:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2018-06-21 12:33:13 +02:00
2018-06-12 15:06:34 +02:00
2018-08-19 10:38:36 -07:00
2017-11-02 11:10:55 +01:00
2018-07-20 00:02:36 +02:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2018-05-19 14:03:14 +02:00
2018-08-20 18:04:42 +02:00
2018-05-22 23:18:31 -07:00
2018-03-20 10:01:58 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2018-04-02 15:16:43 -07:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2018-07-20 01:11:48 +02:00
2017-12-22 20:13:01 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-12-17 12:58:53 +01:00
2018-01-14 21:11:54 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2018-08-19 10:38:36 -07:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2018-08-05 17:10:19 +02:00
2017-11-02 11:10:55 +01:00
2018-04-02 16:18:31 -07:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2018-08-03 12:50:34 +02:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-07-26 13:18:20 +02:00
2018-06-21 16:34:56 +02:00
2018-06-20 19:09:59 +02:00
2017-11-02 11:10:55 +01:00
2018-05-19 11:56:57 +02:00
2018-04-02 15:45:30 -07:00
2018-06-06 13:38:01 +02:00
2017-11-02 11:10:55 +01:00
2018-08-23 11:56:31 -07:00
2018-08-23 11:56:31 -07:00
2017-11-02 11:10:55 +01:00
2018-01-16 16:40:09 +01:00
2017-11-02 11:10:55 +01:00
2018-03-08 12:30:38 +01:00
2018-06-29 20:06:07 -05:00
2017-11-02 11:10:55 +01:00
2018-05-07 07:15:41 +02:00
2018-06-21 15:21:47 +02:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2018-06-26 09:21:48 +02:00
2018-07-20 01:11:47 +02:00
2018-07-20 01:11:42 +02:00
2018-07-20 01:11:47 +02:00
2018-08-14 09:46:06 -07:00
2018-07-20 01:11:42 +02:00
2018-07-20 01:11:42 +02:00
2018-08-14 09:46:06 -07:00
2018-07-20 01:11:42 +02:00
2018-08-27 14:20:49 -04:00
2018-08-17 10:27:36 -07:00
2018-08-14 09:46:06 -07:00
2018-06-07 10:23:33 -07:00
2018-03-01 16:22:48 +00:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2018-07-20 01:11:44 +02:00
2018-08-27 10:29:14 +02:00
2017-11-02 11:10:55 +01:00
2018-07-20 01:11:45 +02:00
2017-12-17 12:58:53 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2018-05-19 14:03:14 +02:00
2017-11-02 11:10:55 +01:00
2018-07-25 11:22:20 +02:00
2018-04-27 09:48:51 +02:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2018-06-21 18:22:02 +02:00
2018-02-16 10:48:49 +01:00
2017-11-02 11:10:55 +01:00
2018-02-20 09:33:39 +01:00
2017-11-07 10:32:44 +01:00
2017-11-02 11:10:55 +01:00
2018-07-20 01:11:44 +02:00
2018-06-14 12:21:18 +09:00
2017-11-02 11:10:55 +01:00
2018-08-25 18:43:59 -07:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2018-08-30 13:02:31 +02:00
2017-11-02 11:10:55 +01:00
2018-05-06 12:49:14 +02:00
2018-05-19 11:56:57 +02:00
2018-05-17 17:09:21 +02:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-07 10:32:44 +01:00
2017-11-02 11:10:55 +01:00
2018-06-14 12:21:18 +09:00
2018-08-31 17:08:22 +02:00
2017-11-15 18:21:05 -08:00
2018-05-15 08:32:42 +02:00
2017-11-02 11:10:55 +01:00
2017-12-15 12:21:38 +01:00
2017-12-15 12:21:38 +01:00
2017-11-02 11:10:55 +01:00
2018-03-28 22:47:06 +02:00
2018-03-20 10:01:57 +01:00
2018-07-20 01:11:40 +02:00
2017-11-02 11:10:55 +01:00
2018-02-05 21:34:57 +01:00
2018-04-09 16:47:28 +02:00
2018-04-05 16:59:38 +02:00
2018-04-09 16:47:28 +02:00
2018-07-20 00:02:38 +02:00
2018-05-09 21:41:38 +02:00
2017-11-02 11:10:55 +01:00
2017-11-13 19:07:38 -08:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2018-08-31 17:08:22 +02:00
2018-06-21 14:20:57 +02:00
2017-11-02 11:10:55 +01:00
2018-01-19 16:31:28 +01:00
2018-07-20 00:02:44 +02:00
2018-01-30 21:54:31 +01:00
2018-07-16 00:05:05 +02:00
2018-09-03 15:12:09 +02:00
2017-11-08 11:16:22 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2018-06-21 16:34:56 +02:00
2018-01-03 16:14:46 +01:00
2017-12-11 18:42:11 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2018-09-01 23:01:56 +02:00
2017-11-02 11:10:55 +01:00
2018-08-22 16:48:35 +02:00
2017-12-23 21:13:00 +01:00
2017-11-02 11:10:55 +01:00
2018-06-10 09:44:53 -07:00
2017-11-02 11:10:55 +01:00
2017-11-15 18:21:04 -08:00