home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
C/C++ Interactive Guide
/
c-cplusplus-interactive-guide.iso
/
c_ref
/
csource4
/
242_01
/
a51.doc
< prev
next >
Wrap
Text File
|
1989-01-13
|
46KB
|
1,233 lines
/*
HEADER: CUG242;
TITLE: 8051 Cross-Assembler (Portable);
FILENAME: A51.DOC;
VERSION: 0.4;
DATE: 11/09/1988;
SEE-ALSO: A51.H;
AUTHORS: William C. Colley III;
*/
8051 Cross-Assembler (Portable)
Version 0.4
Copyright (c) 1985,1987 William C. Colley, III
The manual such as it is.
Legal Note: This package may be used for any commercial or
non-commercial purpose. It may be copied and
distributed freely provided that any fee charged
by the distributor of the copy does not exceed the
sum of: 1) the cost of the media the copy is
written on, 2) any required costs of shipping the
copy, and 3) a nominal handling fee. Any other
distribution requires the written permission of
the author. Also, the author's copyright notices
shall not be removed from the program source, the
program object, or the program documentation.
Table of Contents
1.0 How to Use the Cross-Assembler Package .................. 3
2.0 Format of Cross-Assembler Source Lines .................. 4
2.1 Labels ............................................. 5
2.2 Numeric Constants .................................. 6
2.3 String Constants ................................... 6
2.4 Expressions ........................................ 6
2.5 Bit Expressions .................................... 7
3.0 Machine Opcodes ......................................... 8
3.1 Opcodes -- No Arguments ............................ 8
3.2 Opcodes -- One Argument ............................ 8
3.3 Opcodes -- Two Arguments in Order .................. 9
3.4 Opcodes -- Two Arguments in Either Order ........... 9
3.5 Opcodes -- Three Arguments in Order ................ 9
3.6 Opcodes -- Relative Branches ....................... 9
3.7 Opcodes -- Absolute Branches ....................... 9
3.8 Opcodes -- Long Branches ........................... 10
3.9 Opcodes -- MOV ..................................... 10
4.0 Pseudo Opcodes .......................................... 10
4.1 Pseudo-ops -- BIT .................................. 10
4.2 Pseudo-ops -- DB ................................... 10
4.3 Pseudo-ops -- DS ................................... 11
4.4 Pseudo-ops -- DW ................................... 11
4.5 Pseudo-ops -- END .................................. 11
4.6 Pseudo-ops -- EQU .................................. 12
4.7 Pseudo-ops -- IF, ELSE, ENDIF ...................... 12
4.8 Pseudo-ops -- INCL ................................. 13
4.9 Pseudo-ops -- ORG .................................. 13
4.10 Pseudo-ops -- PAGE ................................. 13
4.11 Pseudo-ops -- REG .................................. 14
4.12 Pseudo-ops -- SET .................................. 14
4.13 Pseudo-ops -- TITL ................................. 14
5.0 Assembly Errors ......................................... 14
5.1 Error * -- Missing Statement ....................... 15
5.2 Error ( -- Parenthesis Imbalance ................... 15
5.3 Error " -- Missing Quotation Mark .................. 15
5.4 Error B -- Branch Target Out of Bounds ............. 15
5.5 Error D -- Illegal Digit ........................... 15
5.6 Error E -- Illegal Expression ...................... 16
5.7 Error I -- IF-ENDIF Imbalance ...................... 16
5.8 Error L -- Illegal Label ........................... 16
5.9 Error M -- Multiply Defined Label .................. 16
5.10 Error O -- Illegal Opcode .......................... 16
5.11 Error P -- Phasing Error ........................... 17
5.12 Error S -- Illegal Syntax .......................... 17
5.13 Error T -- Too Many Arguments ...................... 17
5.14 Error U -- Undefined Label ......................... 17
5.15 Error V -- Illegal Value ........................... 17
6.0 Warning Messages ........................................ 17
6.1 Warning -- Illegal Option Ignored .................. 18
6.2 Warning -- -l Option Ignored -- No File Name ....... 18
6.3 Warning -- -o Option Ignored -- No File Name ....... 18
6.4 Warning -- Extra Source File Ignored ............... 18
6.5 Warning -- Extra Listing File Ignored .............. 18
1
6.6 Warning -- Extra Object File Ignored ............... 18
7.0 Fatal Error Messages .................................... 18
7.1 Fatal Error -- No Source File Specified ............ 18
7.2 Fatal Error -- Source File Did Not Open ............ 18
7.3 Fatal Error -- Listing File Did Not Open ........... 19
7.4 Fatal Error -- Object File Did Not Open ............ 19
7.5 Fatal Error -- Error Reading Source File ........... 19
7.6 Fatal Error -- Disk or Directory Full .............. 19
7.7 Fatal Error -- File Stack Overflow ................. 19
7.8 Fatal Error -- If Stack Overflow ................... 19
7.9 Fatal Error -- Too Many Symbols .................... 19
2
1.0 How to Use the Cross-Assembler Package
First, the question, "What does a cross-assembler do?" needs
to be addressed as there is considerable confusion on this point.
A cross-assembler is just like any other assembler except that it
runs on some CPU other than the one for which it assembles code.
For example, this package assembles 8051 source code into 8051
object code, but it runs on an 8080, a Z-80, an 8088, or whatever
other CPU you happen to have a C compiler for. The reason that
cross-assemblers are useful is that you probably already have a
CPU with memory, disk drives, a text editor, an operating system,
and all sorts of hard-to-build or expensive facilities on hand.
A cross-assembler allows you to use these facilites to develop
code for an 8051.
This program requires one input file (your 8051 source code) and
zero to two output files (the listing and the object). The input
file MUST be specified, or the assembler will bomb on a fatal
error. The listing and object files are optional. If no listing
file is specified, no listing is generated, and if no object file
is specified, no object is generated. If the object file is
specified, the object is written to this file in "Intel
hexadecimal" format.
The command line for the cross-assembler looks like this:
A51 source_file { >list_file } { -o object_file }
where the { } indicates that the specified item is optional.
Some examples are in order:
a51 test51.asm source: test51.asm