home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
C/C++ Interactive Guide
/
c-cplusplus-interactive-guide.iso
/
c_ref
/
csource4
/
267_01
/
a85.doc
< prev
next >
Wrap
Text File
|
1989-01-13
|
41KB
|
1,108 lines
/*
HEADER: CUG267;
TITLE: 8085 Cross-Assembler (Portable);
FILENAME: A85.DOC;
VERSION: 0.1;
DATE: 08/27/1988;
SEE-ALSO: A85.H;
AUTHORS: William C. Colley, III;
*/
8085 Cross-Assembler (Portable)
Version 0.1
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 .................................. 5
2.3 String Constants ................................... 6
2.4 Expressions ........................................ 6
3.0 Machine Opcodes ......................................... 7
3.1 Opcodes -- No Arguments ............................ 7
3.2 Opcodes -- One Register Argument ................... 7
3.3 Opcodes -- One RST Vector Argument ................. 8
3.4 Opcodes -- One I/O Port Argument ................... 8
3.5 Opcodes -- One Immediate Argument .................. 8
3.6 Opcodes -- One Address Argument .................... 8
3.7 Opcodes -- Two Register Arguments................... 8
3.8 Opcodes -- One Register and One Immediate Argument . 8
3.9 Opcodes -- One Register and One Address Argument ... 9
4.0 Pseudo Opcodes .......................................... 9
4.1 Pseudo-ops -- DB ................................... 9
4.2 Pseudo-ops -- DS ................................... 9
4.3 Pseudo-ops -- DW ................................... 9
4.4 Pseudo-ops -- END .................................. 10
4.5 Pseudo-ops -- EQU .................................. 10
4.6 Pseudo-ops -- IF, ELSE, ENDIF ...................... 10
4.7 Pseudo-ops -- INCL ................................. 11
4.8 Pseudo-ops -- ORG .................................. 12
4.9 Pseudo-ops -- PAGE ................................. 12
4.10 Pseudo-ops -- SET .................................. 12
4.11 Pseudo-ops -- TITLE ................................ 12
5.0 Assembly Errors ......................................... 13
5.1 Error * -- Missing Statement ....................... 13
5.2 Error ( -- Parenthesis Imbalance ................... 13
5.3 Error " -- Missing Quotation Mark .................. 13
5.4 Error D -- Illegal Digit ........................... 13
5.5 Error E -- Illegal Expression ...................... 13
5.6 Error I -- IF-ENDIF Imbalance ...................... 14
5.7 Error L -- Illegal Label ........................... 14
5.8 Error M -- Multiply Defined Label .................. 14
5.9 Error O -- Illegal Opcode .......................... 14
5.10 Error P -- Phasing Error ........................... 15
5.11 Error R -- Illegal Register ........................ 15
5.12 Error S -- Illegal Syntax .......................... 15
5.13 Error T -- Too Many Arguments ...................... 15
5.14 Error U -- Undefined Label ......................... 15
5.15 Error V -- Illegal Value ........................... 15
6.0 Warning Messages ........................................ 16
6.1 Warning -- Illegal Option Ignored .................. 16
6.2 Warning -- -l Option Ignored -- No File Name ....... 16
6.3 Warning -- -o Option Ignored -- No File Name ....... 16
6.4 Warning -- Extra Source File Ignored ............... 16
6.5 Warning -- Extra Listing File Ignored .............. 16
6.6 Warning -- Extra Object File Ignored ............... 16
1
7.0 Fatal Error Messages .................................... 16
7.1 Fatal Error -- No Source File Specified ............ 16
7.2 Fatal Error -- Source File Did Not Open ............ 17
7.3 Fatal Error -- Listing File Did Not Open ........... 17
7.4 Fatal Error -- Object File Did Not Open ............ 17
7.5 Fatal Error -- Error Reading Source File ........... 17
7.6 Fatal Error -- Disk or Directory Full .............. 17
7.7 Fatal Error -- File Stack Overflow ................. 17
7.8 Fatal Error -- If Stack Overflow ................... 17
7.9 Fatal Error -- Too Many Symbols .................... 17
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 8085 source code into 8085
object code, but it runs on an 8088, a 68000, 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 8085.
Because this cross-assembler assembles 8085 code, it is, in
fact, possible to use it as a regular assembler by compiling it
under either Aztec C II or Eco-C and running it on an 8085 under
CP/M.
This program requires one input file (your 8085 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:
A85 source_file { >list_file } { -o object_file }
where the { } indicates that the specified item is optional.
Some examples are in order:
a85 test85.asm source: test85.asm