On 11/06/2015 12:57 PM, Tony Luck wrote:
Copy the existing page fault fixup mechanisms to create a new table
to be used when fixing machine checks. Note:
1) At this time we only provide a macro to annotate assembly code
2) We assume all fixups will in code builtin to the kernel.

Shouldn't the first step be to fixup failures during user memory access?


Signed-off-by: Tony Luck <[email protected]>
---
  arch/x86/include/asm/asm.h        |  7 +++++++
  arch/x86/include/asm/uaccess.h    |  1 +
  arch/x86/mm/extable.c             | 16 ++++++++++++++++
  include/asm-generic/vmlinux.lds.h |  6 ++++++
  include/linux/module.h            |  1 +
  kernel/extable.c                  | 14 ++++++++++++++
  6 files changed, 45 insertions(+)

diff --git a/arch/x86/include/asm/asm.h b/arch/x86/include/asm/asm.h
index 189679aba703..f2fa7973f18f 100644
--- a/arch/x86/include/asm/asm.h
+++ b/arch/x86/include/asm/asm.h
@@ -58,6 +58,13 @@
        .long (to) - . + 0x7ffffff0 ;                           \
        .popsection

+# define _ASM_MCEXTABLE(from, to)                              \
+       .pushsection "__mcex_table", "a" ;                  \
+       .balign 8 ;                                             \
+       .long (from) - . ;                                      \
+       .long (to) - . ;                                        \
+       .popsection
+

This does something really weird to rax. (Also, what happens on 32-bit kernels? There's no bit 63.)

Please at least document it clearly.

--Andy
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to [email protected]
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to