f78 HPPA Dependent Features Contents|Index|Previous|Next

HPPA Dependent Features

See the following documentation for the HPPA architecture’s features and options for the assembler.

Options for HPPA

Syntax for HPPA

Floating Point for HPPA

Assembler Directives for HPPA

Opcodes for HPPA

As a back end for GNU CC, as has been thoroughly tested and should work extremely well. We have tested it only minimally on hand-written assembly code and no one has tested it much on the assembly output from the HP compilers.

The format of the debugging sections has changed since the original as port (version 1.3X) was released; therefore, you must rebuild all HPPA objects and libraries with the new assembler so that you can debug the final executable.

The HPPA as port generates a small subset of the relocations available in the SOM and ELF object file formats. Additional relocation support will be added as it becomes necessary.

Options for HPPA

as has no machine-dependent command-line options for the HPPA.

Syntax for HPPA

The assembler syntax closely follows the HPPA instruction set reference manual; assembler directives and general syntax closely follow the HPPA assembly language reference manual, with a few noteworthy differences.

First, a colon may immediately follow a label definition. This is simply for compatibility with how most assembly language programmers write code.

Some obscure expression parsing problems may affect hand written code which uses the spop instructions, or code which makes significant use of the ! line separator.

as is much less forgiving about missing arguments and other similar oversights than the HP assembler. as notifies you of missing arguments as syntax errors; this is regarded as a feature, not a bug.

Finally, as allows you to use an external symbol without explicitly importing the symbol.

Warning:
In the future this will be an error for HPPA targets.

Special characters for HPPA targets include the following.

as00090000.gif ; is the line comment character.

as00090000.gif ! can be used instead of a newline to separate statements.

as00090000.gif Since $ has no special meaning, you may use it in symbol names.

Floating Point for HPPA

The HPPA family uses IEEE floating-point numbers.

Assembler Directives for HPPA

as for the HPPA supports many additional directives for compatibility with the native assembler. This section describes them only briefly. For detailed information on HPPA-specific assembler directives, see HP9000 Series 800 Assembly Language Reference Manual (HP 92432-90001).

as does not support the following assembler directives described in the HP manual.

.endm         .listoff        .macro
.enter
        .liston
.leave
        .locct

Beyond those implemented for compatibility, as supports one additional assembler directive for the HPPA: .param. It conveys register argument locations for static functions. Its syntax closely follows the .export directive.

The following are the additional directives in as for the HPPA:

.block n

.blockz n
Reserve n bytes of storage, and initialize them to zero.

.call
Mark the beginning of a procedure call. Only the special case with no arguments is allowed.

.callinfo [param=value, ...][flag, ...]
Specify a number of parameters and flags that define the environment for a procedure. param may be any of frame (frame size), entry_gr (end of general register range), entry_fr (end of float register range), entry_sr (end of space register range). The values for flag are calls or caller (proc has subroutines), no_calls (proc does not call subroutines), save_rp (preserve return pointer), save_sp (proc preserves stack pointer), no_unwind (do not unwind this proc), hpux_int (proc is interrupt routine).

.code
Assemble into the standard section called $TEXT$, subsection $CODE$.

.copyright string
In the SOM object format, insert string into the object code, marked as a copyright string.

.enter
Not yet supported; the assembler rejects programs containing this directive.

.entry
Mark the beginning of a procedure.

.exit
Mark the end of a procedure.

.export name[,typ][,param=r]
Make a procedure name available to callers. typ, if present, must be one of absolute, code (ELF only, not SOM), data, entry, data, entry, millicode, plabel, pri_prog, or sec_prog.

param, if present, provides either relocation information for the procedure arguments and result, or a privilege level. param may be argw n (where n ranges from 0 to 3, and indicates one of four one-word arguments); rtnval (the proce-dure’s result); or priv_lev (privilege level). For arguments or the result, r specifies how to relocate, and must be one of no (not relocatable), gr (argument is in general register), fr (in floating point register), or ‘fu’ (upper half of float register). For priv_lev, r is an integer.

.half n
Define a two-byte integer constant n; synonym for the portable as directive, .short.

.import name[,typ]
Converse of .export; make a procedure available to call. The arguments use the same conventions as the first two arguments for .export.

.label name
Define name as a label for the current assembly location.

.leave
Not yet supported; the assembler rejects programs containing this directive.

.origin lc
Advance location counter to ffb lc. Synonym for the {No value for ‘‘as’’} portable directive .org.

.param name[,typ][,param=r]
Similar to .export, but used for static procedures.

.proc
Use preceding the first statement of a procedure.

.procend
Use following the last statement of a procedure.

label.reg expr
Synonym for .equ; define label with the absolute expression expr as its value.

.space secname[,params]
Switch to section secname, creating a new section by that name if necessary. You may only use params when creating a new section, not when switching to an existing one. secname may identify a section by number rather than by name. If specified, the list params declares attributes of the section, identified by keywords. The keywords recognized are spnum=exp (identify this section by the number exp, an absolute expression), sort=exp (order sections according to this sort key when linking; exp is an absolute ex-pression), unloadable (section contains no loadable data), notdefined (this section defined elsewhere), and private (data in this section not available to other programs).

.spnum secnam
Allocate four bytes of storage, and initialize them with the section number of the section named secnam. (You can define the section number with the HPPA .space directive.)

.string str
Copy the characters in the stri ffb ng str to the object file. See Strings for information on escape sequences you can use in as strings.

Warning:
The HPPA version of
.string differs from the usual as definition: it does not write a zero byte after copying str.

.stringz str
Like .string, but appends a zero byte after copying str to object file.

.subspa name[,params]

.nsubspa name[,params]
Similar to .space, but selects a subsection name within the current section. You may only specify params when you create a subsection (in the first instance of .subspa for this name). If specified, the list params declares attributes of the subsection, identified by keywords. The keywords recognized are quad=expr (“quadrant” for this subsection), align=expr (alignment for beginning of this subsection; a power of two), access=expr (value for “access rights” field), sort=expr (sorting order for this subspace in link), code_only (subsection contains only code), unloadable (subsection cannot be loaded into memory), common (subsection is common block), dup_comm (initialized data may have duplicate names), or zero (subsection is all zeros, do not write in object file).

.nsubspa always creates a new subspace with the given name, even if one with the same name already exists.

.version str
Write str as version identifier in object code.

Opcodes for HPPA

For detailed information on the HPPA machine instruction set, see PA-RISC Architecture and Instruction Set Reference Manual (HP 09740- 90039).

0