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) |