Add x86 gas -q option to quiet some x86 gas warnings.
Remove useless -m flag_do_long_jump from x86 gas. If BFD_ASSEMBLER, store --defsym value in a bfd_vma, and use scan_bfd_vma.
This commit is contained in:
parent
e413e4e996
commit
a38cf1db3a
4 changed files with 75 additions and 56 deletions
|
@ -1,3 +1,19 @@
|
||||||
|
2000-05-13 Alan Modra <alan@linuxcare.com.au>
|
||||||
|
|
||||||
|
* NEWS: Mention x86 .arch and -q.
|
||||||
|
|
||||||
|
* config/tc-i386.c (quiet_warnings): New.
|
||||||
|
(md_assemble): Use quiet_warnings.
|
||||||
|
(md_parse_option): Set quiet_warnings from -q.
|
||||||
|
(md_show_usage): Mention -q, delete -m.
|
||||||
|
(flag_do_long_jump): Delete.
|
||||||
|
(md_parse_option): Remove -m.
|
||||||
|
(md_show_usage): Remove -m.
|
||||||
|
(md_create_long_jump): Remove useless flag_do_long_jump code.
|
||||||
|
|
||||||
|
* as.c (parse_args): In case OPTION_DEFSYM, use a valueT to hold
|
||||||
|
the symbol value, and use bfd_scan_vma if BFD_ASSEMBLER.
|
||||||
|
|
||||||
2000-05-13 Alan Modra <alan@linuxcare.com.au>
|
2000-05-13 Alan Modra <alan@linuxcare.com.au>
|
||||||
Alexander Sokolov <robocop@netlink.ru>
|
Alexander Sokolov <robocop@netlink.ru>
|
||||||
|
|
||||||
|
|
6
gas/NEWS
6
gas/NEWS
|
@ -4,6 +4,12 @@ Changes in 2.11:
|
||||||
|
|
||||||
Support for IA-64.
|
Support for IA-64.
|
||||||
|
|
||||||
|
x86 gas has a new .arch pseudo op to specify the target CPU architecture.
|
||||||
|
|
||||||
|
x86 gas -q command line option quietens warnings about register size changes
|
||||||
|
due to suffix, indirect jmp/call without `*', stand-alone prefixes, and
|
||||||
|
translating various deprecated floating point instructions.
|
||||||
|
|
||||||
Changes in 2.10:
|
Changes in 2.10:
|
||||||
|
|
||||||
Support for ATMEL AVR.
|
Support for ATMEL AVR.
|
||||||
|
|
6
gas/as.c
6
gas/as.c
|
@ -546,7 +546,7 @@ the GNU General Public License. This program has absolutely no warranty.\n"));
|
||||||
case OPTION_DEFSYM:
|
case OPTION_DEFSYM:
|
||||||
{
|
{
|
||||||
char *s;
|
char *s;
|
||||||
long i;
|
valueT i;
|
||||||
struct defsym_list *n;
|
struct defsym_list *n;
|
||||||
|
|
||||||
for (s = optarg; *s != '\0' && *s != '='; s++)
|
for (s = optarg; *s != '\0' && *s != '='; s++)
|
||||||
|
@ -554,7 +554,11 @@ the GNU General Public License. This program has absolutely no warranty.\n"));
|
||||||
if (*s == '\0')
|
if (*s == '\0')
|
||||||
as_fatal (_("bad defsym; format is --defsym name=value"));
|
as_fatal (_("bad defsym; format is --defsym name=value"));
|
||||||
*s++ = '\0';
|
*s++ = '\0';
|
||||||
|
#ifdef BFD_ASSEMBLER
|
||||||
|
i = bfd_scan_vma (s, (const char **) NULL, 0);
|
||||||
|
#else
|
||||||
i = strtol (s, (char **) NULL, 0);
|
i = strtol (s, (char **) NULL, 0);
|
||||||
|
#endif
|
||||||
n = (struct defsym_list *) xmalloc (sizeof *n);
|
n = (struct defsym_list *) xmalloc (sizeof *n);
|
||||||
n->next = defsyms;
|
n->next = defsyms;
|
||||||
n->name = optarg;
|
n->name = optarg;
|
||||||
|
|
|
@ -219,17 +219,11 @@ static expressionS disp_expressions[2], im_expressions[2];
|
||||||
|
|
||||||
static int this_operand; /* Current operand we are working on. */
|
static int this_operand; /* Current operand we are working on. */
|
||||||
|
|
||||||
static int flag_do_long_jump; /* FIXME what does this do? */
|
|
||||||
|
|
||||||
static int flag_16bit_code; /* 1 if we're writing 16-bit code,
|
static int flag_16bit_code; /* 1 if we're writing 16-bit code,
|
||||||
0 if 32-bit. */
|
0 if 32-bit. */
|
||||||
|
|
||||||
static int intel_syntax = 0; /* 1 for intel syntax, 0 if att syntax. */
|
static int intel_syntax = 0; /* 1 for intel syntax, 0 if att syntax. */
|
||||||
|
|
||||||
static const char *cpu_arch_name = NULL; /* cpu name */
|
|
||||||
|
|
||||||
static unsigned int cpu_arch_flags = 0; /* cpu feature flags */
|
|
||||||
|
|
||||||
static int allow_naked_reg = 0; /* 1 if register prefix % not required */
|
static int allow_naked_reg = 0; /* 1 if register prefix % not required */
|
||||||
|
|
||||||
static char stackop_size = '\0'; /* Used in 16 bit gcc mode to add an l
|
static char stackop_size = '\0'; /* Used in 16 bit gcc mode to add an l
|
||||||
|
@ -237,6 +231,12 @@ static char stackop_size = '\0'; /* Used in 16 bit gcc mode to add an l
|
||||||
and pop instructions so that gcc has the
|
and pop instructions so that gcc has the
|
||||||
same stack frame as in 32 bit mode. */
|
same stack frame as in 32 bit mode. */
|
||||||
|
|
||||||
|
static int quiet_warnings = 0; /* Non-zero to quieten some warnings. */
|
||||||
|
|
||||||
|
static const char *cpu_arch_name = NULL; /* cpu name */
|
||||||
|
|
||||||
|
static unsigned int cpu_arch_flags = 0; /* cpu feature flags */
|
||||||
|
|
||||||
/* Interface to relax_segment.
|
/* Interface to relax_segment.
|
||||||
There are 2 relax states for 386 jump insns: one for conditional &
|
There are 2 relax states for 386 jump insns: one for conditional &
|
||||||
one for unconditional jumps. This is because these two types of
|
one for unconditional jumps. This is because these two types of
|
||||||
|
@ -1566,17 +1566,22 @@ md_assemble (line)
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!intel_syntax
|
if (!quiet_warnings)
|
||||||
&& (i.types[0] & JumpAbsolute) != (t->operand_types[0] & JumpAbsolute))
|
|
||||||
{
|
{
|
||||||
as_warn (_("indirect %s without `*'"), t->name);
|
if (!intel_syntax
|
||||||
}
|
&& ((i.types[0] & JumpAbsolute)
|
||||||
|
!= (t->operand_types[0] & JumpAbsolute)))
|
||||||
|
{
|
||||||
|
as_warn (_("indirect %s without `*'"), t->name);
|
||||||
|
}
|
||||||
|
|
||||||
if ((t->opcode_modifier & (IsPrefix|IgnoreSize)) == (IsPrefix|IgnoreSize))
|
if ((t->opcode_modifier & (IsPrefix|IgnoreSize))
|
||||||
{
|
== (IsPrefix|IgnoreSize))
|
||||||
/* Warn them that a data or address size prefix doesn't affect
|
{
|
||||||
assembly of the next line of code. */
|
/* Warn them that a data or address size prefix doesn't
|
||||||
as_warn (_("stand-alone `%s' prefix"), t->name);
|
affect assembly of the next line of code. */
|
||||||
|
as_warn (_("stand-alone `%s' prefix"), t->name);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Copy the template we found. */
|
/* Copy the template we found. */
|
||||||
|
@ -1692,7 +1697,8 @@ md_assemble (line)
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
#if REGISTER_WARNINGS
|
#if REGISTER_WARNINGS
|
||||||
if ((i.tm.operand_types[op] & InOutPortReg) == 0)
|
if (!quiet_warnings
|
||||||
|
&& (i.tm.operand_types[op] & InOutPortReg) == 0)
|
||||||
as_warn (_("using `%%%s' instead of `%%%s' due to `%c' suffix"),
|
as_warn (_("using `%%%s' instead of `%%%s' due to `%c' suffix"),
|
||||||
(i.op[op].regs - (i.types[op] & Reg16 ? 8 : 16))->reg_name,
|
(i.op[op].regs - (i.types[op] & Reg16 ? 8 : 16))->reg_name,
|
||||||
i.op[op].regs->reg_name,
|
i.op[op].regs->reg_name,
|
||||||
|
@ -1731,7 +1737,8 @@ md_assemble (line)
|
||||||
}
|
}
|
||||||
#if REGISTER_WARNINGS
|
#if REGISTER_WARNINGS
|
||||||
/* Warn if the e prefix on a general reg is missing. */
|
/* Warn if the e prefix on a general reg is missing. */
|
||||||
else if ((i.types[op] & Reg16) != 0
|
else if (!quiet_warnings
|
||||||
|
&& (i.types[op] & Reg16) != 0
|
||||||
&& (i.tm.operand_types[op] & (Reg32|Acc)) != 0)
|
&& (i.tm.operand_types[op] & (Reg32|Acc)) != 0)
|
||||||
{
|
{
|
||||||
as_warn (_("using `%%%s' instead of `%%%s' due to `%c' suffix"),
|
as_warn (_("using `%%%s' instead of `%%%s' due to `%c' suffix"),
|
||||||
|
@ -1758,7 +1765,8 @@ md_assemble (line)
|
||||||
}
|
}
|
||||||
#if REGISTER_WARNINGS
|
#if REGISTER_WARNINGS
|
||||||
/* Warn if the e prefix on a general reg is present. */
|
/* Warn if the e prefix on a general reg is present. */
|
||||||
else if ((i.types[op] & Reg32) != 0
|
else if (!quiet_warnings
|
||||||
|
&& (i.types[op] & Reg32) != 0
|
||||||
&& (i.tm.operand_types[op] & (Reg16|Acc)) != 0)
|
&& (i.tm.operand_types[op] & (Reg16|Acc)) != 0)
|
||||||
{
|
{
|
||||||
as_warn (_("using `%%%s' instead of `%%%s' due to `%c' suffix"),
|
as_warn (_("using `%%%s' instead of `%%%s' due to `%c' suffix"),
|
||||||
|
@ -1934,7 +1942,7 @@ md_assemble (line)
|
||||||
unsigned int op = (i.types[0] & (Reg | FloatReg)) ? 0 : 1;
|
unsigned int op = (i.types[0] & (Reg | FloatReg)) ? 0 : 1;
|
||||||
/* Register goes in low 3 bits of opcode. */
|
/* Register goes in low 3 bits of opcode. */
|
||||||
i.tm.base_opcode |= i.op[op].regs->reg_num;
|
i.tm.base_opcode |= i.op[op].regs->reg_num;
|
||||||
if ((i.tm.opcode_modifier & Ugh) != 0)
|
if (!quiet_warnings && (i.tm.opcode_modifier & Ugh) != 0)
|
||||||
{
|
{
|
||||||
/* Warn about some common errors, but press on regardless.
|
/* Warn about some common errors, but press on regardless.
|
||||||
The first case can be generated by gcc (<= 2.8.1). */
|
The first case can be generated by gcc (<= 2.8.1). */
|
||||||
|
@ -2191,7 +2199,7 @@ md_assemble (line)
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if ((i.tm.opcode_modifier & Ugh) != 0)
|
else if (!quiet_warnings && (i.tm.opcode_modifier & Ugh) != 0)
|
||||||
{
|
{
|
||||||
/* UnixWare fsub no args is alias for fsubp, fadd -> faddp, etc. */
|
/* UnixWare fsub no args is alias for fsubp, fadd -> faddp, etc. */
|
||||||
as_warn (_("translating to `%sp'"), i.tm.name);
|
as_warn (_("translating to `%sp'"), i.tm.name);
|
||||||
|
@ -3927,25 +3935,14 @@ void
|
||||||
md_create_long_jump (ptr, from_addr, to_addr, frag, to_symbol)
|
md_create_long_jump (ptr, from_addr, to_addr, frag, to_symbol)
|
||||||
char *ptr;
|
char *ptr;
|
||||||
addressT from_addr, to_addr;
|
addressT from_addr, to_addr;
|
||||||
fragS *frag;
|
fragS *frag ATTRIBUTE_UNUSED;
|
||||||
symbolS *to_symbol;
|
symbolS *to_symbol ATTRIBUTE_UNUSED;
|
||||||
{
|
{
|
||||||
offsetT offset;
|
offsetT offset;
|
||||||
|
|
||||||
if (flag_do_long_jump)
|
offset = to_addr - (from_addr + 5);
|
||||||
{
|
md_number_to_chars (ptr, (valueT) 0xe9, 1);
|
||||||
offset = to_addr - S_GET_VALUE (to_symbol);
|
md_number_to_chars (ptr + 1, (valueT) offset, 4);
|
||||||
md_number_to_chars (ptr, (valueT) 0xe9, 1);/* opcode for long jmp */
|
|
||||||
md_number_to_chars (ptr + 1, (valueT) offset, 4);
|
|
||||||
fix_new (frag, (ptr + 1) - frag->fr_literal, 4,
|
|
||||||
to_symbol, (offsetT) 0, 0, BFD_RELOC_32);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
offset = to_addr - (from_addr + 5);
|
|
||||||
md_number_to_chars (ptr, (valueT) 0xe9, 1);
|
|
||||||
md_number_to_chars (ptr + 1, (valueT) offset, 4);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Apply a fixup (fixS) to segment data, once it has been determined
|
/* Apply a fixup (fixS) to segment data, once it has been determined
|
||||||
|
@ -4275,13 +4272,14 @@ md_parse_option (c, arg)
|
||||||
{
|
{
|
||||||
switch (c)
|
switch (c)
|
||||||
{
|
{
|
||||||
case 'm':
|
case 'q':
|
||||||
flag_do_long_jump = 1;
|
quiet_warnings = 1;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
#if defined (OBJ_ELF) || defined (OBJ_MAYBE_ELF)
|
#if defined (OBJ_ELF) || defined (OBJ_MAYBE_ELF)
|
||||||
/* -k: Ignore for FreeBSD compatibility. */
|
/* -Qy, -Qn: SVR4 arguments controlling whether a .comment section
|
||||||
case 'k':
|
should be emitted or not. FIXME: Not implemented. */
|
||||||
|
case 'Q':
|
||||||
break;
|
break;
|
||||||
|
|
||||||
/* -V: SVR4 argument to print version ID. */
|
/* -V: SVR4 argument to print version ID. */
|
||||||
|
@ -4289,20 +4287,14 @@ md_parse_option (c, arg)
|
||||||
print_version_id ();
|
print_version_id ();
|
||||||
break;
|
break;
|
||||||
|
|
||||||
/* -Qy, -Qn: SVR4 arguments controlling whether a .comment section
|
/* -k: Ignore for FreeBSD compatibility. */
|
||||||
should be emitted or not. FIXME: Not implemented. */
|
case 'k':
|
||||||
case 'Q':
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 's':
|
case 's':
|
||||||
/* -s: On i386 Solaris, this tells the native assembler to use
|
/* -s: On i386 Solaris, this tells the native assembler to use
|
||||||
.stab instead of .stab.excl. We always use .stab anyhow. */
|
.stab instead of .stab.excl. We always use .stab anyhow. */
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'q':
|
|
||||||
/* -q: On i386 Solaris, this tells the native assembler to do
|
|
||||||
fewer checks. */
|
|
||||||
break;
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
default:
|
default:
|
||||||
|
@ -4315,15 +4307,16 @@ void
|
||||||
md_show_usage (stream)
|
md_show_usage (stream)
|
||||||
FILE *stream;
|
FILE *stream;
|
||||||
{
|
{
|
||||||
fprintf (stream, _("\
|
|
||||||
-m do long jump\n"));
|
|
||||||
#if defined (OBJ_ELF) || defined (OBJ_MAYBE_ELF)
|
#if defined (OBJ_ELF) || defined (OBJ_MAYBE_ELF)
|
||||||
fprintf (stream, _("\
|
fprintf (stream, _("\
|
||||||
-V print assembler version number\n\
|
-Q ignored\n\
|
||||||
-k ignored\n\
|
-V print assembler version number\n\
|
||||||
-Qy, -Qn ignored\n\
|
-k ignored\n\
|
||||||
-q ignored\n\
|
-q quieten some warnings\n\
|
||||||
-s ignored\n"));
|
-s ignored\n"));
|
||||||
|
#else
|
||||||
|
fprintf (stream, _("\
|
||||||
|
-q quieten some warnings\n"));
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue