diff options
| -rw-r--r-- | arch/x86/kernel/dumpstack.c | 28 |
1 files changed, 9 insertions, 19 deletions
diff --git a/arch/x86/kernel/dumpstack.c b/arch/x86/kernel/dumpstack.c index 666a284116ac..9c8652974f8e 100644 --- a/arch/x86/kernel/dumpstack.c +++ b/arch/x86/kernel/dumpstack.c | |||
| @@ -22,8 +22,6 @@ | |||
| 22 | #include <asm/stacktrace.h> | 22 | #include <asm/stacktrace.h> |
| 23 | #include <asm/unwind.h> | 23 | #include <asm/unwind.h> |
| 24 | 24 | ||
| 25 | #define OPCODE_BUFSIZE 64 | ||
| 26 | |||
| 27 | int panic_on_unrecovered_nmi; | 25 | int panic_on_unrecovered_nmi; |
| 28 | int panic_on_io_nmi; | 26 | int panic_on_io_nmi; |
| 29 | static int die_counter; | 27 | static int die_counter; |
| @@ -93,26 +91,18 @@ static void printk_stack_address(unsigned long address, int reliable, | |||
| 93 | */ | 91 | */ |
| 94 | void show_opcodes(u8 *rip, const char *loglvl) | 92 | void show_opcodes(u8 *rip, const char *loglvl) |
| 95 | { | 93 | { |
| 96 | unsigned int code_prologue = OPCODE_BUFSIZE * 2 / 3; | 94 | #define PROLOGUE_SIZE 42 |
| 95 | #define EPILOGUE_SIZE 21 | ||
| 96 | #define OPCODE_BUFSIZE (PROLOGUE_SIZE + 1 + EPILOGUE_SIZE) | ||
| 97 | u8 opcodes[OPCODE_BUFSIZE]; | 97 | u8 opcodes[OPCODE_BUFSIZE]; |
| 98 | u8 *ip; | ||
| 99 | int i; | ||
| 100 | |||
| 101 | printk("%sCode: ", loglvl); | ||
| 102 | |||
| 103 | ip = (u8 *)rip - code_prologue; | ||
| 104 | if (probe_kernel_read(opcodes, ip, OPCODE_BUFSIZE)) { | ||
| 105 | pr_cont("Bad RIP value.\n"); | ||
| 106 | return; | ||
| 107 | } | ||
| 108 | 98 | ||
| 109 | for (i = 0; i < OPCODE_BUFSIZE; i++, ip++) { | 99 | if (probe_kernel_read(opcodes, rip - PROLOGUE_SIZE, OPCODE_BUFSIZE)) { |
| 110 | if (ip == rip) | 100 | printk("%sCode: Bad RIP value.\n", loglvl); |
| 111 | pr_cont("<%02x> ", opcodes[i]); | 101 | } else { |
| 112 | else | 102 | printk("%sCode: %" __stringify(PROLOGUE_SIZE) "ph <%02x> %" |
| 113 | pr_cont("%02x ", opcodes[i]); | 103 | __stringify(EPILOGUE_SIZE) "ph\n", loglvl, opcodes, |
| 104 | opcodes[PROLOGUE_SIZE], opcodes + PROLOGUE_SIZE + 1); | ||
| 114 | } | 105 | } |
| 115 | pr_cont("\n"); | ||
| 116 | } | 106 | } |
| 117 | 107 | ||
| 118 | void show_ip(struct pt_regs *regs, const char *loglvl) | 108 | void show_ip(struct pt_regs *regs, const char *loglvl) |
