forked from pool/binutils
f343644904
error about swapped .arch/.code directives to a warning. It happens in the wild. OBS-URL: https://build.opensuse.org/package/show/devel:gcc/binutils?expand=0&rev=462
26 lines
1.1 KiB
Diff
26 lines
1.1 KiB
Diff
Index: binutils-2.42/gas/config/tc-i386.c
|
|
===================================================================
|
|
--- binutils-2.42.orig/gas/config/tc-i386.c 2024-01-29 01:00:00.000000000 +0100
|
|
+++ binutils-2.42/gas/config/tc-i386.c 2024-02-05 17:54:33.515139672 +0100
|
|
@@ -2992,13 +2992,17 @@ set_cpu_arch (int dummy ATTRIBUTE_UNUSED
|
|
{
|
|
check_cpu_arch_compatible (string, cpu_arch[j].enable);
|
|
|
|
+ /* XXX code in the wild calls 'as --64' (to generate ELF64),
|
|
+ but then does '.arch i386' first and only then '.code32' or
|
|
+ '.code16'. This checking here would require swapping these
|
|
+ two directives, so just warn for the time being. */
|
|
if (flag_code == CODE_64BIT && !cpu_arch[j].enable.bitfield.cpu64 )
|
|
{
|
|
- as_bad (_("64bit mode not supported on `%s'."),
|
|
+ as_warn (_("64bit mode not supported on `%s' (consider swapping .arch and .code directives)."),
|
|
cpu_arch[j].name);
|
|
- (void) restore_line_pointer (e);
|
|
+ /*(void) restore_line_pointer (e);
|
|
ignore_rest_of_line ();
|
|
- return;
|
|
+ return;*/
|
|
}
|
|
|
|
if (flag_code == CODE_32BIT && !cpu_arch[j].enable.bitfield.cpui386)
|