diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2017-08-26 12:06:28 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2017-08-26 12:06:28 -0400 |
commit | c153e62105c3124d7aee0a1fa563df8b8e995078 (patch) | |
tree | 432e2df9b427863f9d0e3f12e175f6f6aeab4656 /tools | |
parent | 0adb8f3d312966bd3e712248b48098ce086d03bd (diff) | |
parent | ccd5b3235180eef3cfec337df1c8554ab151b5cc (diff) |
Merge branch 'x86-urgent-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip
Pull x86 fixes from Ingo Molnar:
"Two fixes: one for an ldt_struct handling bug and a cherry-picked
objtool fix"
* 'x86-urgent-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip:
x86/mm: Fix use-after-free of ldt_struct
objtool: Fix '-mtune=atom' decoding support in objtool 2.0
Diffstat (limited to 'tools')
-rw-r--r-- | tools/objtool/arch/x86/decode.c | 26 |
1 files changed, 25 insertions, 1 deletions
diff --git a/tools/objtool/arch/x86/decode.c b/tools/objtool/arch/x86/decode.c index a36c2eba64e7..4559a21a8de2 100644 --- a/tools/objtool/arch/x86/decode.c +++ b/tools/objtool/arch/x86/decode.c | |||
@@ -271,7 +271,7 @@ int arch_decode_instruction(struct elf *elf, struct section *sec, | |||
271 | case 0x8d: | 271 | case 0x8d: |
272 | if (rex == 0x48 && modrm == 0x65) { | 272 | if (rex == 0x48 && modrm == 0x65) { |
273 | 273 | ||
274 | /* lea -disp(%rbp), %rsp */ | 274 | /* lea disp(%rbp), %rsp */ |
275 | *type = INSN_STACK; | 275 | *type = INSN_STACK; |
276 | op->src.type = OP_SRC_ADD; | 276 | op->src.type = OP_SRC_ADD; |
277 | op->src.reg = CFI_BP; | 277 | op->src.reg = CFI_BP; |
@@ -281,6 +281,30 @@ int arch_decode_instruction(struct elf *elf, struct section *sec, | |||
281 | break; | 281 | break; |
282 | } | 282 | } |
283 | 283 | ||
284 | if (rex == 0x48 && (modrm == 0xa4 || modrm == 0x64) && | ||
285 | sib == 0x24) { | ||
286 | |||
287 | /* lea disp(%rsp), %rsp */ | ||
288 | *type = INSN_STACK; | ||
289 | op->src.type = OP_SRC_ADD; | ||
290 | op->src.reg = CFI_SP; | ||
291 | op->src.offset = insn.displacement.value; | ||
292 | op->dest.type = OP_DEST_REG; | ||
293 | op->dest.reg = CFI_SP; | ||
294 | break; | ||
295 | } | ||
296 | |||
297 | if (rex == 0x48 && modrm == 0x2c && sib == 0x24) { | ||
298 | |||
299 | /* lea (%rsp), %rbp */ | ||
300 | *type = INSN_STACK; | ||
301 | op->src.type = OP_SRC_REG; | ||
302 | op->src.reg = CFI_SP; | ||
303 | op->dest.type = OP_DEST_REG; | ||
304 | op->dest.reg = CFI_BP; | ||
305 | break; | ||
306 | } | ||
307 | |||
284 | if (rex == 0x4c && modrm == 0x54 && sib == 0x24 && | 308 | if (rex == 0x4c && modrm == 0x54 && sib == 0x24 && |
285 | insn.displacement.value == 8) { | 309 | insn.displacement.value == 8) { |
286 | 310 | ||