home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
World of A1200
/
World_Of_A1200.iso
/
programs
/
develop
/
phxass
/
phxass.doc
< prev
next >
Wrap
Text File
|
1995-02-27
|
40KB
|
1,147 lines
last change: 93-10-01
********************************
* *
* P h x A s s V 3.xx *
* *
* MC680x0/68851/6888x *
* Macro Assembler *
* *
* Written by Frank Wille *
* *
********************************
Preface
=======
PhxAss V3.xx is SHAREWARE and © copyright 1993 by Frank Wille. Commercial
usage of this program, without a written permission of the author, is strictly
forbidden!
PhxAss V3.xx supports all instructions and addressing modes of the following
Motorola processors: 68000,68010,68020,68030,68040,68851,68881,68882
I have completely rewritten huge parts of the source-code, e.g. the whole
addressing mode recognition and the specific code for all instructions.
Because of new searching algorithms the assembling is 15-45% (!) faster as
with version V2.x. On my 7 MHz 68010 A1000 I have measured nearly 25000
lines per minute.
This program is SHAREWARE. So if you like it, please send me 25 DM or 15$ to
become a registered user. In return you will get the newest updates.
Modifications to PhxAss V2.xx
=============================
Register symbols (EQUR) must be declared before they are used. This enables a
faster addressing mode recognition.
There are some new optimizations possible. The optimize-flags which can be
specified behind the -n option or after the OPT directive have completely
changed (see "Assembler Options").
If you have enabled the small-code model, all jumps which are referencing
external symbols are converted to PC-relative instead of long branch.
The '*'-symbol contains the current address. For example a 'bra *+10' would
branch to the location 12 bytes behind the 'bra'-opcode.
New directives: FPU, PMMU, CODE_C, CODE_F, DATA_C, DATA_F, BSS_C, BSS_F and
INCDIR.
Already mentioned above: The instructions and addressing modes of 68020-68040,
68851(PMMU) and 6888x(FPCP) are completely supported. You can use Motorola's
new addressing mode style even in the 68000 mode (e.g MOVE (4,A5),D0 ).
The new addressing mode recognition has no difficulties with parentheses '()'
instead of brackets '[]' to indicate a term. An operand like
-([x|y]*z)+6([addr+2,A4,regxy*QSIZE],[outerdisp+$100<<(1+3)]),((abc-xyz)+2,A3)
would cause no problems.
PhxAss enables floating-point numbers to be used with the 6888x (FPCP)
instructions. For example: fmove.d #3.1415926536,fp7
moves the double-precision number pi to the FPCP register seven.
Note: Ensure that your LIBS: directory contains the 'mathieeedoubbas.library'.
Since V3.10 PhxAss is able to optimize forward-branches, which are coming
into their 8/16-bit range by optimzation of the subsequent code. As a result,
other forward-branches could come into range and are also optimized, and so
on.
V3.30:
o Symbols which are preceded by a '.' will be regarded as local symbols too.
o A special version of PhxAss is available, which is not limited to the
maximum number of 65535 lines.
V3.40:
o Macro parameters may contain 63 characters now.
o The extended addressing mode recognition accepts the register symbols
ZD0-ZD7 and ZA0-ZA7 to specify a suppressed register.
o Two new escape codes available:
\e = escape ($1b) and \c = control sequence introducer ($9b).
V3.42:
o Float constants may be replaced by hex-constants now.
o When branch-optimization is activated, no extension-checking takes place.
The best-possible code will be generated.
V3.47
o New optimization-flag: 'I' forces PhxAss to ignore a 'Too large distance'
error.
V3.50
o '@' is allowed to be the first character of a symbol name, providing the
second character is non-numeric.
o The RORG directive is implemented.
o Two Devpac-specific directives are also supported now:
RSRESET and RS.x for faster reading of (Devpac) include files.
o The new option '-c' can be used to switch off the case-sensitivity.
V3.51
o RSSET was forgotten in V3.50
o New directives: IDNT, COMMENT, SUBTTL
V3.55
o From now on near-data symbols can be accessed not only by Absolute Addressing
but also by Address Register Indirect mode ( (An) must be the correct near-
data base register). This will make the assembling of your source much
faster, because PhxAss has to do less optimizations. As a side effect XREFs
will be interpreted correctly and must not be replaced by NREFs.
o If no unit name is given (by TTL or IDNT), PhxAss will use the name of the
source code without extension as the default unit name.
o The OFFSET directive is supported.
V3.60
o PhxAss V3.60 is pure! You can use the CLI-command RESIDENT to add it to the
resident list.
Bug fixes since V2.11
=====================
o Some instructions had generated a wrong error, e.g. TRAP and STOP generated
'Assembly aborted' instead of 'Out of range'.
o 'move.l #xxxx,-(a0)' produced an illegal opcode.
o If someone writes a program without first opening a section with CODE/CSEG,
SECTION or an initial label, all labels got wrong values.
o In some cases the equates file let PhxAss crash.
o A XDEF for a symbol which was already declared in another section would
add this symbol to the external-hunk of the section currently active.
o Jump to Branch optimization did not check the addressing mode of the
JMP/JSR instruction. It simply optimized all modes.
o A long branch to the next instruction was incorrectly optimized to $6x00.
o Bcc.B was not recognized as a short branch. PhxAss accepted only Bcc.S.
o The CNOP directive had disabled all optimizing in its section.
o The 'Word at odd address'-error crashed PhxAss sometimes.
o INITNEAR was useless in the absolute mode.
Bug fixes since V3.00
=====================
o TRACKDISK now really works.
o The 68020 addressing-mode ([Rn]) was assembled with a wrong size in pass one.
o The near-data range was incorrectly limited to 32k in object files.
o The formatted text-output should also work on OS2.xx/3.xx now.
o MOVE USP,An , MOVES and MOVEP produced incorrect code.
o GLOBAL and BSS destroyed the MSW-bits of the BSS-hunk type ($000003eb).
o CNOP definitely bug-free (I hope).
o References on "\@"-labels behind another macro nesting were impossible.
o "\@" only allowed 999 macro calls (now it's unlimited).
o Some extended adressing modes had made some problems:
([..],Rn.s|*x,od) and ([PC.. got a wrong size in pass one,
([BaseDisp]) generated an error and (bd,An/PC,Xn) (where bd is outside of
the normal 8-bit range) crashed PhxAss.
o FETOXM1 was forgotten (in my Reference Manual too).
o TAB-Codes within strings could not be expanded.
o Include paths which are suffixed by a ':' (volume names) were not recognized.
o FMOVEM.L Dn,FPcr got four bytes more in pass one than in pass two.
o Starting with page 100 the listing file became unreadable.
o The 'Out of memory' error was useless, because PhxAss crashed in most cases.
o CPUSHL,CINVL,CPUSHP,CINVP didn't work.
o BTST Dn,#x was missing.
o The new formard-branch optimization destroyed the CNOP-alignments, which
are located between the branch-instruction and the branch-destination.
o NARG was not zero for a macro call without arguments.
o INCLUDE/INCBIN without quotes caused an error.
Starting PhxAss
===============
Start the assembler by entering the command line:
PhxAss [<-options>] <filename> [<-options>]
where [<-options>] specify optional parameters and <filename> is the name of
the file to be assembled. If no extension in <filename> is given, the assembler
assumes ".asm" for being the extension. Some options cannot be specified before
the file name (see "Assembler Options").
<filename> must be the name of an assembler source code file. The source code
must be an ASCII text file where each line ends with a linefeed ($0a) character
(the format, which all Amiga editors generate). TAB-codes ($09) are allowed.
When the assembler is running, it can be stopped at any time with CTRL-C.
Assembler Options
=================
The following assembler options are supported by PhxAss V3.xx :
-o<filename> Defines the name of the output file. If not specified,
PhxAss takes the source code's filename and replaces
its extension with ".o" .
-d The names of all global labels of each section are
written to symbol data blocks. A debugger can use
these names instead of addresses.
-a Enable auto-align for DC.x directives. All DC.W, DC.L,
etc. directives in the code will be automatically
aligned to word-boundaries.
-c Case-sensitivity off. All symbol names will be con-
verted to upper case. This will slow down PhxAss (5%).
-s<symname>[=value] Predefines a symbol by SET directive. If the value is
missing, the symbol will be set to 1.
-e[<filename>] Generates an equates file. If <filename> is missing,
the name of the source code with extension ".equ" will
be used. Cannot be specified before the name of the
source code.
-l[<filename>] Generates a listing file. If <filename> is missing, the
name of the source code with extension ".lst" will be
used. Cannot be specified before the name of the source
code.
-x Includes a reference list of all global symbols in the
listing file. If no listing file was opened, this
option will cause an error.
-p[<lines>] Sets the page length for equates and listing files.
If <lines> isn't specified or set to zero, no form.
feed ($0c) characters will be generated. The default
value is 60 lines.
-q Quiet mode. The assembler makes no outputs until an
error occurs.
-i<path1>[,<path2>..] Defines one or more include-paths which will be used
by the INCLUDE and INCBIN directives.
-h<name1>[,<name2>..] Defines one or more INCLUDE directives at the top of
the source code.
-mf Forces the whole code to use the large code and large
data model. NEAR directives within the source code
will be ignored.
-mn[<areg>][,<secnum>] Forces the whole code to use the small data model.
or [,S...] <areg> (default: 4) specifies the number of the
address register which will be used as pointer to the
small data section. Only the registers A2-A6 can be
used. <secnum> is the number of the section which will
be the small data section (defaults to -1).
If <secnum> is -1 or if a string, starting with 'S'
(e.g. "SmallData"), is specified instead of the
section number, all Data and Bss sections will be
treated as a whole small data section. They are
coalesced by calling the linker with the small data
option.
-mc Forces the whole code to use the small code model.
All JSR and JMP instructions which are referencing
external symbols are converted to PC-relative jumps.
-n[<Flags>] Sets the optimize flags. The following characters can
be specified after '-n':
N (Normal)
Standard optimizations:
clr.l -> moveq #0, move.l -> moveq,
link.l(68020) -> link.w, adda/suba -> lea
($xxxx).L -> ($xx).W, 0(An) -> (An)
R (Relative)
($xxxx) -> xx(PC)
Q (Quick)
Conversions to addq/subq
B (Branches)
Bcc.l(68020) -> Bcc.w -> Bcc.b, jmp/jsr -> bra/bsr
T (Total branch optimization)
Bcc.l(68020) -> Bcc.w -> Bcc.b (forward branches)
Only active if 'B' is also selected.
WARNING! If you use this option together with a
listing file, then you can't rely on the line-
addresses.
L (Logical Shifts)
lsl #1,Dn -> add Dn,Dn
lsl.w/b #2,Dn -> add Dn,Dn add Dn,Dn
P (PEA/LEA conversion)
move.l #x,An -> lea x,An
-> lea x(PC),An / lea x.w,An
move.l #x,-(SP) -> pea x -> pea x(PC) / pea x.w
S (Special, e.g. Read-Modify-Write operations)
pea 0 -> clr.l -(SP)
add/sub #0,An or lea 0(An),An -> (remove)
The following are not recommendable for a MC68000
accessing hardware registers:
move #0,<ea> -> clr <ea>
move.b #-1,<ea> -> st <ea>
M (MOVEM)
movem Rn,<ea> -> move Rn,<ea>
movem ,<ea> -> (remove)
I (Ignore too large distances)
Distances, which are currently out of range will
not cause an error. This is useful for originally
assembling a reassembler-output or when you are
sure that all distances will come into range again,
by optimization of the subsequent code.
BE CAUTIOUS!!! If a distance has not come into
range, PhxAss will write faulty code!
There are two short cuts:
* Selects all standard optimizations & T (-nnrqbt).
! Enables all optimizations possible (-nnrqbtlpsm).
-n without parameters will forbid any optimizing.
If -n is not specified the assembler uses standard
optimization (-nnrqb).
Programmer Information
======================
1. Comments
Comments start with a ';' or with a '*'. The text which follows after the
operand field is also a comment and doesn't need ';' or '*'.
Example:
; Comment text
moveq #0,d0
** This is a comment too **
nop ; comment
add.l d0,d0 comment after operand field
If no operand field is given, e.g. after the NOP instruction, the comment must
be preceded by a ';'. The example above without a semicolon after the NOP
would make the assembler to treat 'comment' as its operand.
'*' is not allowed as a comment-introducer behind an instruction or directive.
2. Labels
Labels must start in the first column of a line. The colon at the label's end
is optional.
Example:
Label: moveq #0,d0
Local labels have a '$' suffixed or are preceded by a '.' (since V3.30). They
are only valid between two global labels.
Example:
Global1: add.w d0,d1
beq.s local1$
bpl.s .local2
rts
local1$: moveq #-1,d0
.local2: rts
Global2:
The length for global and local labels is unlimited. Valid characters for the
labels are: 'a'-'z', 'A'-'Z', '0'-'9' and '_' . The first character can be a
'.', but global labels cannot start with a digit.
The special '*'-symbol always contains the current address. This enables
instruction like: bra *+4
CAUTION! Forward references with '*' will be corrected by PhxAss, but backward
references won't!
3. Executable M68000 instructions
They have the general format:
label operation operands
PhxAss recognizes all operations found in Motorola's M68000PM/AD Programmer's
Reference Manual and all of the common additions and short forms like BHS
instead of BCC, BLO instead of BCS, MOVE instead of MOVEA, ADD instead of
ADDI, etc. . In the current version all MC68000,68010,68020,68030,68040,
68851,68881 and 68882 instructions are completely supported.
The operand field consists of one to four (68851) operands seperated by a
comma with no imbedded spaces.
4. Expressions
Expressions consist of symbols and constants. Symbols can be absolute,
relocatable or external. The arithmetic operations supported by PhxAss are
(from highest to lowest precedence) :
~ not (unary) - negation (unary)
<< shift left >> shift right
* multiplication / division // modulo
& and | or ('!' also allowed) ^ exclusive or
- subtraction + addition
( ) parentheses or [ ] brackets
For absolute symbols and constants (which are absolute too), all arithmetic
operations are allowed.
If relocatables or externals occur in the expression, only subtraction and
addition is possible with some restrictions:
reloc - abs extern - abs reloc - reloc
reloc + abs extern + abs abs + reloc abs + extern
are defined, the others are illegal.
There are six types of constants:
Hexadecimal, preceded by a '$', consists of '0'-'9' and 'A'-'F' (or 'a'-'f')
Decimal, consists of '0'-'9'
Float, has the format [+/-][integer][.fraction][E[+/-]exponent]
Octal, preceded by a '@', consists of '0'-'7'
Binary, preceded by a '%', consists of '0' and '1'
String, embedded by ' or ", consists of one to four characters.
The character '\' is an escape-symbol, which can generate the following codes:
\\ the '\'-character itself
\' character #39 (single quote)
\" character #34 (quote)
\0 character #0 (string terminator)
\n character #10 (line feed)
\f character #12 (formular feed)
\b character #8 (backspace)
\t character #9 (tabulator)
\r character #13 (carriage return)
\e character #27 (escape)
\c character #155(control sequence introducer)
5. Directives
The following paragraphs describe all directives that are supported by the
assembler.
EQU
symbol equ <expression>
symbol = <expression>
The expression will be assigned to the symbol.
EQU.x
symbol equ.x <float symbol or constant>
symbol =.x <float symbol or constant>
An equate with the extension .d,.f,.p,.s,.x or .q will assign the value
of a floating-point expression to the symbol. No arithmetic operations
are allowed with floating-point. The expression must be a constant or
another floating-point symbol.
EQUR
symbol equr <register>
This directive assigns a register (D0-D7,A0-A7 or SP) to the symbol.
Since V3.00 a register symbol must be declared before it is used.
REG
symbol reg <register list>
This directive assigns the value of the register list to the symbol.
Valid register lists contain several register names (see EQUR)
separated by the '/' character. The '-' character defines a range of
registers. The following are valid register lists:
a1/a3-a5/d0/d2/d4
d0-d7/a2-a6
d1-3/d5-7/a0-1/a3-6 (since V3.56)
SET
symbol set <absolute expression>
This directive assigns the value of the expression to the symbol. No
relocatables or externals are allowed within the expression. A symbol
defined by a SET directive may change its value by another SET.
There are some set-symbols which are defined by PhxAss:
_PHXASS_ set 1
_VERSION_ set version<<16+revision
According to the connected processor and co-processor PhxAss will set
_MC68000_, _MC68010_, _MC68020_ and _MC68881_. The symbols _MC68030_,
_MC68040, and __MC68882_ will only be created when OS2/3.x is present.
NARG is zero outside a macro. Within a macro NARG is set to the number
of specified arguments.
RSRESET
This directive resets the internal RS-counter.
RSSET
rsset [<count]
This directive sets the internal RS-counter to the <count> expression.
RS
[symbol] rs.x [<count>]
RS assigns the value of the internal RS-counter to the symbol, then it
increases the counter by the extension size multiplied with <count>. If
<count> is missing, it defaults to zero. For valid extensions see the
DC directive.
IDNT
idnt <name>
This directive sets the name of the object file unit which the assembler
will generate. By default, it will be the name of the source file without
the extension.
TTL
See IDNT.
SUBTTL
subttl will cause no error with PhxAss, but for now it does nothing.
COMMENT
comment text
You may write any text you like behind this directive.
LIST
The following source code will be written to the listing file.
NOLIST
The following source code will not be written to the listing file.
OPT
opt <optimize flags>
Changes optimization. For a listing of all optimize flags, see "Assembler
Options".
MACRO, ENDM
symbol macro
...text...
endm
macro symbol
...text...
endm
This directive assigns a macro to the symbol. The symbol may appear on
the left or the right side of the directive. The text between the MACRO
and ENDM directives will be inserted into the source code when the
assembler discovers the symbol. When calling the macro, up to nine
arguments, separated by a comma, can be specified in the operand field.
They are referenced in the macro text as '\1' through '\9'. '\0' is
reserved for the extension of the macro symbol. Example:
bhs macro
bcc.\0 \1
endm
This macro can be called by: bhs.s label
".s" will be assigned to \0 and "label" will be assigned to \1.
A "\@" within the macro is replaced by text of the form "nnn", where
nnn is a unique three-digit number for each macro call. Labels within a
macro should consist of "\@", because defining labels twice is illegal.
MEXIT
Upon encountering this directive within a macro, the assembler scans for
the ENDM directive and leaves the macro.
END
In pass one the assembler ignores the rest of the source code and starts
pass two. In pass two the assembler closes all files and terminates.
By default the assembler terminates at end of file.
FAIL
The assembler displays the error "69 Assembly aborted !" and terminates.
ECHO
echo <string>
The assembler echoes the string. If <string> isn't specified, only a
newline is echoed.
MACHINE
machine <processor-number>
This directive sets the processor-type for which the code will be
generated. Valid processor-numbers are:
68000, 68010, 68020, 68030, 68040
FPU
fpu [<cpID>]
This directive enables code generation for a MC68881/68882 coprocessor.
By default the <cpID> is set to one, which should be the correct ID for
most systems using a floating point coprocessor.
Never set <cpID> to zero, because this is the constant ID for a PMMU.
If you have set the processor-type to 68040 you should not use this
directive.
PMMU
This directive enables code generation for a MC68851 Paged Memory
Management Unit. PMMU only makes sense if you have set the processor-
type to '68020'.
SECTION
section <name>[,<type>[,<memflag>]]
The following code will be placed in the section named <name>. There
are three section types: CODE, DATA and BSS. CODE contains the executable
M68000 instructions, DATA contains initialized data and BSS contains un-
initialized data (set to zero before the program is started). By default
<type> is set to CODE. The section will be loaded to the memory indicated
by the <memflag> argument. This can be FAST or CHIP. By default the
section will be loaded to the memory with the highest priority.
For compatibility reasons CODE_C, DATA_C and BSS_C are also recognized as
section type since V3.56.
Creating a section lets the assembler change into relocatable mode. In
this mode the following directives are illegal:
org, load, file, trackdisk
CODE, CSEG
These directives correspond to: section "CODE",code
DATA, DSEG
These directives correspond to: section "DATA",data
CODE_C, CODE_F, DATA_C, DATA_F, BSS_C, BSS_F
See CODE, DATA or BSS. In addition a memflag will be set, which causes
the section to be loaded to FAST (xxx_F) or to CHIP (xxx_C).
BSS (1)
This directive corresponds to: section "BSS",bss
BSS (2)
bss symbol,<size>
BSS with arguments does not start a section. It defines a symbol to be
in the BSS-section, reserves <size> bytes in this section and assigns
the address of the first byte to the symbol.
GLOBAL
global symbol,<size>
This directive does the same as BSS symbol,<size>. In addition GLOBAL
will declare the symbol as XDEF (ext_def).
OFFSET
offset [<start offset>]
This directive indicates the beginning of a special offset-section. All
the labels, which are declared in this section, will be treated as
absolute offsets instead of addresses. <start offset> defaults to zero.
This might be useful for declaring structure offsets with the DS.x
directive. While writing programs for PhxAss you should prefer the faster
RSRESET, RSSET and RS.x directives. OFFSET was mainly implemented for
compatibility reasons.
INCDIR
incdir <path1>[,<path2>,...]
This directive does the same like the -i option (see Assembler Options).
INCLUDE
include <filename>
This directive causes PhxAss to suspend the assembling of the current
file and to assemble the file named <filename>. When done, the assembler
continues assembling the original file.
If PhxAss can't find the include file, it first searches within the
include directory defined by the environment variable PHXASSINC. Then
it searches within the include directories defined by INCDIR and the
-i assembler option (see "Assembler Options").
INCBIN
incbin <filename>
This directive causes the assembler to include a binary file into the
current section (e.g. graphics, samples or trigonometrical tables).
The assembler searches in the same include directories like INCLUDE.
XREF
xref symbol1[,symbol2,...]
This directive tells the assembler that the specified symbols are
externally defined and will be inserted by the linker.
NREF
nref symbol1[,symbol2,...]
This directive does the same like XREF, but the assembler is forced to
use these symbols as small-data relocatables.
XDEF
xdef symbol1[,symbol2,...]
This directive causes the assembler to add the names and values of the
specified symbols to the external-block of the object file. The linker
can read the values of these symbols and insert them into other object
files.
PUBLIC
public symbol1[,symbol2,...]
When the specified symbols are defined in the current code, PUBLIC will
do the same like XDEF. When the symbols are unknown, PUBLIC will do the
same like XREF.
ORG
org address
Defines the origin of the following code and lets the assembler change
into absolute mode. Since V1.8 several ORG directives are allowed and
each one can be seen as a new section. The following directives are
illegal in absolute mode:
ttl, code, cseg, data, dseg, bss, section, offset, xref, nref, xdef,
public, idnt.
LOAD
load address
After assembling is done, the executable code will be loaded to this
address. By default the code will be loaded to the address which was
specified as origin.
FILE
file <filename>
After assembling is done, the executable code will be written to the file
named <filename>.
TRACKDISK
trackdisk <drive>,<startblock>[,<offset>]
After assembling is done, the executable code will be written directly to
floppy disk using the 'trackdisk.device'. <drive> is valid from 0 to 3.
<startblock> is valid from 0 to 1759. <offset>, which is zero by default,
specifies the byte-offset within a block and is valid from 0 to 511.
NEAR
near [An[,<secnum> | SmallData]]
This directive initializes the parameters used by the near-data model.
NEAR with arguments may appear only once in the whole source code. After
initializing the small-data model, it can be switched on and off by NEAR
and FAR without arguments. In this mode you are allowed to access near-
symbols via 'NearSymbol(An)'. Absolute references will be automatically
converted to Address Register Indirect, if possible.
The first argument, the address-register, is valid from A2 to A6 and will
be A4 by default. <secnum>, which defaults to zero, specifies the number
of the section which will be accessed by Address Register Indirect mode.
If <secnum> is -1 or a string starting with 'S' or 's', all Data and Bss
sections will be treated as near-sections and can be coalesced by the
linker.
near code
If the argument equals to the string "CODE" the assembler activates the
small-code model. This will force all absolute XREF jumps into PC-
relative mode.
FAR
This directive turns off the small-data model when active.
INITNEAR
This directive inserts two M68000 instructions into the code which will
initialize the small-data model depending on the parameters set by the
NEAR directive. The assembler will generate this code (10 bytes):
lea SmallDataBase,An
lea 32766(An),An
DC
label dc.x <value>[,<value>,...]
label dc.b "string"[,...]
The DC (Define Constant) directive causes one or more fields of memory
to be allocated and initialized. Each field has the same size, specified
by the extension of the directive. Each byte, word or longword <value>
can be an expression and may contain forward references. For floating-
point and quadword types only constants are allowed. The following
extensions are valid:
.B (1 byte) Byte .W (2 bytes) Word
.L (4 bytes) Longword .F (4 bytes) Fast Floating Point
.S (4 bytes) Single Precision .D (8 bytes) Double Precision
.Q (8 bytes) Quadword(V3.42) .X (12 bytes) Ext. Precision
.P (12 bytes) Packed BCD
If the extension is .B, .W or .L several values can be expressed by a
string, but when using word- or longword-size the string must be aligned.
DCB, BLK
label dcb.x <num>[,<fill>]
label blk.x <num>[,<fill>]
These directives allocate a block of memory having <num> entries. The
available entry-sizes are the same like above. The block will be
initialized with <fill> which is zero when missing.
DS
label ds.x <num>
This directive allocates a block of memory having <num> entries and
initializes each field with zero. See DCB, BLK.
CNOP
cnop <offset>,<align>
This directive aligns the address of the following code to <align>. Then
the <offset> is added. Example: cnop 2,4 . This example would
align the next address two bytes behind the next longword boundary.
EVEN
This directive equals to cnop 0,2 which will make the address word-
aligned.
IFcond, ELSE, ENDIF, ENDC
These directives support conditional assembling. The general form of the
IF directive is:
ifcond <expression> or symbol
...
[else
...]
endc (or endif)
PhxAss supports the following conditions:
IFC "string1","string2" compares two strings. This is useful within
macros, when the strings contain macro-
arguments '\x' .
IFD/IFND symbol Tests if the symbol is defined (undefined).
IFEQ/IFNE <exp> Tests if <exp> is zero (not zero).
IFGT/IFLT <exp> Tests if <exp> is greater (less) than zero.
IFGE/IFLE <exp> Tests if <exp> is greater (less) than or
equal to zero.
Linker
======
You may use every linker which supports the standard Amiga-DOS object file
format. If you want to use the small-data model, you should test how small-data
references (HUNK_DREL16 = $3f8) are interpreted by your linker. They are for
exmaple correctly interpreted by PhxLnk and DLink. BLink (PD and Lattice-C)
displays no error but generates wrong code.
Assembler Errors
================
In the current version of PhxAss the following errors can be generated:
01 Out of memory
02 Only ONE source file can be specified
Example: phxass file1 file2 -> Error 02
03 Listing file option was declared twice
04 Need source file for this option
Example: phxass -e srcfile or phxass -l srcfile -> Error 04
phxass srcfile -e -> ok
05 Equates file option was declared twice
06 Need file name after -o option
07 Need file name after -h option
08 Need directory name after -i option
09 Illegal model. Use F for far or N[2-6][,SecNum] for near
10 Illegal base register for the near-mode
Valid base registers are: A2-A6
11 Missing source file name
12 File doesn't exist
13 Missing include file name
14 Read error
15 String buffer overflow
Source code lines are limited to 79 characters.
16 Too many sections
Maximum is 255 sections.
17 Symbol can't be declared as external
XDEF can only be used with absolute or relocatable symbols.
18 Symbol was declared twice
19 Unable to declare XREF-symbol
A symbol, which is defined in the current source code, can't be an external.
20 Illegal opcode extension
Legal: .b .w .l .s .f .d .x .p .q
21 Illegal macro parameter
Possible parameters are: \0 (opcode extension), \1 - \9 and \@
22 Illegal characters in label
See Labels chapter in Programmer Information.
23 Unknown directive
The opcode is neither a 680x0-mnemonic nor an assembler directive or macro.
24 Too many parameters for a macro
Nine parameters ( \1 to \9 ) are possible.
25 Can't open trackdisk.device
26 Argument buffer overflow
Arguments are limited to 79 chracters.
27 Bad register list
Valid register lists: d0-d3 d3-d4/a2 d2/d3/a4-a6 d7 a0/d2 d2-6/a0-4
28 Missing label
This directive requires a label.
29 Illegal seperator for a register list
Valid seperators are '-' and '/'.
30 SET, MACRO, XDEF, XREF and PUBLIC are illegal for a local symbol
31 Not a register (try d0-d7 or a0-a7 or sp)
32 Too many ')'
33 Unknown addressing mode
See Motorola's "8-/16-/32-bit Microprocessor User's Manual" for a
description of all addressing modes.
34 Addressing mode not supported
Example: move.b d0,a1 / move usp,d2 / clr.w (d3)+ -> Error 34
35 Can't use macro in operand
Macros must be used as opcodes.
36 Undefined symbol
37 Missing register
Example: mulu d0, -> Error 37
38 Need data-register
39 Need address-register
40 Word at odd address
Example: dc.b "Hallo"
dc.w 0 -> Error 40
Insert CNOP 0,2 or EVEN after string-constants.
41 Syntax error in operand
42 Relocatability error
Example: move.l label(pc),d0 , where label is not a reloc. and/or label
is not defined in the current section -> Error 42
43 Too large distance
Example: move.w 50000(a0),d0 -> Error 43
Too large distance for a displacement by indirect addressing or branch.
Short branches have a range of +126/-128 bytes. Long branches have a range
of +32766/-32768 bytes.
44 Displacement expected
Example: label: move.l label(a2),d1 -> Error 44
45 Valid address expected
A program-address was expected.
46 Missing argument
47 Need numeric symbol
48 Displacement outside of section
Example: bra label , where label is not defined in the current section
-> Error 48
49 Only one distance allowed
Expression can't contain several distances.
Example: move.l #[label1-label2]+[label3-label4],d0 -> Error 49
50 Missing bracket/parenthesis
51 Expression stack overflow
A maximum of 128 arguments are allowed in one expression.
52 Unable to negate an address
53 Can't use distance and reloc in the same expression
54 Can't shift an address
55 Can't multiply an address
56 Overflow during multiplication
57 Can't divide an address
58 Division by zero
59 No logical operation allowed on addresses
60 Need two addresses to make a distance
61 Unable to sum addresses
62 Write error
63 Alignment error
Example: dc.l "XYZ" -> Error 63
64 Can't subtract a XREF
Valid operations with externals: ext + abs , abs + ext and ext - abs
65 Impossible in absolute mode
These directive can't be used in absolute mode:
ttl, code, cseg, data, dseg, bss, section, xref, nref, xdef, public
66 Unknown error (fatal program failure)
The assembler or its memory was corrupted by a faulty program running at
the same time.
67 No externals in absolute mode
See 65.
68 Out of range
Example: addq.l #9,d1 -> Error 68
69 Assembly aborted
Generated by the FAIL directive.
70 Missing ENDC/ENDIF
71 Missing macro name
72 Missing ENDM
73 Can't define macro within a macro
74 Unexpected ENDM
75 Unexpected ENDC/ENDIF
76 Impossible in relative mode
These directive can't be used in relative mode: org, file, load, trackdisk.
77 Parameter buffer overflow
Parameters are limited to 79 characters.
78 Can't open timer.device
79 Unable to create file
Maybe the destination disk is write-protected.
80 Need listing file to add references
-x option was specified without the -l option.
81 No address allowed here
Example: ds.l label -> Error 81
82 Illegal characters in symbol
See error 22.
83 Source code too large (max. 65535 lines)
84 No floating point without mathieeedoubbas.library
To use floating point symbols, you must have the mathieeedoubbas.library
in your LIBS: directory.
85 IEEE Double Precision Overflow/Underflow
86 IEEE Single Precision Overflow/Underflow
87 Motorola FFP Overflow/Underflow
88 Incompatible float types
89 Packed BCD Overflow/Underflow
90 Can't mix LOAD, FILE and TRACKDISK
Example: load $70000
file "mycode" -> Error 90
91 Near mode not activated
The near mode must be activated first, before using the INITNEAR directive.
92 Instruction not implemented in your machine
The instruction exists for another processor, but not for your one. Use
MACHINE to change processor type.
93 Illegal scale factor
Example: move.w (a1,d2*3) -> Error 93
Valid scale factors are: 1, 2, 4 and 8
94 Missing operand
Example: move.l (a0)+ -> Error 94
95 Section doesn't exist
This error is caused by specifying an illegal section number in the NEAR
directive.
History
=======
After six years of working with assemblers like SEKA, AS (Aztec-C) and A68k,
I decided in December 1991 that I need a new, powerful assembler. First, I had
the idea to buy O.M.A. or Devpac, but I don't like these modern assemblers with
an integrated editor. Other reasons for starting the development of PhxAss were
the chronic lack of money (I'm student) and the possibility to create an
assembler which will satisfy all of my demands.
I completed the first version V1.00 at the 28th of January in 1992. From now
on I used PhxAss to assemble itself (first I used A68k). It took me more than
a year and 23 versions to reach V3.00 (PhxAss was not my only project in this
period).
Here is a list of my hardware and literature that enabled the development of
PhxAss:
Hardware: My good old A1000 (first version from '85) with 68010 CPU,
2 MB Fast-RAM and a 33 MB Harddisk.
Literature: Motorola MC68000/68008/68010/68HC000 8-/16-/32-Bit Microprocessor
User's Manual (Prentice Hall)
Motorola MC68020 32-Bit Microprocessor User's Manual (Prentice
Hall)
Motorola MC68881/882 Floating-Point Coprocessor User's Manual
(Prentice Hall)
Motorola MC68851 Paged Memory Management Unit User's Manual
(Prentice Hall)
Motorola M68000,MC68020,MC68020,MC68040,MC68851,MC68881/882
Programmer's Reference Manual (Prentice Hall)
Amiga ROM Kernel Reference Manual: Libraries & Devices (Addison-
Wesley)
Amiga ROM Kernel Reference Manual: Includes & Autodocs (Addison-
Wesley)
Amiga Intern (Data Becker)
Amiga Intern Band 2 (Data Becker)
Bugs
====
Known bugs in version V3.60:
o Floating-point symbols defined by the EQU.x directive do not appear in the
equates file.
o When the instruction xxxx is removed by optimization, PhxAss generates an
illegal short branch with zero displacement.
Bcc.s label
xxxx
label:
This can only happen when you have set the optimize flag 'M' and xxxx is a
MOVEM without registers or when you have set the 'S'-flag and xxxx is a
'ADDA/SUBA #0,An' or 'LEA 0(An),An'.
o Because of many misprints in Motorola's Programmer's Reference Manual I was
forced to estimate the opcodes of some instructions (FSABS and FDABS).
o The Forward-Branch optimization (T-flag) doesn't change the line-addresses
in the listing file.
o The following lines from the orignial Commodore include file "exec/types.i"
can't be assembled and must be changed:
\@BITDEF SET 1<<\3
BITDEF0 \1,\2,F_,\@BITDEF
change to:
BITDEF\@ SET 1<<\3
BITDEF0 \1,\2,F_,BITDEF\@
USERS OF 32-BIT PROCESSORS AND COPROCESSORS:
Please try to test all specific instructions of your processor and send me
your bug-reports. In return you will get the newest version.
If any bugs or questions occur, please write to :
Frank Wille
Auf dem Dreische 45
32049 Herford
GERMANY
__
///
///
///
__ ///
\\\ ///
\\\ ///
\\\///
\XX/ A M I G A F O R E V E R !