x86: Fix the error of using "const" in gen-insn-attr-x86.awk
authorCong Ding <dinggnu@gmail.com>
Sun, 9 Dec 2012 08:21:04 +0000 (08:21 +0000)
committerH. Peter Anvin <hpa@linux.intel.com>
Mon, 10 Dec 2012 18:31:24 +0000 (10:31 -0800)
The original version code causes following sparse warnings:
arch/x86/lib/inat-tables.c:1080:25: warning: duplicate const
arch/x86/lib/inat-tables.c:1095:25: warning: duplicate const
arch/x86/lib/inat-tables.c:1118:25: warning: duplicate const

for the variables inat_escape_tables, inat_group_tables, and inat_avx_tables
in the code generated by gen-insn-attr-x86.awk.

The author Masami Hiramutsu says here is to make both the value pointed by the
pointers and the pointers itself read-only, so we move the "const" to be after
the "*".

Signed-off-by: Cong Ding <dinggnu@gmail.com>
Link: http://lkml.kernel.org/r/20121209082103.GA9181@gmail.com
Acked-by: Masami Hiramatsu <masami.hiramatsu.pt@hitachi.com>
Signed-off-by: H. Peter Anvin <hpa@linux.intel.com>
arch/x86/tools/gen-insn-attr-x86.awk

index ddcf39b1a18d3f8ad034237abc9adf293d46b24c..e6773dc8ac41c795e8ccb6f6f51faf3050b29270 100644 (file)
@@ -356,7 +356,7 @@ END {
                exit 1
        # print escape opcode map's array
        print "/* Escape opcode map array */"
-       print "const insn_attr_t const *inat_escape_tables[INAT_ESC_MAX + 1]" \
+       print "const insn_attr_t * const inat_escape_tables[INAT_ESC_MAX + 1]" \
              "[INAT_LSTPFX_MAX + 1] = {"
        for (i = 0; i < geid; i++)
                for (j = 0; j < max_lprefix; j++)
@@ -365,7 +365,7 @@ END {
        print "};\n"
        # print group opcode map's array
        print "/* Group opcode map array */"
-       print "const insn_attr_t const *inat_group_tables[INAT_GRP_MAX + 1]"\
+       print "const insn_attr_t * const inat_group_tables[INAT_GRP_MAX + 1]"\
              "[INAT_LSTPFX_MAX + 1] = {"
        for (i = 0; i < ggid; i++)
                for (j = 0; j < max_lprefix; j++)
@@ -374,7 +374,7 @@ END {
        print "};\n"
        # print AVX opcode map's array
        print "/* AVX opcode map array */"
-       print "const insn_attr_t const *inat_avx_tables[X86_VEX_M_MAX + 1]"\
+       print "const insn_attr_t * const inat_avx_tables[X86_VEX_M_MAX + 1]"\
              "[INAT_LSTPFX_MAX + 1] = {"
        for (i = 0; i < gaid; i++)
                for (j = 0; j < max_lprefix; j++)