aboutsummaryrefslogtreecommitdiff
path: root/gas
diff options
context:
space:
mode:
authorH.J. Lu <hjl.tools@gmail.com>2018-08-10 11:03:50 -0700
committerH.J. Lu <hjl.tools@gmail.com>2018-08-10 11:03:50 -0700
commitd7f449c026181e14162a67407842462e4bc0d8bd (patch)
tree36b78882fa5eed4b3de09b52ea3a70a032fdd831 /gas
parent19449d7c67690c641b1ec9c13ff3531677a5afcc (diff)
downloadbinutils-d7f449c026181e14162a67407842462e4bc0d8bd.zip
binutils-d7f449c026181e14162a67407842462e4bc0d8bd.tar.gz
binutils-d7f449c026181e14162a67407842462e4bc0d8bd.tar.bz2
x86: Don't display --32/--64/--x32 without BFD64
For 32-bit x86 assembler, --64 and --x32 are unsupported if BFD64 is undefined. Even if BFD64 is defined, --64 and --x32 still may not be supported if x86-64 support isn't compiled in: [hjl@gnu-hsw-1 gas]$ ./as-new --64 -o x.o x.s Assembler messages: Fatal error: no compiled in support for x86_64 [hjl@gnu-hsw-1 gas]$ ./as-new --x32 -o x.o x.s Assembler messages: Fatal error: no compiled in support for 32bit x86_64 [hjl@gnu-hsw-1 gas]$ This patch removes --32/--64/--x32 from md_show_usage if BFD64 is undefined and runs code64-inval only if BFD64 is undefined. * config/tc-i386.c (md_show_usage): Don't display --32/--64/--x32 if BFD64 is undefined. * testsuite/gas/i386/i386.exp (gas_bfd64_check): New. Run code64-inval if gas_bfd64_check fails.
Diffstat (limited to 'gas')
-rw-r--r--gas/ChangeLog7
-rw-r--r--gas/config/tc-i386.c4
-rw-r--r--gas/testsuite/gas/i386/i386.exp9
3 files changed, 17 insertions, 3 deletions
diff --git a/gas/ChangeLog b/gas/ChangeLog
index 2df3fdb..fe86913 100644
--- a/gas/ChangeLog
+++ b/gas/ChangeLog
@@ -1,5 +1,12 @@
2018-08-10 H.J. Lu <hongjiu.lu@intel.com>
+ * config/tc-i386.c (md_show_usage): Don't display --32/--64/--x32
+ if BFD64 is undefined.
+ * testsuite/gas/i386/i386.exp (gas_bfd64_check): New.
+ Run code64-inval if gas_bfd64_check fails.
+
+2018-08-10 H.J. Lu <hongjiu.lu@intel.com>
+
* testsuite/gas/i386/evex-no-scale.s: Removed.
* testsuite/gas/i386/evex-no-scale-32.d: Don't use
evex-no-scale.s.
diff --git a/gas/config/tc-i386.c b/gas/config/tc-i386.c
index ddbffb9..50c5bfa 100644
--- a/gas/config/tc-i386.c
+++ b/gas/config/tc-i386.c
@@ -11127,8 +11127,8 @@ md_show_usage (FILE *stream)
fprintf (stream, _("\
-s ignored\n"));
#endif
-#if (defined (OBJ_ELF) || defined (OBJ_MAYBE_ELF) \
- || defined (TE_PE) || defined (TE_PEP))
+#if defined BFD64 && (defined (OBJ_ELF) || defined (OBJ_MAYBE_ELF) \
+ || defined (TE_PE) || defined (TE_PEP))
fprintf (stream, _("\
--32/--64/--x32 generate 32bit/64bit/x32 code\n"));
#endif
diff --git a/gas/testsuite/gas/i386/i386.exp b/gas/testsuite/gas/i386/i386.exp
index 6ea4dee..aa1a0f2 100644
--- a/gas/testsuite/gas/i386/i386.exp
+++ b/gas/testsuite/gas/i386/i386.exp
@@ -33,6 +33,13 @@ proc gas_32_check { } {
return [regexp "targets:.*i386" [lindex $status 1]];
}
+proc gas_bfd64_check { } {
+ global AS
+
+ set status [gas_host_run "$AS --help" ""]
+ return [regexp "32bit/64bit/x32" [lindex $status 1]];
+}
+
if [expr ([istarget "i*86-*-*"] || [istarget "x86_64-*-*"]) && [gas_32_check]] then {
global ASFLAGS
@@ -534,7 +541,7 @@ if [expr ([istarget "i*86-*-*"] || [istarget "x86_64-*-*"]) && [gas_32_check]]
run_dump_test "intel-regs"
run_dump_test "mixed-mode-reloc32"
run_dump_test "code64"
- } else {
+ } elseif { ![gas_bfd64_check] } {
run_list_test "code64-inval" "-I${srcdir}/$subdir -al"
}