summaryrefslogtreecommitdiffstats
path: root/arch/x86/tools/insn_sanity.c
diff options
context:
space:
mode:
authorMasami Hiramatsu <masami.hiramatsu.pt@hitachi.com>2011-12-05 13:05:39 +0100
committerIngo Molnar <mingo@elte.hu>2011-12-05 14:53:15 +0100
commit130b78b2bf16d5d89091db38374faef896360cf9 (patch)
tree46f1f553aba35de8e2ffea42128e2237da479dc6 /arch/x86/tools/insn_sanity.c
parentx86/tools: Fix Makefile to build all test tools (diff)
downloadlinux-130b78b2bf16d5d89091db38374faef896360cf9.tar.xz
linux-130b78b2bf16d5d89091db38374faef896360cf9.zip
x86: Fix instruction decoder to handle grouped AVX instructions
For reducing memory usage of attribute table, x86 instruction decoder puts "Group" attribute only on "no-last-prefix" attribute table (same as vex_p == 0 case). Thus, the decoder should look no-last-prefix table first, and then only if it is not a group, move on to "with-last-prefix" table (vex_p != 0). However, current implementation, inat_get_avx_attribute() looks with-last-prefix directly. So, when decoding a grouped AVX instruction, the decoder fails to find correct group because there is no "Group" attribute on the table. This ends up with the mis-decoding of instructions, as Ingo reported in http://thread.gmane.org/gmane.linux.kernel/1214103 This patch fixes it to check no-last-prefix table first even if that is an AVX instruction, and get an attribute from "with last-prefix" table only if that is not a group. Reported-by: Ingo Molnar <mingo@elte.hu> Signed-off-by: Masami Hiramatsu <masami.hiramatsu.pt@hitachi.com> Cc: "H. Peter Anvin" <hpa@zytor.com> Cc: yrl.pp-manager.tt@hitachi.com Link: http://lkml.kernel.org/r/20111205120539.15475.91428.stgit@cloud Signed-off-by: Ingo Molnar <mingo@elte.hu>
Diffstat (limited to 'arch/x86/tools/insn_sanity.c')
0 files changed, 0 insertions, 0 deletions