Add "?" pseudo-flag to ELF .section/.pushsection directives.

This commit is contained in:
Roland McGrath 2010-08-17 20:03:41 +00:00
parent ebf252ff9b
commit 01642c122a
5 changed files with 140 additions and 93 deletions

View File

@ -1,3 +1,11 @@
2010-08-17 Roland McGrath <roland@redhat.com>
* config/obj-elf.c (obj_elf_parse_section_letters): Take new
boolean result parameter CLONE; set it if '?' flag letter seen.
(obj_elf_section): Update caller. Handle that flag by copying
the LINKONCE and GROUP_NAME state from NOW_SEG.
* doc/as.texinfo (Section): Document the ? flag.
2010-08-09 Cary Coutant <ccoutant@google.com>
* as.c (show_usage): Don't list --compress-debug-sections if zlib not

View File

@ -420,7 +420,7 @@ obj_elf_local (int ignore ATTRIBUTE_UNUSED)
do
{
symbolP = get_sym_from_input_line_and_check ();
symbolP = get_sym_from_input_line_and_check ();
c = *input_line_pointer;
S_CLEAR_EXTERNAL (symbolP);
symbol_get_obj (symbolP)->local = 1;
@ -444,7 +444,7 @@ obj_elf_weak (int ignore ATTRIBUTE_UNUSED)
do
{
symbolP = get_sym_from_input_line_and_check ();
symbolP = get_sym_from_input_line_and_check ();
c = *input_line_pointer;
S_SET_WEAK (symbolP);
symbol_get_obj (symbolP)->local = 1;
@ -741,9 +741,10 @@ obj_elf_change_section (const char *name,
}
static bfd_vma
obj_elf_parse_section_letters (char *str, size_t len)
obj_elf_parse_section_letters (char *str, size_t len, bfd_boolean *clone)
{
bfd_vma attr = 0;
*clone = FALSE;
while (len > 0)
{
@ -773,6 +774,9 @@ obj_elf_parse_section_letters (char *str, size_t len)
case 'T':
attr |= SHF_TLS;
break;
case '?':
*clone = TRUE;
break;
/* Compatibility. */
case 'm':
if (*(str - 1) == 'a')
@ -974,13 +978,15 @@ obj_elf_section (int push)
if (*input_line_pointer == '"')
{
bfd_boolean clone;
beg = demand_copy_C_string (&dummy);
if (beg == NULL)
{
ignore_rest_of_line ();
return;
}
attr |= obj_elf_parse_section_letters (beg, strlen (beg));
attr |= obj_elf_parse_section_letters (beg, strlen (beg), &clone);
SKIP_WHITESPACE ();
if (*input_line_pointer == ',')
@ -1032,6 +1038,11 @@ obj_elf_section (int push)
attr &= ~SHF_MERGE;
}
if ((attr & SHF_GROUP) != 0 && clone)
{
as_warn (_("? section flag ignored with G present"));
clone = FALSE;
}
if ((attr & SHF_GROUP) != 0 && *input_line_pointer == ',')
{
++input_line_pointer;
@ -1051,6 +1062,16 @@ obj_elf_section (int push)
as_warn (_("group name for SHF_GROUP not specified"));
attr &= ~SHF_GROUP;
}
if (clone)
{
const char *now_group = elf_group_name (now_seg);
if (now_group != NULL)
{
group_name = xstrdup (now_group);
linkonce = (now_seg->flags & SEC_LINK_ONCE) != 0;
}
}
}
else
{

View File

@ -8,7 +8,7 @@
@c (2) for platform-specific directives, examine md_pseudo_op
@c in config/tc-*.c
@c (3) for object-format specific directives, examine obj_pseudo_op
@c in config/obj-*.c
@c in config/obj-*.c
@c (4) portable directives in potable[] in read.c
@c %**start of header
@setfilename as.info
@ -70,17 +70,17 @@
@c instructions. Except in multi-column format, these tables look silly.
@c Unfortunately, Texinfo doesn't have a general-purpose multi-col format, so
@c the multi-col format is faked within @example sections.
@c
@c
@c Again unfortunately, the natural size that fits on a page, for these tables,
@c is different depending on whether or not smallbook is turned on.
@c This matters, because of order: text flow switches columns at each page
@c break.
@c
@c
@c The format faked in this source works reasonably well for smallbook,
@c not well for the default large-page format. This manual expects that if you
@c turn on @smallbook, you will also uncomment the "@set SMALL" to enable the
@c tables in question. You can turn on one without the other at your
@c discretion, of course.
@c discretion, of course.
@ifinfo
@set SMALL
@c the insn tables look just as silly in info files regardless of smallbook,
@ -246,7 +246,7 @@ gcc(1), ld(1), and the Info entries for @file{binutils} and @file{ld}.
[@b{--}|@var{files} @dots{}]
@c
@c Target dependent options are listed below. Keep the list sorted.
@c Add an empty line for separation.
@c Add an empty line for separation.
@ifset ALPHA
@emph{Target Alpha options:}
@ -417,7 +417,7 @@ gcc(1), ld(1), and the Info entries for @file{binutils} and @file{ld}.
@emph{Target PDP11 options:}
[@b{-mpic}|@b{-mno-pic}] [@b{-mall}] [@b{-mno-extensions}]
[@b{-m}@var{extension}|@b{-mno-}@var{extension}]
[@b{-m}@var{cpu}] [@b{-m}@var{machine}]
[@b{-m}@var{cpu}] [@b{-m}@var{machine}]
@end ifset
@ifset PJ
@ -469,7 +469,7 @@ gcc(1), ld(1), and the Info entries for @file{binutils} and @file{ld}.
@ifset TIC54X
@emph{Target TIC54X options:}
[@b{-mcpu=54[123589]}|@b{-mcpu=54[56]lp}] [@b{-mfar-mode}|@b{-mf}]
[@b{-mcpu=54[123589]}|@b{-mcpu=54[56]lp}] [@b{-mfar-mode}|@b{-mf}]
[@b{-merrors-to-file} @var{<filename>}|@b{-me} @var{<filename>}]
@end ifset
@ -859,11 +859,11 @@ is normally the M32R, but this option changes it to the M32RX.
@item --warn-explicit-parallel-conflicts or --Wp
Produce warning messages when questionable parallel constructs are
encountered.
encountered.
@item --no-warn-explicit-parallel-conflicts or --Wnp
Do not produce warning messages when questionable parallel constructs are
encountered.
Do not produce warning messages when questionable parallel constructs are
encountered.
@end table
@end ifset
@ -961,13 +961,13 @@ defined by the configuration option when building the assembler.
Specify to use the 16-bit integer ABI.
@item -mlong
Specify to use the 32-bit integer ABI.
Specify to use the 32-bit integer ABI.
@item -mshort-double
Specify to use the 32-bit double ABI.
Specify to use the 32-bit double ABI.
@item -mlong-double
Specify to use the 64-bit double ABI.
Specify to use the 64-bit double ABI.
@item --force-long-branches
Relative branches are turned into absolute ones. This concerns
@ -1021,7 +1021,7 @@ Warn when the assembler switches to another architecture.
@ifset TIC54X
The following options are available when @value{AS} is configured for the 'c54x
architecture.
architecture.
@table @gcctabopt
@item -mfar-mode
@ -1342,22 +1342,22 @@ a Z80 family processor.
Assemble for Z80 processor.
@item -r800
Assemble for R800 processor.
@item -ignore-undocumented-instructions
@item -ignore-undocumented-instructions
@itemx -Wnud
Assemble undocumented Z80 instructions that also work on R800 without warning.
@item -ignore-unportable-instructions
@item -ignore-unportable-instructions
@itemx -Wnup
Assemble all undocumented Z80 instructions without warning.
@item -warn-undocumented-instructions
@item -warn-undocumented-instructions
@itemx -Wud
Issue a warning for undocumented Z80 instructions that also work on R800.
@item -warn-unportable-instructions
@item -warn-unportable-instructions
@itemx -Wup
Issue a warning for undocumented Z80 instructions that do not work on R800.
@item -forbid-undocumented-instructions
Issue a warning for undocumented Z80 instructions that do not work on R800.
@item -forbid-undocumented-instructions
@itemx -Fud
Treat all undocumented instructions as errors.
@item -forbid-unportable-instructions
@item -forbid-unportable-instructions
@itemx -Fup
Treat undocumented Z80 instructions that do not work on R800 as errors.
@end table
@ -1614,7 +1614,7 @@ is the object file. Its default name is
@end ifclear
@ifset BOUT
@ifset GENERIC
@code{a.out}, or
@code{a.out}, or
@end ifset
@code{b.out} when @command{@value{AS}} is configured for the Intel 80960.
@end ifset
@ -2463,7 +2463,7 @@ constants are an exception: they do not end statements.
@end ifclear
@ifset abnormal-separator
@ifset HPPA
A @dfn{statement} ends at a newline character (@samp{\n}) or an exclamation
A @dfn{statement} ends at a newline character (@samp{\n}) or an exclamation
point (@samp{!}). The newline or exclamation point is considered part of the
preceding statement. Newlines and exclamation points within character
constants are an exception: they do not end statements.
@ -2519,7 +2519,7 @@ Whitespace before a label or after a colon is permitted, but you may not
have whitespace between a label's symbol and its colon. @xref{Labels}.
@ifset HPPA
For HPPA targets, labels need not be immediately followed by a colon, but
For HPPA targets, labels need not be immediately followed by a colon, but
the definition of a label must begin in column zero. This also implies that
only one label may be defined on each line.
@end ifset
@ -3474,7 +3474,7 @@ you may use them in debugging.
@item @var{number}
This is the number that was used in the local label definition. So if the
label is written @samp{55:} then the number is @samp{55}.
label is written @samp{55:} then the number is @samp{55}.
@item @kbd{C-B}
This unusual character is included so you do not accidentally invent a symbol
@ -3482,7 +3482,7 @@ of the same name. The character has ASCII value of @samp{\002} (control-B).
@item @emph{ordinal number}
This is a serial number to keep the labels distinct. The first definition of
@samp{0:} gets the number @samp{1}. The 15th definition of @samp{0:} gets the
@samp{0:} gets the number @samp{1}. The 15th definition of @samp{0:} gets the
number @samp{15}, and so on. Likewise the first definition of @samp{1:} gets
the number @samp{1} and its 15th definition gets @samp{15} as well.
@end table
@ -3688,7 +3688,7 @@ table information for COFF.
The SOM format for the HPPA supports a multitude of symbol attributes set with
the @code{.EXPORT} and @code{.IMPORT} directives.
The attributes are described in @cite{HP9000 Series 800 Assembly
The attributes are described in @cite{HP9000 Series 800 Assembly
Language Reference Manual} (HP 92432-90001) under the @code{IMPORT} and
@code{EXPORT} assembler directive documentation.
@end ifset
@ -3990,7 +3990,7 @@ Some machine configurations provide additional directives.
* File:: @code{.file}
* Fill:: @code{.fill @var{repeat} , @var{size} , @var{value}}
* Float:: @code{.float @var{flonums}}
* Func:: @code{.func}
* Func:: @code{.func}
* Global:: @code{.global @var{symbol}}, @code{.globl @var{symbol}}
@ifset ELF
* Gnu_attribute:: @code{.gnu_attribute @var{tag},@var{value}}
@ -4218,7 +4218,7 @@ write @samp{<4.3 !> 5.4!!>} to get the literal text @samp{4.3 > 5.4!}.
@item Expression results as strings
You can write @samp{%@var{expr}} to evaluate the expression @var{expr}
and use the result as a string.
and use the result as a string.
@end ftable
@node Ascii
@ -4300,9 +4300,9 @@ should have an entry in @code{.eh_frame}. It initializes some internal
data structures. Don't forget to close the function by
@code{.cfi_endproc}.
Unless @code{.cfi_startproc} is used along with parameter @code{simple}
Unless @code{.cfi_startproc} is used along with parameter @code{simple}
it also emits some architecture dependent initial CFI instructions.
@section @code{.cfi_endproc}
@cindex @code{cfi_endproc} directive
@code{.cfi_endproc} is used at the end of a function where it closes its
@ -4329,7 +4329,7 @@ or a symbol name. The default after @code{.cfi_startproc} is @code{.cfi_lsda 0x
no LSDA.
@section @code{.cfi_def_cfa @var{register}, @var{offset}}
@code{.cfi_def_cfa} defines a rule for computing CFA as: @i{take
@code{.cfi_def_cfa} defines a rule for computing CFA as: @i{take
address from @var{register} and add @var{offset} to it}.
@section @code{.cfi_def_cfa_register @var{register}}
@ -4349,7 +4349,7 @@ value that is added/substracted from the previous offset.
@section @code{.cfi_offset @var{register}, @var{offset}}
Previous value of @var{register} is saved at offset @var{offset} from
CFA.
CFA.
@section @code{.cfi_rel_offset @var{register}, @var{offset}}
Previous value of @var{register} is saved at offset @var{offset} from
@ -4362,25 +4362,25 @@ code it's annotating.
Previous value of @var{register1} is saved in register @var{register2}.
@section @code{.cfi_restore @var{register}}
@code{.cfi_restore} says that the rule for @var{register} is now the
same as it was at the beginning of the function, after all initial
@code{.cfi_restore} says that the rule for @var{register} is now the
same as it was at the beginning of the function, after all initial
instruction added by @code{.cfi_startproc} were executed.
@section @code{.cfi_undefined @var{register}}
From now on the previous value of @var{register} can't be restored anymore.
@section @code{.cfi_same_value @var{register}}
Current value of @var{register} is the same like in the previous frame,
Current value of @var{register} is the same like in the previous frame,
i.e. no restoration needed.
@section @code{.cfi_remember_state},
First save all current rules for all registers by @code{.cfi_remember_state},
then totally screw them up by subsequent @code{.cfi_*} directives and when
everything is hopelessly bad, use @code{.cfi_restore_state} to restore
@section @code{.cfi_remember_state},
First save all current rules for all registers by @code{.cfi_remember_state},
then totally screw them up by subsequent @code{.cfi_*} directives and when
everything is hopelessly bad, use @code{.cfi_restore_state} to restore
the previous saved state.
@section @code{.cfi_return_column @var{register}}
Change return column @var{register}, i.e. the return address is either
Change return column @var{register}, i.e. the return address is either
directly in @var{register} or can be accessed by rules for @var{register}.
@section @code{.cfi_signal_frame}
@ -4421,13 +4421,13 @@ using the largest size.
@ifset COFF-ELF
When using ELF or (as a GNU extension) PE, the @code{.comm} directive takes
an optional third argument. This is the desired alignment of the symbol,
an optional third argument. This is the desired alignment of the symbol,
specified for ELF as a byte boundary (for example, an alignment of 16 means
that the least significant 4 bits of the address should be zero), and for PE
as a power of two (for example, an alignment of 5 means aligned to a 32-byte
boundary). The alignment must be an absolute expression, and it must be a
boundary). The alignment must be an absolute expression, and it must be a
power of two. If @code{@value{LD}} allocates uninitialized memory for the
common symbol, it will use the alignment when placing the symbol. If no
common symbol, it will use the alignment when placing the symbol. If no
alignment is specified, @command{@value{AS}} will set the alignment to the
largest power of two less than or equal to the size of the symbol, up to a
maximum of 16 on ELF, or the default section alignment of 4 on PE@footnote{This
@ -4594,15 +4594,15 @@ This directive sets the value of @var{symbol} to @var{expression}.
It is synonymous with @samp{.set}; see @ref{Set,,@code{.set}}.
@ifset HPPA
The syntax for @code{equ} on the HPPA is
The syntax for @code{equ} on the HPPA is
@samp{@var{symbol} .equ @var{expression}}.
@end ifset
@ifset Z80
The syntax for @code{equ} on the Z80 is
@samp{@var{symbol} equ @var{expression}}.
The syntax for @code{equ} on the Z80 is
@samp{@var{symbol} equ @var{expression}}.
On the Z80 it is an eror if @var{symbol} is already defined,
but the symbol is not protected from later redefinition.
but the symbol is not protected from later redefinition.
Compare @ref{Equiv}.
@end ifset
@ -4614,7 +4614,7 @@ the assembler will signal an error if @var{symbol} is already defined. Note a
symbol which has been referenced but not actually defined is considered to be
undefined.
Except for the contents of the error message, this is roughly equivalent to
Except for the contents of the error message, this is roughly equivalent to
@smallexample
.ifdef SYM
.err
@ -4803,13 +4803,13 @@ Record a @sc{gnu} object attribute for this file. @xref{Object Attributes}.
@cindex @code{hidden} directive
@cindex visibility
This is one of the ELF visibility directives. The other two are
@code{.internal} (@pxref{Internal,,@code{.internal}}) and
@code{.internal} (@pxref{Internal,,@code{.internal}}) and
@code{.protected} (@pxref{Protected,,@code{.protected}}).
This directive overrides the named symbols default visibility (which is set by
their binding: local, global or weak). The directive sets the visibility to
@code{hidden} which means that the symbols are not visible to other components.
Such symbols are always considered to be @code{protected} as well.
Such symbols are always considered to be @code{protected} as well.
@end ifset
@node hword
@ -4992,7 +4992,7 @@ integers. On the H8/300H and the Renesas SH, however, @code{.int} emits
@cindex @code{internal} directive
@cindex visibility
This is one of the ELF visibility directives. The other two are
@code{.hidden} (@pxref{Hidden,,@code{.hidden}}) and
@code{.hidden} (@pxref{Hidden,,@code{.hidden}}) and
@code{.protected} (@pxref{Protected,,@code{.protected}}).
This directive overrides the named symbols default visibility (which is set by
@ -5219,7 +5219,7 @@ This option will set the @code{epilogue_begin} register in the
@item is_stmt @var{value}
This option will set the @code{is_stmt} register in the
@code{.debug_line} state machine to @code{value}, which must be
@code{.debug_line} state machine to @code{value}, which must be
either 0 or 1.
@item isa @var{value}
@ -5435,7 +5435,7 @@ l&:
@end table
Note: this problem of correctly identifying string parameters to pseudo ops
also applies to the identifiers used in @code{.irp} (@pxref{Irp})
also applies to the identifiers used in @code{.irp} (@pxref{Irp})
and @code{.irpc} (@pxref{Irpc}) as well.
@item .endm
@ -5577,13 +5577,13 @@ undefined.
@cindex @code{popsection} directive
@cindex Section Stack
This is one of the ELF section stack manipulation directives. The others are
@code{.section} (@pxref{Section}), @code{.subsection} (@pxref{SubSection}),
@code{.pushsection} (@pxref{PushSection}), and @code{.previous}
@code{.section} (@pxref{Section}), @code{.subsection} (@pxref{SubSection}),
@code{.pushsection} (@pxref{PushSection}), and @code{.previous}
(@pxref{Previous}).
This directive replaces the current section (and subsection) with the top
section (and subsection) on the section stack. This section is popped off the
stack.
stack.
@end ifset
@ifset ELF
@ -5660,7 +5660,7 @@ their binding: local, global or weak). The directive sets the visibility to
@code{protected} which means that any references to the symbols from within the
components that defines them must be resolved to the definition in that
component, even if a definition in another component would normally preempt
this.
this.
@end ifset
@node Psize
@ -5697,8 +5697,8 @@ expanded. @xref{Macro}.
@cindex @code{pushsection} directive
@cindex Section Stack
This is one of the ELF section stack manipulation directives. The others are
@code{.section} (@pxref{Section}), @code{.subsection} (@pxref{SubSection}),
@code{.popsection} (@pxref{PopSection}), and @code{.previous}
@code{.section} (@pxref{Section}), @code{.subsection} (@pxref{SubSection}),
@code{.popsection} (@pxref{PopSection}), and @code{.previous}
(@pxref{Previous}).
This directive pushes the current section (and subsection) onto the
@ -5868,7 +5868,7 @@ taken as a subsection number (@pxref{Sub-Sections}).
@cindex Section Stack
This is one of the ELF section stack manipulation directives. The others are
@code{.subsection} (@pxref{SubSection}), @code{.pushsection}
@code{.subsection} (@pxref{SubSection}), @code{.pushsection}
(@pxref{PushSection}), @code{.popsection} (@pxref{PopSection}), and
@code{.previous} (@pxref{Previous}).
@ -5898,6 +5898,8 @@ section contains zero terminated strings
section is a member of a section group
@item T
section is used for thread-local-storage
@item ?
section is a member of the previously-current section's group, if any
@end table
The optional @var{type} argument may contain one of the following constants:
@ -5962,6 +5964,13 @@ the Merge flag should come first, like this:
.section @var{name} , "@var{flags}"MG, @@@var{type}, @var{entsize}, @var{GroupName}[, @var{linkage}]
@end smallexample
If @var{flags} contains the @code{?} symbol then it may not also contain the
@code{G} symbol and the @var{GroupName} or @var{linkage} fields should not be
present. Instead, @code{?} says to consider the section that's current before
this directive. If that section used @code{G}, then the new section will use
@code{G} with those same @var{GroupName} and @var{linkage} fields implicitly.
If not, then the @code{?} symbol has no effect.
If no flags are specified, the default flags depend upon the section name. If
the section name is not recognized, the default will be for the section to have
none of the above flags: it will not be allocated in memory, nor writable, nor
@ -6118,7 +6127,7 @@ This directive emits @var{size} bytes, each of value @var{fill}. Both
@section @code{.sleb128 @var{expressions}}
@cindex @code{sleb128} directive
@var{sleb128} stands for ``signed little endian base 128.'' This is a
@var{sleb128} stands for ``signed little endian base 128.'' This is a
compact, variable length representation of numbers used by the DWARF
symbolic debugging format. @xref{Uleb128, ,@code{.uleb128}}.
@ -6212,7 +6221,7 @@ All five fields are specified.
@node String
@section @code{.string} "@var{str}", @code{.string8} "@var{str}", @code{.string16}
"@var{str}", @code{.string32} "@var{str}", @code{.string64} "@var{str}"
"@var{str}", @code{.string32} "@var{str}", @code{.string64} "@var{str}"
@cindex string, copying to object file
@cindex string8, copying to object file
@ -6230,7 +6239,7 @@ one string to copy, separated by commas. Unless otherwise specified for a
particular machine, the assembler marks the end of each string with a 0 byte.
You can use any of the escape sequences described in @ref{Strings,,Strings}.
The variants @code{string16}, @code{string32} and @code{string64} differ from
The variants @code{string16}, @code{string32} and @code{string64} differ from
the @code{string} pseudo opcode in that each 8-bit character from @var{str} is
copied and expanded to 16, 32 or 64 bits respectively. The expanded characters
are stored in target endianness byte order.
@ -6271,8 +6280,8 @@ before further assembly.
@cindex @code{subsection} directive
@cindex Section Stack
This is one of the ELF section stack manipulation directives. The others are
@code{.section} (@pxref{Section}), @code{.pushsection} (@pxref{PushSection}),
@code{.popsection} (@pxref{PopSection}), and @code{.previous}
@code{.section} (@pxref{Section}), @code{.pushsection} (@pxref{PushSection}),
@code{.popsection} (@pxref{PopSection}), and @code{.previous}
(@pxref{Previous}).
This directive replaces the current subsection with @code{name}. The current
@ -6488,7 +6497,7 @@ Note: Some targets support extra types in addition to those listed above.
@section @code{.uleb128 @var{expressions}}
@cindex @code{uleb128} directive
@var{uleb128} stands for ``unsigned little endian base 128.'' This is a
@var{uleb128} stands for ``unsigned little endian base 128.'' This is a
compact, variable length representation of numbers used by the DWARF
symbolic debugging format. @xref{Sleb128, ,@code{.sleb128}}.
@ -6549,12 +6558,12 @@ Similar to the directive @code{.error}
This directive sets the weak attribute on the comma separated list of symbol
@code{names}. If the symbols do not already exist, they will be created.
On COFF targets other than PE, weak symbols are a GNU extension. This
On COFF targets other than PE, weak symbols are a GNU extension. This
directive sets the weak attribute on the comma separated list of symbol
@code{names}. If the symbols do not already exist, they will be created.
On the PE target, weak symbols are supported natively as weak aliases.
When a weak symbol is created that is not an alias, GAS creates an
When a weak symbol is created that is not an alias, GAS creates an
alternate symbol to hold the default value.
@node Weakref
@ -7055,7 +7064,7 @@ family.
@include c-m68hc11.texi
@end ifset
@ifset MICROBLAZE
@ifset MICROBLAZE
@include c-microblaze.texi
@end ifset
@ -7350,8 +7359,8 @@ things without first using the debugger to find the facts.
If you have contributed to GAS and your name isn't listed here,
it is not meant as a slight. We just don't know about it. Send mail to the
maintainer, and we'll correct the situation. Currently
@c (January 1994),
maintainer, and we'll correct the situation. Currently
@c (January 1994),
the maintainer is Ken Raeburn (email address @code{raeburn@@cygnus.com}).
Dean Elsner wrote the original @sc{gnu} assembler for the VAX.@footnote{Any

View File

@ -1,3 +1,10 @@
2010-08-17 Roland McGrath <roland@redhat.com>
* gas/elf/groupauto.s: New file.
* gas/elf/groupautoa.d: New file.
* gas/elf/groupautob.d: New file.
* gas/elf/elf.exp (run_elf_list_test): Use them.
2010-08-06 Quentin Neill <quentin.neill@amd.com>
* gas/i386/arch-10-1.l: Add nopl instruction.

View File

@ -37,7 +37,7 @@ proc run_elf_list_test { name suffix opts readelf_opts readelf_pipe } {
}
# We're testing bits in obj-elf -- don't run on anything else.
if { ([istarget "*-*-*elf*"]
if { ([istarget "*-*-*elf*"]
|| [istarget "*-*-linux*"]
|| [istarget "m6811-*"]
|| [istarget "m6812-*"]
@ -70,7 +70,7 @@ if { ([istarget "*-*-*elf*"]
}
if { ([istarget "*arm*-*-*"]
|| [istarget "xscale*-*-*"]) } {
if { ([istarget "*-*-*eabi"]
|| [istarget "*-*-linux-*"]
|| [istarget "*-*-symbianelf"])} then {
@ -85,7 +85,7 @@ if { ([istarget "*-*-*elf*"]
# function prologues.
if {![istarget "mn10300-*-*"]
&& ![istarget "xtensa*-*-*"]
&& ![istarget "am3*-*-*"]} then {
&& ![istarget "am3*-*-*"]} then {
run_dump_test "ehopt0"
}
case $target_triplet in {
@ -102,10 +102,12 @@ if { ([istarget "*-*-*elf*"]
run_dump_test "file"
}
}
run_dump_test "group0a"
run_dump_test "group0b"
run_dump_test "group1a"
run_dump_test "group1b"
run_dump_test "group0a"
run_dump_test "group0b"
run_dump_test "group1a"
run_dump_test "group1b"
run_dump_test "groupautoa"
run_dump_test "groupautob"
case $target_triplet in {
{ alpha*-*-* } { }
{ cr16*-*-* } { }
@ -128,21 +130,21 @@ if { ([istarget "*-*-*elf*"]
}
}
run_dump_test "pseudo"
run_dump_test "section0"
run_dump_test "section1"
run_dump_test "section0"
run_dump_test "section1"
if {! [istarget "h8300-*-*"]} then {
# The h8300 port issues a warning message for
# new sections created without atrributes.
run_elf_list_test "section2" "$target_machine" "-al" "-s" ""
}
run_dump_test "section3"
run_dump_test "section3"
run_dump_test "section4"
if {! [istarget "h8300-*-*"]} then {
# The h8300 port issues a warning message for
# new sections created without atrributes.
run_elf_list_test "section5" "" "-al" "-SW" "| grep \" \\\\.test\\\[0-9\\\]\""
}
run_dump_test "struct"
run_dump_test "struct"
run_dump_test "symtab"
run_dump_test "symver"
@ -159,10 +161,10 @@ if { ([istarget "*-*-*elf*"]
run_elf_list_test "type" "" "" "-s" "| grep \"1 *\\\[FIONTCU\\\]\""
}
run_dump_test "section6"
run_dump_test "section7"
run_dump_test "section8"
run_dump_test "dwarf2-1"
run_dump_test "dwarf2-2"
run_dump_test "dwarf2-3"
run_dump_test "section6"
run_dump_test "section7"
run_dump_test "section8"
run_dump_test "dwarf2-1"
run_dump_test "dwarf2-2"
run_dump_test "dwarf2-3"
}