98e4619f2b
Add a new test titled: Test x86 instruction decoder - new instructions The purpose of this test is to check the instruction decoder after new instructions have been added. Initially, MPX instructions are tested which are already supported, but the definitions in x86-opcode-map.txt will be tweaked in a subsequent patch, after which this test can be run to verify those changes. The data for the test comes from assembly language instructions in insn-x86-dat-src.c which is converted into bytes by the scripts gen-insn-x86-dat.sh and gen-insn-x86-dat.awk, and included into the test program insn-x86.c as insn-x86-dat-32.c and insn-x86-dat-64.c. The conversion is not done as part of the perf tools build because the test data must be under (git) change control in order for the test to be repeatably-correct. Also it may require a recent version of binutils. Commiter notes: Using it: # perf test decoder 39: Test x86 instruction decoder - new instructions : Ok # perf test -v decoder 39: Test x86 instruction decoder - new instructions : --- start --- test child forked, pid 21970 Decoded ok: 0f 31 rdtsc Decoded ok: f3 0f 1b 00 bndmk (%eax),%bnd0 Decoded ok: f3 0f 1b 05 78 56 34 12 bndmk 0x12345678,%bnd0 Decoded ok: f3 0f 1b 18 bndmk (%eax),%bnd3 <SNIP> Decoded ok: f2 e9 00 00 00 00 bnd jmpq 402 <main+0x402> Decoded ok: f2 e9 00 00 00 00 bnd jmpq 408 <main+0x408> Decoded ok: 67 f2 ff 21 bnd jmpq *(%ecx) Decoded ok: f2 0f 85 00 00 00 00 bnd jne 413 <main+0x413> test child finished with 0 ---- end ---- Test x86 instruction decoder - new instructions: Ok # Signed-off-by: Adrian Hunter <adrian.hunter@intel.com> Acked-by: Masami Hiramatsu <masami.hiramatsu.pt@hitachi.com> Tested-by: Arnaldo Carvalho de Melo <acme@redhat.com> Cc: "H. Peter Anvin" <hpa@zytor.com> Cc: Andy Lutomirski <luto@amacapital.net> Cc: Dave Hansen <dave.hansen@linux.intel.com> Cc: Denys Vlasenko <dvlasenk@redhat.com> Cc: Jiri Olsa <jolsa@redhat.com> Cc: Peter Zijlstra <peterz@infradead.org> Cc: Qiaowei Ren <qiaowei.ren@intel.com> Cc: Thomas Gleixner <tglx@linutronix.de> Link: http://lkml.kernel.org/r/1441196131-20632-3-git-send-email-adrian.hunter@intel.com Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
76 lines
1.7 KiB
Awk
76 lines
1.7 KiB
Awk
#!/bin/awk -f
|
|
# gen-insn-x86-dat.awk: script to convert data for the insn-x86 test
|
|
# Copyright (c) 2015, Intel Corporation.
|
|
#
|
|
# This program is free software; you can redistribute it and/or modify it
|
|
# under the terms and conditions of the GNU General Public License,
|
|
# version 2, as published by the Free Software Foundation.
|
|
#
|
|
# This program is distributed in the hope it will be useful, but WITHOUT
|
|
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
|
# more details.
|
|
|
|
BEGIN {
|
|
print "/*"
|
|
print " * Generated by gen-insn-x86-dat.sh and gen-insn-x86-dat.awk"
|
|
print " * from insn-x86-dat-src.c for inclusion by insn-x86.c"
|
|
print " * Do not change this code."
|
|
print "*/\n"
|
|
op = ""
|
|
branch = ""
|
|
rel = 0
|
|
going = 0
|
|
}
|
|
|
|
/ Start here / {
|
|
going = 1
|
|
}
|
|
|
|
/ Stop here / {
|
|
going = 0
|
|
}
|
|
|
|
/^\s*[0-9a-fA-F]+\:/ {
|
|
if (going) {
|
|
colon_pos = index($0, ":")
|
|
useful_line = substr($0, colon_pos + 1)
|
|
first_pos = match(useful_line, "[0-9a-fA-F]")
|
|
useful_line = substr(useful_line, first_pos)
|
|
gsub("\t", "\\t", useful_line)
|
|
printf "{{"
|
|
len = 0
|
|
for (i = 2; i <= NF; i++) {
|
|
if (match($i, "^[0-9a-fA-F][0-9a-fA-F]$")) {
|
|
printf "0x%s, ", $i
|
|
len += 1
|
|
} else {
|
|
break
|
|
}
|
|
}
|
|
printf "}, %d, %s, \"%s\", \"%s\",", len, rel, op, branch
|
|
printf "\n\"%s\",},\n", useful_line
|
|
op = ""
|
|
branch = ""
|
|
rel = 0
|
|
}
|
|
}
|
|
|
|
/ Expecting: / {
|
|
expecting_str = " Expecting: "
|
|
expecting_len = length(expecting_str)
|
|
expecting_pos = index($0, expecting_str)
|
|
useful_line = substr($0, expecting_pos + expecting_len)
|
|
for (i = 1; i <= NF; i++) {
|
|
if ($i == "Expecting:") {
|
|
i++
|
|
op = $i
|
|
i++
|
|
branch = $i
|
|
i++
|
|
rel = $i
|
|
break
|
|
}
|
|
}
|
|
}
|