x86: Fix instruction decoder to handle grouped AVX instructions
authorMasami Hiramatsu <masami.hiramatsu.pt@hitachi.com>
Mon, 5 Dec 2011 12:05:39 +0000 (21:05 +0900)
committerIngo Molnar <mingo@elte.hu>
Mon, 5 Dec 2011 13:53:15 +0000 (14:53 +0100)
commit130b78b2bf16d5d89091db38374faef896360cf9
tree46f1f553aba35de8e2ffea42128e2237da479dc6
parent1056c3e916f12cdd8042ab27dfccbb3a9e871df0
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>
arch/x86/lib/inat.c
arch/x86/lib/insn.c