* doc/c-xtensa.texi (Xtensa Options, Absolute Literals Directive):
Remove comments about placement of literal pools. (Literal Directive): Update description of literal placement. (Literal Prefix Directive): Remove statement that this does not apply to absolute-mode literals. Describe new section naming scheme.
This commit is contained in:
parent
98b4dd9401
commit
40e7b7b9ef
2 changed files with 47 additions and 28 deletions
|
@ -1,3 +1,11 @@
|
||||||
|
2004-10-14 Bob Wilson <bob.wilson@acm.org>
|
||||||
|
|
||||||
|
* doc/c-xtensa.texi (Xtensa Options, Absolute Literals Directive):
|
||||||
|
Remove comments about placement of literal pools.
|
||||||
|
(Literal Directive): Update description of literal placement.
|
||||||
|
(Literal Prefix Directive): Remove statement that this does not apply
|
||||||
|
to absolute-mode literals. Describe new section naming scheme.
|
||||||
|
|
||||||
2004-10-12 Bob Wilson <bob.wilson@acm.org>
|
2004-10-12 Bob Wilson <bob.wilson@acm.org>
|
||||||
|
|
||||||
* config/tc-xtensa.c (xtensa_frequency_pseudo): Use set_subseg_freq.
|
* config/tc-xtensa.c (xtensa_frequency_pseudo): Use set_subseg_freq.
|
||||||
|
|
|
@ -54,9 +54,7 @@ Indicate to the assembler whether @code{L32R} instructions use absolute
|
||||||
or PC-relative addressing. If the processor includes the absolute
|
or PC-relative addressing. If the processor includes the absolute
|
||||||
addressing option, the default is to use absolute @code{L32R}
|
addressing option, the default is to use absolute @code{L32R}
|
||||||
relocations. Otherwise, only the PC-relative @code{L32R} relocations
|
relocations. Otherwise, only the PC-relative @code{L32R} relocations
|
||||||
can be used. Literals referenced with absolute @code{L32R} relocations
|
can be used.
|
||||||
are always placed in the @code{.lit4} section, independent of the
|
|
||||||
placement of PC-relative literals.
|
|
||||||
|
|
||||||
@item --target-align | --no-target-align
|
@item --target-align | --no-target-align
|
||||||
@kindex --target-align
|
@kindex --target-align
|
||||||
|
@ -616,16 +614,16 @@ can be used to load a pointer to the symbol @code{sym} into register
|
||||||
the data in a literal pool.
|
the data in a literal pool.
|
||||||
|
|
||||||
Literal pools for absolute mode @code{L32R} instructions
|
Literal pools for absolute mode @code{L32R} instructions
|
||||||
(@pxref{Absolute Literals Directive}) are always placed in the
|
(@pxref{Absolute Literals Directive}) are placed in a seperate
|
||||||
@code{.lit4} section. By default literal pools for PC-relative mode
|
@code{.lit4} section. By default literal pools for PC-relative mode
|
||||||
@code{L32R} instructions are placed in a separate section; however, when
|
@code{L32R} instructions are placed in a separate @code{.literal}
|
||||||
using the @samp{--text-@-section-@-literals} option (@pxref{Xtensa
|
section; however, when using the @samp{--text-@-section-@-literals}
|
||||||
Options, ,Command Line Options}), the literal pools are placed in the
|
option (@pxref{Xtensa Options, ,Command Line Options}), the literal
|
||||||
current section. These text section literal pools are created
|
pools are placed in the current section. These text section literal
|
||||||
automatically before @code{ENTRY} instructions and manually after
|
pools are created automatically before @code{ENTRY} instructions and
|
||||||
@samp{.literal_position} directives (@pxref{Literal Position Directive,
|
manually after @samp{.literal_position} directives (@pxref{Literal
|
||||||
,literal_position}). If there are no preceding @code{ENTRY}
|
Position Directive, ,literal_position}). If there are no preceding
|
||||||
instructions, explicit @code{.literal_position} directives
|
@code{ENTRY} instructions, explicit @code{.literal_position} directives
|
||||||
must be used to place the text section literal pools; otherwise,
|
must be used to place the text section literal pools; otherwise,
|
||||||
@command{@value{AS}} will report an error.
|
@command{@value{AS}} will report an error.
|
||||||
|
|
||||||
|
@ -679,9 +677,6 @@ continue:
|
||||||
|
|
||||||
The @code{literal_prefix} directive allows you to specify different
|
The @code{literal_prefix} directive allows you to specify different
|
||||||
sections to hold literals from different portions of an assembly file.
|
sections to hold literals from different portions of an assembly file.
|
||||||
This directive only applies to literals referenced from PC-relative
|
|
||||||
@code{L32R} instructions; it has no effect for absolute literals
|
|
||||||
(@pxref{Absolute Literals Directive}).
|
|
||||||
With this directive, a single assembly file can be used to generate code
|
With this directive, a single assembly file can be used to generate code
|
||||||
into multiple sections, including literals generated by the assembler.
|
into multiple sections, including literals generated by the assembler.
|
||||||
|
|
||||||
|
@ -690,13 +685,34 @@ into multiple sections, including literals generated by the assembler.
|
||||||
.end literal_prefix
|
.end literal_prefix
|
||||||
@end smallexample
|
@end smallexample
|
||||||
|
|
||||||
For the code inside the delimited region, the assembler puts literals in
|
By default the assembler places literal pools in sections separate from
|
||||||
the section @code{@var{name}.literal}. If this section does not yet
|
the instructions, using the default literal section names of
|
||||||
exist, the assembler creates it. The @var{name} parameter is
|
@code{.literal} for PC-relative mode @code{L32R} instructions and
|
||||||
optional. If @var{name} is not specified, the literal prefix is set to
|
@code{.lit4} for absolute mode @code{L32R} instructions (@pxref{Absolute
|
||||||
the ``default'' for the file. This default is usually @code{.literal}
|
Literals Directive}). The @code{literal_prefix} directive causes
|
||||||
but can be changed with the @samp{--rename-section} command-line
|
different literal sections to be used for the code inside the delimited
|
||||||
argument.
|
region. The new literal sections are determined by including @var{name}
|
||||||
|
as a prefix to the default literal section names. If the @var{name}
|
||||||
|
argument is omitted, the literal sections revert to the defaults. This
|
||||||
|
directive has no effect when using the
|
||||||
|
@samp{--text-@-section-@-literals} option (@pxref{Xtensa Options,
|
||||||
|
,Command Line Options}).
|
||||||
|
|
||||||
|
Except for two special cases, the assembler determines the new literal
|
||||||
|
sections by simply prepending @var{name} to the default section names,
|
||||||
|
resulting in @code{@var{name}.literal} and @code{@var{name}.lit4}
|
||||||
|
sections. The @code{literal_prefix} directive is often used with the
|
||||||
|
name of the current text section as the prefix argument. To facilitate
|
||||||
|
this usage, the assembler uses special case rules when it recognizes
|
||||||
|
@var{name} as a text section name. First, if @var{name} ends with
|
||||||
|
@code{.text}, that suffix is not included in the literal section name.
|
||||||
|
For example, if @var{name} is @code{.iram0.text}, then the literal
|
||||||
|
sections will be @code{.iram0.literal} and @code{.iram0.lit4}. Second,
|
||||||
|
if @var{name} begins with @code{.gnu.linkonce.t.}, then the literal
|
||||||
|
section names are formed by replacing the @code{.t} substring with
|
||||||
|
@code{.literal} and @code{.lit4}. For example, if @var{name} is
|
||||||
|
@code{.gnu.linkonce.t.func}, the literal sections will be
|
||||||
|
@code{.gnu.linkonce.literal.func} and @code{.gnu.linkonce.lit4.func}.
|
||||||
|
|
||||||
@node Absolute Literals Directive
|
@node Absolute Literals Directive
|
||||||
@subsection absolute-literals
|
@subsection absolute-literals
|
||||||
|
@ -721,11 +737,6 @@ To change the @code{L32R} mode, the program must write the
|
||||||
to keep track of the mode and indicate to the assembler which mode is
|
to keep track of the mode and indicate to the assembler which mode is
|
||||||
used in each region of code.
|
used in each region of code.
|
||||||
|
|
||||||
Literals referenced with absolute @code{L32R} instructions are always
|
|
||||||
placed in the @code{.lit4} section. PC-relative literals may be placed
|
|
||||||
in the current text section or in a separate literal section, as
|
|
||||||
described elsewhere (@pxref{Literal Directive}).
|
|
||||||
|
|
||||||
If the Xtensa configuration includes the absolute @code{L32R} addressing
|
If the Xtensa configuration includes the absolute @code{L32R} addressing
|
||||||
option, the default is to assume absolute @code{L32R} addressing unless
|
option, the default is to assume absolute @code{L32R} addressing unless
|
||||||
the @samp{--no-@-absolute-@-literals} command-line option is specified.
|
the @samp{--no-@-absolute-@-literals} command-line option is specified.
|
||||||
|
|
Loading…
Reference in a new issue