

The 68XX Specialists for Application and System Software

SSB 6809 ASSEMBLER

We Sell Capabilities...

#### COPYRIGHT NOTICE

This entire manual and accompanying software have been copyrighted by Smoke Signal Broadcasting. The reproduction of this document or accompanying software for any reason other than archival or backup purposes for or on the computer for which the original copy was aquired is strictly prohibited.

#### WARRANTEE INFORMATION

The SSB ASSEMBLER is provided AS IS without warrantee. Reasonable care has been taken to insure that the software operates as described in this manual. If you find a situation in which the assembler does not operate as described, please contact Smoke Signal Broadcasting. We will attempt to correct any errors brought to our attention, but we make no gaurantee to do so.

### TABLE OF CONTENTS

| INTRODUCTION            | 2      |
|-------------------------|--------|
| INVOKING THE ASSEMBLER  | 2      |
| COMMAND OPTION SWITCHES | 2      |
| OPTIONS SUMMARY         | )<br>/ |
| COMMAND LINE EXAMPLES   | ፯<br>5 |
| ASSEMBLER DESCRIPTION   | 6      |
|                         |        |
| SOURCE STATEMENT FORMAT | 6      |
| LABEL FIELD             | 7      |
| OPERATION FIELD         | Š      |
| OPERAND FIELD           | 9      |
| ADDRESSING MODES1       | Õ      |
| EXPRESSIONS1            | þ      |
| SYMBOLS1                | 8      |
| CONSTANTS1              | 9      |
| COMMENT FIELD2          | Ø      |
| AUTO FIELDING           | Ø      |
| ASSEMBLER DIRECTIVES2   | 1      |
| ASSEMBLER OPERATION2    | 7      |
| APPENDICES2             | . 8    |
| CHARACTER SET           | A      |
| 6809 INSTRUCTION SET    | E      |
| ERROR MESSAGES          | C      |
| LISTING DESCRIPTION     | , C    |
| USEFUL INFORMATION      | E      |
|                         |        |

#### INTRODUCTION

The SSE 6809 Assembler for DOS69 is a versatile and powerful assembler for the 6809 computer system. The assembler will permit very large source files (including multiple files) to be assembled, producing a binary file on disk. A number of assembly-time options are provided. The name of the source file(s) to be assembled, unless otherwise specified, default(s) to a filename bearing a type 1 extension. Likewise, binary output filenames will default to type 0 extensions. Since DOS69 initially defines a type 0 extension as .BIN and a type 1 extension as .TXT, extension types and their literal equivalents will be used interchangeably throughout the remainder of this manual.

In addition to all the standard 6809 mnemonics, the assembler will accept and translate all 6800 mnemonics to 6809 object code. This allows programs written for the 6800 to be moved to the 6809 with minimum of difficulty.

#### INVOKING THE ASSEMBLER

The assembler is invoked using the ASM09 command, which uses the general syntax of:

ASMO9 <FILENAME> [ , <FILENAME>...] [ / <OPTION> [ [,] <OPTION>...] ]

The name of the file(s) to be assembled default(s) to the base name bearing a type I extension and the drive currently assigned as the work drive. If the "O=XXX" option (specifies object file tilename) is not included in the command line, the binary file will be assigned the same 'name' as the first source file which is being assembled, but will be assigned a type Ø extension. ADMD9 will allow up to 20 source files to be assembled at one time. The default filename extensions can be overiden by simply defining the extension explicitly. That is, if FILE.A is specified, then the file FILE.A will be operated upon rather than FILE.TXT or FILE.BIN. Refer to the DOS69 documentation for information regarding extension type definitions, work drive assignments, and the use of the SET command for defining such parameters.

#### COMMAND OPTION SWITCHES

There are many option switches which can be included in the option list. The option list is separated from the file specs by a '/'. Each option code is represented by a single letter, with multiple options specified as a list of unseparated option switches. Options of the form "i=xxx", if not the last option on the command line, must be separated by a ",". This is to delimit the end of the string. Below is a list of the available options and their meanings. a "-" preceeding an option switch will result in that switch being turned off. (note that some switches detault to "ON"...).

# SSB 6809 ASSEMBLER USER MANUAL

## ASM COMMAND LINE OPTION SWITCHES

| OPTION | DEFAULT    | FUNCTION                                                                                                                                     |
|--------|------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| A      | <b>-</b> A | assemble into memory note: the assembler will not overlay itself                                                                             |
| G      | <b>-</b> G | print code generated by FCB, FDB, & FCC directives                                                                                           |
| н      | <b>-</b> H | get initial heading from console                                                                                                             |
| K      | <b>-</b> K | use formfeeds (instead of linefeeds) to get to the top of the next page                                                                      |
| L      | -L         | generate listing (may use L=XXX form) listing file defaults to XXX.LST where XXX is filename of lst file in command line                     |
| M      | -M         | list error messages                                                                                                                          |
| N=đđđ  | N=78       | set printer line length to ddd(dec.). 49 < ddd < 121                                                                                         |
| O      | O          | <pre>create object file. (may use O=XXX form )   object file defaults to XXX.BIN where XXX is file   name of lst file in command line.</pre> |
| P=ddd  | P=66       | set number of lines per printed page & enable paging                                                                                         |
| S      | <b>-</b> s | print symbol table                                                                                                                           |
| T      | <b>-T</b>  | <pre>put system's time / date into page headings     requires moniter to have a time / date routine.     (see appendix E)</pre>              |
| x      | -x         | print cross reference concordance                                                                                                            |

#### **EXAMPLES**

- ASM09 TEST ASM09 TEST/LS 2.
- ASM09 0:TEST/O=1:TEST.\$,SL 3.
- ASM09 TEST/L-O
- ASM09 PROG0.TXT, PROG1.TXT, PROG2.TXT
- ASM09 1:EQU.SYS, PROG3.TXT, 2:PROG4.TXT/0=PROG.\$

The first example would assemble the source file TEST.TXT from the working drive and would check to see if TEST.BIN exists on the the same drive. If TEST.BIN was not found, then the assembler will create TEST.BIN. However, if TEST.BIN existed, the assembler would overwrite TEST.BIN with new object code. The second example would do the same thing as the first, except that listing would be enabled & the symbol table would be printed.

Example 3 would cause assembly of TEST.TXT (found on drive 0) and would create a "transient command" file TEST.\$ (on drive 1).

The 4th example would cause file TEST.TXT (on the current working drive) to be assembled for a listing only.

Example 5 shows how to assemble several files together to form a single object file. Successful multiple assembly requires only the last input file to contain an 'END' directive. Note also that the same rules for multiple and undefined symbol detection apply between files as well as within files. In addition, if the name of the binary file is not specified, the binary file will take on the name of the first file given in the file specs. This example would place the binary output in a file named 'PROGØ.BIN' on the working drive.

The command line of example 6 shows again how multiple files can be assembled, with input files being read from different drives, and a transient command file PROG.\$ being the binary output file located on the working drive. Note here how an equate file, for example, can be included in the assembly process.

#### LISTINGS

To have the listing printed on a printer rather than appearing on the system terminal, simply precede the the ASM09 command with the "P," prefix (see 'P' command in the DOS69 description). This is assuming that the appropriate PRINT.SYS file exists in the operating system, and has been run prior to an attempt to use the printer. For example:

DOS: P ASM09 TEST/L

This would cause the assembly listing of the source file TEST.TXT to be printed on the system printer. Note that an option switch of "/L=," would route the listing to a disk file (due to the "="), and that this file would have the same filename as the first source file in the command (but with an extension of ".LST" (due to the "," in "/L=,")).

#### NOTE:

Listing output (whether to a file, the console, or to the printer) can be stopped, restarted or aborted by the standard control characters (see appendix E).

For a complete description of the format of the listing which will be produced by ASM09, please refer to appendix D.

#### ASSEMBLER DESCRIPTION

The SSB 6809 Assembler was written for maximum flexibility for DOS69 disk system users. As always, flexibility adds complexity and therefore the user is advised to read the following application notes before attempting to use the assembler.

It is assummed that the user is familiar with assembly language and, in particular, the mnemonics of the 6809 assembly language. Those who are not should refer to the "M6809 Microprocessor Programming Manual" or the "M6809 Programming Reference Manual", both available from your Motorola distributor.

The source language (input) for the SSB 6809 Assembler consists of a subset of the 7-bit ASCII (American Standard Code for Information Interchange, 1968) character set. In all cases the parity bit (most significant bit) of each character must be 0.

#### SOURCE STATEMENT FORMAT

Each source statement may include up to 5 fields: a sequence number, a label (or "\*" for a comment line), an operation, an operand, and (optionally) a comment.

#### SEQUENCE NUMBERS

The sequence number field is an optional field provided as a programming convenience. The sequence number field starts at the beginning of the source line, and consists of up to five decimal digits. The value of the number must be less than 65536. Sequence numbers (if supplied) must be followed by a space. ASM09 will automatically supply sequence numbers if the first character of the first source line of the first file is not an ASCII numeric digit ("0": "9").

Although sequence numbers are optional, they must be consistently used or not used for the entire assembly. If the first source statement has a sequence number, then every succeeding source statement must also have a sequence number. If the first source statement does not have a sequence number, then no other source statement may be numbered.

#### SOURCE STATEMENT FORMAT

( continued )

#### LABEL FIELD

ł

The label field occurs as the first field of a source statement. The label field can take one of the following forms:

- 1. An asterisk (\*) as the first character in the label field indicates that the rest of the source statement is comment. Comments are ignored by the Assembler, and are printed on the source listing only for the programmer's information.
- 2. A space as the first character indicates that the label field is empty. The line has no label and is not a comment.
- 3. A symbol chaacter as the first character indicates that the line has a label. Symbol characters are the upper case letters A-Z, digits 0-9, and the special characters, period (.), dollar sign (\$), and underscore (\_). Symbols consist of one to six characters, the first of which must be alphabetic or the special character, period (.). Certain special symbols are reserved by the Assembler, and will cause an error to be generated if they appear in a label field. These reserved symbols are: A, B, and X, CC, D, DP, PC, PCR, S, U, and Y.

A symbol may occur only once in the label field unless it is used with the SET directive. If a symbol does occur more than once in a label field, then each reference to that symbol will be flagged with an error.

With the exception of some directives, a label is assigned the value of the program counter of the first byte of the instruction or data being assembled.

Each unique label, undefined symbol, and external reference symbol in a program is allocated a ten-byte block in the symbol table. In addition, a ten-byte block is allocated for every four references to a symbol, if the cross reference option is in effect.

#### SOURCE STATEMENT FORMAT

( continued:)

#### OPERATION FIELD

------

The operation field occurs after the label field, and must be preceded by at least one space. The operation field must contain a symbol. Thus, the rules governing labels apply to the operation field as well. Entries in the operation field may be one of two types:

#### Opcode

These correspond directly to the machine instructions. The operation code includes the "A" or "B" character for the accumulator specification. For compatibility with other 6800 / 6809 assemblers, a single space may separate the operation code from the accumulator designator. For example, "LDA A" is the same as "LDA A" is the same as "LDAA". Although ASM09 recognizes the above instruction forms, the propr form for the 6809 instruction "load accumulator A" is "LDA".

#### Directive

These are special operation codes known to ASM09 which control the assembly process rather than being translated into machine instructions. (see section entitled "ASSEMBLER DIRECTIVES")

#### SOURCE STATEMENT FORMAT

( continued )

#### OPERAND FIELD

The operand field's interpretation is dependant on the contents of the operation field. The operand field, if required, must follow the operation field, and must be preceded by at least one space. The operand field may contain a symbol, expression, or a combination of symbols and expressions separated by commas. The operand field of machine instructions is used to specify the addressing mode of the instruction, as well as the operand of the instruction.

The following operand formats exist:

| Operand Format                       | 6809 Addressing Mode             |
|--------------------------------------|----------------------------------|
| no operand                           | accumulator and inherent         |
| <pre><expression></expression></pre> | direct, extended, or relative    |
| # <expression></expression>          | immediate                        |
| <expression>,X</expression>          | indexed                          |
| < <expression></expression>          | direct                           |
| > <expression></expression>          | extended                         |
| [ <expression>]</expression>         | extended indirect                |
| <expression>,R</expression>          | indexed                          |
|                                      | 8 bit offset indexed             |
| > <expression>,R</expression>        |                                  |
| [ <expression>,R]</expression>       |                                  |
|                                      | 8 bit offset indirect            |
| >[ <expression>,R]</expression>      | 16 bit offset indirect           |
| Q+                                   | auto increment by 1              |
| Q++                                  | auto incremet by 2               |
| [O++]                                | auto increment indirect ( by 2 ) |
| -Q                                   | auto decrement by 1              |
| c                                    | auto decrement by 2              |
| [Q]                                  | auto decrement indirect (by 2)   |
| W1[,W2,Wn]                           | immediate                        |
| 11 T [ ] 11 C ] + + + 11 L L L       | THINGALACE                       |

where R is one o the registers PCR, S, U, X, or Y, and Q is one of the registers S, U, X, or Y. Wi (i=1 to n) is one of the symbols A, B, CC, D, DP, PC, S, U, X, or Y.

#### 6809 ADDRESSING MODES

-----

The 6809 includes some instructions which require no operands. These instructions are self-contained, and employ the inherent addressing or the accumulator addressing mode. For more information, refer to appendix B.

#### IMMEDIATE ADDRESSING

Immediate addressing refers to the use of one or two bytes of information that immediately follow the operation code in memory. Immediate addressing is indicated by preceding the operand field with the pound sign or number sign (\*) e.g., \*<expression>. The expression following the "\*" will be assigned one or two bytes of storage, depending on the instruction. All instructions referencing the accumulator "A" or "B", or the condition code register "CC", will generate a one-byte immediate value. Also, immediate addressing used with the PSHS, PULS, PSHU, and PULU instructions generates a one-byte immediate value. Immediate operands used in all other instructions generate a two-byte value.

The register list operand does not take the form #<expression> but still generates one byte of immediate data. The form of the operand is:

where Ri (i-l to n) is one of the symbols A, B, CC, D, DP, PC, S, U, X or Y. The number and type of symbols vary, depending on the specific instruction.

For the instructions PSHS, PULS, PSHU, and PULU, any of the above register names may be included in the register list. The only restriction is that "U" cannot be specified with PSHU or PULU, and "S" cannot be specified with PSHS or PULS. The one-byte immediate value assigned to the operand is determine by the registers specified. Each register name sets a bit in the immediate byte as follows:

For the instructions EXG and TFR, exactly two of the above register names must be included in the register list. The other restriction is the size of the registers specified. For the EXG instruction, the two registers must be the same size. For the TFR instruction, the two registers must be the same size, or the first can be a 16-bit register and the second an 8-bit register. In the case where the transfer is from a 16-bit register to an 8-bit register, the least significant 8 bits are transferred. The 8-bit registers are A, B, CC, and DP. The 16-bit

Ì.

registers are D, PC, S, U, X, and Y. The one-byte immediate value assigned to the operand is determined by the register names. The most significant four bits of the immediate byte contain the value of the first register name; the least significant four bits contain the value of the second register as shown by the following table:

| Register  | valu <b>e</b> |          | si | ze  |
|-----------|---------------|----------|----|-----|
| specified | (hex)         | (binary) | 8b | 16b |
| "D"       | Ø             | 0000     |    | *   |
| "X"       | 1             | 0001     |    | *   |
| "Y"       | 2             | 0010     |    | *   |
| 4 U 44    | 3             | 0011     |    | *   |
| "S"       | 4             | 0100     |    | *   |
| "PC"      | 5             | 0101     |    | *   |
| "A"       | 8             | 1000     | *  |     |
| "B"       | 9             | 1001     | *  |     |
| "CC"      | Ā             | 1010     | *  |     |
| "DP"      | В             | 1011     | *  |     |

#### RELATIVE ADDRESSING

Relative addressing is used by branch instructions. There are two forms of the branch instruction. The short branch can only be executed within the range -126 to +129 bytes relative; to the first byte of the branch instruction. The actual branch offset is put into the second byte of the branch instruction. The long branch can execute in the full range of addressing from 0000-FFFF (hexadecimal) because a two-byte offset is calculated and put into the operand field of the branch instruction. The offset is the two's complement of the difference between the location of the byte immediately following the branch instruction and the location of the destination of the branch.

#### DIRECT AND EXTENDED ADDRESSSING

Direct and extended addresssing utilize one (direct) or two (extended) bytes to contain the address of the Direct and extended addressing are indicated by operand. having only an expression in the operand field (i.e., <expression>). Direct addressing will be used by ASM09 whenever possible. Regardless of the criteria described above, it is possible to force the Assembler to use the direct addressing mode by preceding the operand with the "<" character. Similarly extended addressing can be forced by preceding the operand with the ">" character. These two operand forms are: <<expression> ><expression>. There is no restriction on the latter form. It will always generate extended addressing. If direct addressing is forced, the most significant byte of the expression is compared with the direct page pseudo register. If they are not the same, a warning message is generated. The user must ensure that the direct page register is set up at execution time.

#### INDEXED ADDRESSING

Indexed addressing is relative to one of the index registers. The general form is <expression>,R. The address is calculated at the time of instruction execution by adding the value of <expression> to the current contents of the index register. The other general form is [<expression>,R]. In this indirect form, the address is calculated at the time of instruction execution by first adding the value of <expression> to the current contents of the index register, and then retrieving the two bytes from the calculated address and address+1. This two-byte value is used as the effective address of the operand. The allowable forms of indexed addressing are described below. Appendix B describes the format of the post-byte (i.e., the byte immediately following the opcode) for each of the indexed addressing modes.

In the description below, R refers to one of the index registers S, U, X, or Y.

The accumulator offset mode allows one of the accumulators to be specified instead of an <expression>. Valid forms are:

where <acc> is one of the accumulators A, B, or D. This form generates a one-byte operand (post-byte only). When accumulator A or B is specified, sign extension occurs prior to adding the value in the accumulator to the index register. The valid forms for the automatic increment/decrement mode are shown below. For each row, the three entries shown are equivalent.

In this form, the only valid expression is 0. Like the accumulator offset mode, this form generates a one-byte operand (post-byte only). The valid forms for the expression offset mode are:

| R                                                                      | , R   | <expression>,R</expression>                 |
|------------------------------------------------------------------------|-------|---------------------------------------------|
| [R]                                                                    | [,R]  | [ <expression>,R]</expression>              |
| <r< td=""><td>&lt;,R</td><td>&lt;<expression>,R</expression></td></r<> | <,R   | < <expression>,R</expression>               |
| <[R]                                                                   | <[,R] | <[ <expression>,R]</expression>             |
| <r< td=""><td>&gt;,R</td><td>&gt;<expression>,R</expression></td></r<> | >,R   | > <expression>,R</expression>               |
| >[R] <                                                                 | >1.Rl | > ( <expression).r< td=""></expression).r<> |

The "<" and ">" characters force an 8-bit or 16-bit offset, respectively, and are described below. If no expression is specified, only the post byte of the operand is generated. If an expression with a value in the range -16 to +15 is specified without indirection, a one-byte

operand is generated which contains the expression's value as well as the index register indicator. At execution time, the expression's value is expanded to 16 bits with sign extension before being added to the index register. All other forms will generate a post-byte, as well as either a one-byte or two-byte offset which contains the value of the expression. The size of the offset is determined by the type and size of the expression. Expressions with values in the range -128 to +127 generate an 8-bit offset. If an expression that follows the above rules contains a symbol that is referenced before it has been defined, the instruction will be assembled using a 16-bit offset in order to avoid phasing errors. All other cases will result in a 16-bit offset being generated. the case where an 8-bit offset is generated, the value is expanded to 16 bits with sign extension at execution time. Regardless of the criteria described above, it is possible to force the Assembler to generate an 8-bit offset by preceding the operand with the "<" character. Similarly, a 16-bit offset can be forced by preceding the operand with the ">" character. There is no restriction on the ">"form. It always generates a post-byte followed by a 16-bit offset. If an 8-bit offset is forced and the expression has a value outside of the range -128 to +127, a byte overflow error is generated.

The valid forms for the program counter relative mode are exactly the same as the expression offset mode, with the exception that the index register specification must be "PCR". However, the manner in which the offset is generated by ASMØ9 differs. The assembler generates a relative address which is then used as the 8-bit or 16-bit offset following the post-byte. The relative address is the two's complement of the difference between the location of the byte immediately following the indexed instruction and the value of the expression. If the relative address calculated is not in the range -128 to +127, or if the expression references a symbol that has not yet been defined, a two-byte offset is generated after the post-byte. A one byte offset is generated if the relative address is in the range -128 to +127. Like the expression offset mode, a one-byte offset can be forced by preceding the operand with a "<". A ">" forces a two-byte offset. A byte overflow error is generated if a one-byte offset is forced when the relative address is not in the range -128 to +127.

#### EXTENDED INDIRECT ADDRESSING

The extended indirect mode has the form:

[<expression>]

Although extended indirect is a logical extension of the extended addressing mode, this mode is implemented using an encoding of the post-byte under the indexed addressing mode. A post-byte is generated, as well as a two-byte offset which contains the value of the expression.

#### **EXPRESSIONS**

An expression is a combination of symbols, constants, algebraic operators, and parentheses. The expression is used to specify a value which is to be used as an operand. Expressions follow the conventional rules of algebra.

#### **OPERATORS**

The precedence of the various operators is as follows. Paranthetical expressions are evaluated first, with the innermost parentheses being processed before the outer ones. Next, the multiplication (\*), division (/), and all two-character operators have precedence. Of lowest precedence are the addition (+) and subtraction (-) operators. Unary minus can only occur at the beginning of an expression or immediately before a left parenthesis. Unary minus is equivalent in evaluation to putting a zero directly before the minus sign. For example the following expressions are all equivalent:

-TAG\*INDEX+3 Ø-TAG1\*INDEX+3 -(TAG1\*INDEX)+3

Operators of the same precedence are evaluated from left to right. All intermediate results in the computation of an expression are truncated to a 16-bit integer value. The result of an expression is also a 16-bit integer. Operators can operate on numeric constants, single character ASCII literals, and symbols. In addition to the normal operators for multiplication, division, addition, and subtraction, ASM09 recognizes certain two character operators. The operators are infix operators and have the same precedence as multiplication or division. Each two-character operator begins with an exclamation point (!) and takes two operands. The following two-character operators are defined:

!^ - exponentiation

The left operand is raised to the power specified by the right operand. If the right operand is zero, the resulting value will be "l", regardless of the value of the left operand.

!. - logical AND

Each bit in the left operand is logically "ANDed" with the corresponding bit in the right operand.

!+ - inclusive OR

Each bit in the left operand is inclusively "ORed" with the corresponding bit in the right operand.

!X - exclusive OR

Each bit in the left operand is exclusively "ORed" with the corresponding bit in the right operand.

!< - shift left

The left operand is shifted to the left by the number of bits specified by the right operand. The left operand is zero-filled from the right.

!> - shift right

The left operand is shifted to the right by the numer of bits specified by the right operand. The left operand is zero-filled from the left.

!L - rotate left

The left operand is rotated left by the number of bits specified by the right operand. The most significant bit is rotated into the least significant bit position of the left operand.

IR - rotate right

The left operand is rotated right by the number of bits specified by the right operand. The least significant bit is rotated into the most significant bit position of the left operand.

#### SSB 6809 ASSEMBLER USER MANUAL

#### SYMBOLS

Each symbol is associated with a 16 bit integer value which is used in place of the symbol during the expression evaluation. The asterisk (\*) used in an expression as a symbol represents the current value of the location counter (the first byte of a multi-byte instruction).

#### CONSTANTS

Constants represent quantities of data that do not vary in value during the execution of a program. The numeric constants can be in one of four bases: decimal, hexadecimal, binary, or octal.

A decimal constant consists of a string of numeric digits. The value of a decimal constant must fall in the range 0-65535, inclusive. Optionally, decimal constants may be preceded by the ampersand character (&). The following example shows both valid and invalid decimal constants:

| VALID | INVALID | REASON INVALID         |
|-------|---------|------------------------|
| 12    | 123456  | more than 5 digits     |
| 12345 | 12.3    | invalid character      |
| 65201 | 67800   | out of range (> 65535) |

A hexadecimal constant consists of a maximum of four characters from the set of digits (0-9) and the upper case alphabetic letters (A-F), and is preceded by a dollar sign (\$). Hexadecimal constants can also be designated by being succeded by the letter "H". In this case, the first digit of the hexadecimal constant must be a numeric so that the constant can be distinguished from a symbol name. Hexadecimal constants must be in the range \$0000 to \$FFFF. The following example shows both valid and invalid hexadecimal constants:

| VALID  | INVALID | REASON INVALID    |
|--------|---------|-------------------|
| \$12   | ABCD    | no preceding "\$" |
| 0ABCDH | \$G2A   | invalid character |
| \$001F | \$2F018 | too many digits   |

A binary constant consists of a maximum of 16 ones or zeros preceded by a percent sign (%). Binary constants can also be represented by a series of ones and zeros succeeded by the letter "B". The following examle shows both valid and invalid binary constants:

| VALID        | INVALID                  | REASON INVALID                           |
|--------------|--------------------------|------------------------------------------|
| %00101<br>%1 | 1010101<br>%100110001010 | missing percent<br>10111 too many digits |
| 10100B       | %210101                  | invalid digit                            |

An octal constant consists of a maximum of six numeric digits, excluding the digits 8 and 9, preceded by a commercial at-sign (0). Octal constants can also be designated by ending in the letter "O" or "Q". Octal constants must be in the the ranges 00 to 0177777. The following example shows both valid and invalid octal constants:

### SSB 6809 ASSEMBLER USER MANUAL

| VALID          | INVALID                     | REASON INVAID                   |  |  |
|----------------|-----------------------------|---------------------------------|--|--|
| @17634<br>377Q | @231723 <b>4</b><br>@277272 | too many digits<br>out of range |  |  |
| 1776000        | 239140                      | invalid character               |  |  |

Character constants can be used in expressions if they are single characters. Character constants are preceded by a single quote. Any character, including the single quote, can be used as a character constant. The following example shows both valid and invalid character constants:

| VALID | INVALID | REASON INVALID |
|-------|---------|----------------|
| **    | 'VALID  | too long       |

#### COMMENT FIELD

The last field of an ASM09 source statement is the comment field. This field is optional and is only printed on the source listing for documentation purposes. The comment field is separated from the operand field (or from the operation field if no operand is required)

#### AUTO FIELDING

ASM09 performs automatic output fielding. No matter what the source file looks like in terms of field spacing, the output will automatically tab each field into a columnar form.

#### ASSEMBLER DIRECTIVES

In addition to the 6809 mnemonics, this assembler supports 16 assembler directives or pseudo-ops. These pseudo-ops are listed below along with a brief description. More detailed descriptions follow:

| FCC   | form constant character                     |
|-------|---------------------------------------------|
| FCB   | form constant byte                          |
| FDB   | form double byte                            |
| SPC   | insert spaces in output listing             |
| OPT   | activates or deactivates assembler options  |
| PAGE  | skip to next page of output                 |
| ORG   | define new origin (PC)                      |
| EQU   | assign value to symbol                      |
| END   | signal end of source program                |
| NAM   | specify name                                |
| TTL   | specify title                               |
| RMB   | reserve memory bytes                        |
| BSZ   | reserve block of storage (fill with \$00's) |
| SETDP | set direct-page pseudo register             |
| REG   | define register list                        |
| SET   | assign temporary value to a symbol          |

#### FCC

or

The function of FCC is to create character strings for messages or tables. The character string 'text' is broken down to ASCII, one character per byte. The two allowable formats are shown below.

label FCC count, text

label FCC delimiter text same delimiter

where count is any decimal number. In the case where a number is used as a delimiter, the first character of text must not be a comma. The character limit of any FCC statement is 255. The use of label is optional.

#### FCB

The FCB pseudo-op caused an axpression to be evaluated and the resultant 8 bits placed in memory. Usage is shown below:

label FCB expression 1, expression 2, ... expression N

Each expression is separated by a comma with a maximum of 255 expressions per FCB statement. The label is optional.

**FDB** 

The function of the FDB directive is identical to the FCB except 16 bit quantities are assembled, i.e., two bytes generated for each expression. The required format is shown below:

label FDB expression 1, expression 2,  $\dots$  expression N where the label is optional.

SPC

The SPC operator causes the specified number of spaces to be inserted in the output listing. The format is shown below:

SPC expression

Notice that no label is allowed. If 'expression' evaluates to zero, one space is inserted. The operator SPC itself does not appear in the output listing. If PAGE mode is selected, SPC will not cause spacing past the top of the next page.

OPT

The directive OPT is used to activate or deactivate the assembler options from within the source program. The format is shown below. Note that no label is allowed, and no code is generated.

OPT option1,option2,...optionN

The allowable options are:

SYM print sorted symbol table after listing. NOS do not print the symbol table (default).

GEN print code generated by FCB, FDB, and FCC.

NOG print only one line for each FCB, FDB, or FCC (default).

LIS print the assembled source listing. (if "/L" in command)

NOL supress the printing of the assembly listing (default).

PAG enable page formatting and numbering (default).

NOP disable page mode.

CRE enable printing of cross-reference concordance at end of listing. This option must be specified before the first symbol is encountered in the source program.

LLE=ddd set printer line length (defaults to 78, max is 120).

P=ddd set printer page length (defaults to 66, max is 128).

WAR enable printing of warning messages (default).
NOW suppress warnings

OBJ enable writing of object module (default) NOO disable writing of object module

If contradicting options appear, the last one appearing takes precedence. All options take effect simultaneously at the beginning of pass 2. The default options specified take effect unless the user specifies a particular option. Only the first 3 characters of an option name are significant and multiple options are separated by a comma.

SSB 6809 ASSEMBLER USER MANUAL

PAGE

The PAGE operator, if the PAGE option is on, causes a page eject and subsequently causes the title (if any) and page number to be printed at the top of the next page. No label is allowed and no code is produced.

ORG

The ORG operator, whose format is shown below, causes a new origin address (PC) for the code following.

ORG expression

No label is allowed and no code is produced. If no ORG appears an origin of 0000 is assumed

EQU

EQU is used to equate a symbol to an expression as shown below. A label is required and no code is generated. Only one level of forward referencing is allowed and the equate must not be recursive.

label EQU expression

No code is produced by EQU.

END

This operator signals the assembler that the end of the source input has occured. No label is allowed and no code is generated.

A second use of the END statement allows for the assignment of a transfer address to the binary file created. This can be accomplished by putting a label or value in the 'operand field' of the END statement. As an example, suppose the program you are assembling is to start executing at location \$100, and in the source file you have the label START on the statement which is OKGed at \$100. The END statement should now include this label in its operand field in order to assign \$100 as the transfer address, as shown on the next page.

ORG \$100 START LDX \$007D

program here

END START

or

END \$0100

NAM

The NAM directive inserts a module name into the heading line. It has no effect on the object code.

TTL

This operator is used to assign a title to be printed at the top of all pages if the PAGE option is on. If the PAGE option is off, this operator has no effect. The format, as shown below allows up to 45 characters in the title. No label is allowed.

TTL text for the title

No code is generated. If more than one NAM or TTL operator appears the last one encountered will be printed on the next page.

RMB

This operator causes the assembler to reserve memory for data storage. No code is generated, therefore the contents of the reserved memory locations are undefined at run time. The label is optional as shown below:

label RMB expression

where 'expression' is a 16 bit quantity.

BSZ

This directive causes ASM09 to reserve a block of memory whose length is given by the operand field. All bytes thus reserved will be set to \$00.

SETDP

This directive causes ASM09 to set an internal psuedo register to the value of the low order 8 bits of the expression in the operand field. If the high order 8 bits are not all zeroes, a byte overflow error will occur. If the high order 8 bits of any memory reference match the contents of this register, then ASM09 will assemble that instruction using the direct addressing mode (unless the ">" is used, in which case the extended addressing mode will be used). If a forward reference is made to a symbol (e.g. RMB's at the end of the program), ASM09 will assemble that instruction using the extended addressing mode (unless the "<" is used, in which case the direct addressing mode will be used).

#### NOTE:

If direct page psudeo register does not agree with the high order byte of the forced direct address, an addressing error will occur.

It is up to the programmer to insure that the DP register is set up appropriatly at execution time to correctly reach the desired memory region.

REG

This directive translates a list of register names into a mask which may be used in the post-byte of certain instructions. The operand field must contain a non-duplicated list of symbols of the set A, B, CC, D, DP, PC, S, U, X, OR Y. An error will occur if both U and S are specified at the same time.

SET

This directive will assign a value to a symbol. Its function is the same as "EQU", however, a symbol may be redefined after being "SET".

#### ASSEMBLER OPERATION

#### Pass 1

The first pass is used to build the symbol table which is used to resolve forward references.

#### rass 2

option is on, the assembled source listing is printed with error messages, if any. If the LIS option is off, only offending source lines and their corresponding error messages are printed. If the SYM option is on, a symbol table will be printed at the end of pass 2. If the CREF option is in effect, this symbol table will contain all of the symbols' definition & reference points. Note that this will eat a lot of paper -- you won't often need a cross reference concordance...

#### APPENDIX A

### ( CHARACTER SET )

The character set recognized by ASM09 is a subset of ASCII. The ASCII code is shown in the following figure. The following characters are recognized by ASM09:

- 1. The upper case letters A thru Z
- 2. The digits Ø thru 9.
- Four arithmetic operators: +, -, \*, & /.
- 4. The special 2-character expression operators: !, !>, !<, !X, !., !+, !R, & !L
- 5. Parentheses in expression: ( & ).
- 6. The special symbol characters: underscore (), period (.), and dollar sign (\$). Only the period may be used as the first character of a symbol.
- 7. The characters used as prefixes for constants and addressing modes:
  - # immediate addressing
  - hexadecimal constant
  - & decimal constant
  - @ octal constant
  - % binary constant
  - character constant
- 8. The characters used as suffixes for constants and addressing modes:
  - ,X indexed addressing
  - H hexadecimal constant
  - O octal constant
  - Q octal constant
  - . decimal constant
  - % binary constant
  - character constant
- 9. Three seperator characters: space, carriage return, & comma.
- 10. The character "\*" to indicate comments. Comments may contain any printable character.
- 11. The special symbols "A" & "B" to denote the accumulators,
   "\*" to indicate the value of the location counter,
   "PCR", "S", "U", "X", & "Y" to indicate indexed addressing
   in the operand field, "D" to specify the 16-bit double
   accumulator, and "CC" & "DP" to specify the control
   registers.
- 12. The special characters "[", & "]" used to indicate indirect addressing, "<" to force direct addressing or to force 8 bit offset mode, ">" to force extended addressing or to force 16 bit offset mode for indexed addresses, and "+" & "-" to indicate auto increment / decrement.

### ASCII CODE

|             | 2  | 3      | 4 | 5 | 6      | 7      |
|-------------|----|--------|---|---|--------|--------|
| Ø           | sp | Ø      | @ | P | •      | p      |
| 1           | 1  | 1      | A | Q | a      | q      |
| 2           |    | 2      | В | R | b      | ř      |
| 2 3         | #  | 3      | C | S | C      | s      |
| 4<br>5<br>6 | \$ | 4      | D | T | đ      | t      |
| 5           | 8  | 5      | E | U | е      | u      |
| 6           | &  | 6      | F | V | e<br>f | V      |
| 7           | 1  | 7      | G | W | g      | W      |
| 8           | (  | 8      | H | X | ĥ      | X      |
| 8<br>9      | )  | 9      | I | Y | h<br>i | У      |
| A           | *  | :      | J | Z | j      |        |
| В           | +  | ;<br>< | K | ] | k      | z<br>[ |
|             | ,  | <      | L | \ | 1      |        |
| D           | _  | =      | M | } | m      |        |
| E           | •  | >      | N | ^ | n      | ~      |
| F           | /  | ?      | 0 |   | 0      | del    |

#### APPENDIX B

#### 6809 INSTRUCTIONS )

The following table lists the special symbols used in the description of the 6809 instruction set:

```
left side of equal sign is replaced by right side
[]
      evaluate contents first; grouping
()
      the contents of
M()
      the contents of the memory location addressed by the
         enclosed expression
+
      arithmetic addition
      arithmetic subtraction -
      arithmetic multiplication
      boolean and
and
effad 6809 effective address
      boolean inclusive or
or
      boolean exclusive or
xor
L>
      logical shift right by number of bits specified
      logical shift left by number of bits specified
L<
A>
      arithmetic shift right by number of bits specified
AΚ
      arithmetic shift left by number of bits specified
R>
      rotate right by number of bits specified
R<
      rotate left by number of bits specified
$nn
      the hexadecimal number nn
      a bit value of n ( 0 or 1 )
n
nn
      an 8 bit value of nn (00: $FF)
nnnn
      a 16 bit value of nnnn ( 0000 : $FFFF )
      8 bit address
aa
aaaa
      16 bit address
      accumulator A
71
      accumulator B
В
C
      carry condition code ( bit 0 of CC )
CC
      condition code register
      16 bit dual acumulator A,B
D
F
      fast interrupt condition code ( bit 6 of CC )
      half carry condition code ( bit 5 of CC ) interrupt condition code ( bit 4 of CC )
H
Ι
      8 bit immediate operand
ìi
iiii
      16 bit immediate operand
N
      sign condition code (bit 3 of CC)
Р
      program counter
      register list
r 1
      8 bit relative branch address
r r
      16 bit relative branch address
rrrr
      stack pointer
      user stack pointer
U
ν
      overflow condition code (bit l of CC)
Х
      index register
XX
      8 bit indexed addressing offset
      opcode depends on index mode
qoxx
Y
      index register
7,
      zero condition code (bit 2 of CC)
```

#### 6809 8 bit arithmetic instructions ) Mne-Oper-Op-Function Status monic and code FHINZVC ABX 3A X = (X) + (B)ADCA ii 89 A=(A)+ii+(C)T - T T T T99 aa A=(A)+m(aa)+(C)XXOP **A9** A=(A)+xxop+(C)aaaa **B9** A=(A)+M(aaaa)+(C)ADCB i i C9 B=(B)+ii+(C)- T - T T T T D9 aa A=(A)+M(aa)E9 qoxx B=(B)+xxopaaaa F9 B=(B)+M(aaaa)+(C)ADDA ii 8B A=(A)+ii- T - T T T 9B aa A = (A) + M(aa)qoxx AB A = (A) + xxopaaaa BB A=(A)+M(aaaa)**ADDB** ii CB B=(B)+ii- T - T T T T aa DB B=(B)+M(aa)B=(B)+xxopqoxx EB FΒ aaaa B=(B)+M(aaaa)ADDD iiii C3 D=(D)+iiii- T T T T D3aa D=(D)+M(aa:aa+1)E3 qoxx D=(D)+xxopaaaa F3 D=(D)+M(aaaa:aaaa+1)**LAA** 19 binary to BCD conv. T: T - T - TMUL 3D D=(A) \* (B)Τ 1 SECA ii 82 A=(A)-ii-(C)TTTT 92 aa A = (A) - M(aa) - (C)х хор **A2** A=(A)-xxop-(C)B<sub>2</sub> aaaa A=(A)-M(aaaa)-(C)SBCB C2 ii B=(B)-ii-(C)TTTT aa D<sub>2</sub> B=(B)-M(aa)-(C)qoxx E2 B=(B)-xxop-(C)F2 aaaa B=(B)-M(aaaa)-(C)SEX 1D Sign extension of B into A - - - T T Ø -SUEA ii 80 A=(A)-ii? - T T T T90 aa A=(A)-M(aa)xxop AØ A=(A)-xxopá a a a BØ A=(A)-M(aaaa)SUBB ii CØ B=(B)-ii- ? - T T T T DØ aa B=(B)-M(aa)qoxx EØ B=(B)-xxopaaaa FØ B=(B)-M(aaaa)SUBD iiii 83 D=(D)-iiiiTTTT 93 D=(D)-M(aa:aa+1)aa xxop **A**3 D=(D)-xxopaaaa **B3** D=(D)-M(aaaa:aaaa+1)NEG 00 aа $M(aa) = \emptyset - M(aa)$ - ? - T T ? T xxop 6Ø xxop=0-xxop 70 aaaa $M(aaaa) = \emptyset - M(aaaa)$ NEGA 40 $A=\emptyset-(A)$ T $\mathbf{T}$ NEGB 50 $B=\emptyset-(B)$ T T ? T

# ( 6809 logical instructions )

| Ane-<br>monic        | Oper-<br>and                   | Op-<br>code                | Function                                                                      | F           |             |              | ue<br>N     |             | V (        |
|----------------------|--------------------------------|----------------------------|-------------------------------------------------------------------------------|-------------|-------------|--------------|-------------|-------------|------------|
| ANDA                 | ii<br>aa<br><b>xxo</b> p       | 84<br>94<br>A4             | A=(A) and ii<br>A=(A) and M(aa)<br>A=(A) and xxop                             | -           | -           | -            | T           | T           | ß          |
| ANDB                 | aaaa<br>ii<br>aa<br>xxop       | B4<br>C4<br>D4<br>E4       | A=(A) and M(aaaa) B=(B) and ii B=(B) and M(aa) B=(B) and xxop                 | -           | -           | <del>-</del> | T           | T           | <b>6</b>   |
| ANDCC                | aaaa<br>ii                     | F4<br>1C                   | B=(B) and M(aaaa)<br>CC=(CC) and ii                                           | ?           | ?           | ?            | ?           | ?           | ?          |
| ASL                  | aa<br>xxop                     | Ø8<br>68                   | M(aa)=M(aa) A< 1 xxop=xxop A< 1                                               | -           | ?           | -            | T           | T           | ?          |
| ASLA<br>ASLB<br>ASR  | aaaa<br><br><br>aa             | 78<br>48<br>58<br>07       | M(aaaa)=M(aaaa) A< 1<br>A=(A) A< 1<br>B=(B) A< 1<br>M(aa)=M(aa) A> 1          | -<br>-      |             |              |             | T           | ?          |
| ASRA<br>ASRE         | xxop<br>aaaa<br>               | 67<br>77<br>47<br>57       | xxop=xxop A> 1<br>M(aaaa)=M(aaaa) a> 1<br>A=(A) A> 1<br>B=(B) A> 1            | <u>-</u>    | 3           |              | T<br>T      | T<br>T      | ?          |
| BITA                 | ii                             | 85                         | (A) and ii                                                                    | -           | -           | _            |             | T           |            |
| ВІТВ                 | aa<br>xxop<br>aaaa<br>ii<br>aa | 95<br>A5<br>B5<br>C5<br>D5 | (A) and M(aa) (A) and xxop (A) and M(aaaa) (B) and ii (B) and M(aa)           | -           | -           | _            | J.          | Т           | Ō          |
| CLR                  | xxop<br>aaaa<br>aa<br>xxop     | E5<br>F5<br>ØF<br>6F       | (B) and xxop<br>(B) and M(aaaa)<br>M(aa)=0<br>xxop=0                          | _           | -           | -            | Ø           | 1           | Ø          |
| CLRA<br>CLRB<br>COM  | aaaa<br><br><br>aa             | 7F<br>4F<br>5F<br>03<br>63 | M(aaaa) = 0<br>A=0<br>B=0<br>M(aa) = M(aa) xor \$FF<br>xxop = xxop xor \$FF   | -<br>-      | -<br>-      | -<br>-<br>-  | Ø<br>Ø<br>T | !<br>1<br>T |            |
| COMA<br>COMB<br>EORA | xxop<br>aaaa<br><br>ii         | 73<br>43<br>53<br>88       | M(aaaa) =M(aaaa) xor \$FF<br>A=(A) xor \$FF<br>B=(B) xor \$FF<br>A=(A) xor ii | -<br>-<br>- | -<br>-<br>- | -            | T<br>T<br>T | T<br>T      | (i)<br>(i) |
| EORB                 | aa<br>xxop<br>aaaa<br>ii       | 98<br>A8<br>B8<br>C8       | A=(A) xor M(aa)<br>A=(A) xor xxop<br>A=(A) xor M(aaaa)<br>B=(B) xor ii        | _           | _           | _            | Ŧ           | J,          | Ø          |
| מאסוני               | aa<br>xxop<br>aaaa             | D8<br>E8<br>F8             | B=(B) xor M(aa)<br>B=(B) xor xxop<br>B=(B) xor M(aaaa)                        |             |             |              |             |             |            |

í

```
6809
                          logical instructions )
                             continued
                                            )
Nne- Oper-
             Op-
                   Function
                                                               Status
monic and
             code
                                                              FHINZVC
ORA
      ii
             8A
                   A=(A) or ii
A=(A) or M(aa)
                                                               - - - T T 0 -
      aa
             9A
                   A=(A) or xxop
      ххор
             AA
      aaaa
             BA
                   A=(A) or M(aaaa)
CRB
      ii
             CA
                   B=(B) or ii
                                                               - - - T T B -
             DA
      aa
                   B=(B) or M(aa)
      qoxx
             ΕA
                   B=(B) or xxop
      aaaa
                   B=(B) or m(aaaa)
             FA
ORCC
                   CC=(CC) or ii
      ii
             1A
                                                              3 3 3 3 3 3 3 3
```

### SSB 6809 ASSEMBLER USER MANUAL

### Function Status Oper-Op-Mne-FHIN2VC monic and code - ? - T T T T CMPA ii 81 (A) - ii91 (A) - M(aa)aa qoxx Al (A) - xxop(A) -M (aāaa) aaaa Вl - ? - T T T T **CMPB** ii C1 (B)-ii(B)-M(aa) Dl aa (B) - xxopqoxx El (B)-M(aaaa)aaaa F1 - - - T T T T iiii 1083 (D)-iiii CMPD 1093 (D) - M(aa:aa+1)aa 10A3 (D)-xxop qoxx 10B3 (D)-M(aaaa:aaaa+1) aaaa 118C (S)-iiii - - T T T T CMPS iiii 119C (S)-M(aa:aa+1) aa 11AC (S)-xxop qoxx llBC (S)-M(aaaa:aaaa+l) aaaa - - - T T Tiiii 1183 (U)-iiii CMPU aa 1193 (U)-M(aa:aa+1)11A3 (U)-xxopqoxx 11B3 (U)-M(aaaa:aaaa+1) aaaa (X)-iiii - - T T T8C CMPX iiii 9C (x)-M(aa:aa+1)**a**a докк AC qoxx-(X)aaaa BC (X)-M(aaaa:aaaa+1)108C (Y)-iiii CMPY iiii -- T T T T 109C (Y)-M(aa:aa+1)aa qoxx 10AC (Y) - xxop10BC (Y)-M(aaa:aaaa+1) aaaa - - T T 0 -TST ØD M(aa) - 00aa 6D xxop-00 qoxx **7**D M(aaaa)-00 aaaa - T T Ø Ø (A) - 004D TSTA - - T T 0 0

6809 compare / test instructions

 $(B) - \emptyset \emptyset$ 

5D

TSTB

6809

#### load / pull instructions Oper-0p-Function Status monic and code FHINZVC EXG r 1 1E exchange 2 registers ? ? ? ? ? ? 3 TFR rl 1F transfer register 3 3 3 3 3 3 3 3 LLA ii 86 A=ii - - T T 0 aa 96 A=M(aa)ххор A6 A=xxop aaaa **B6** A=M (aaaa) LDB ii C6 B=ii T T Ø -D6 B=M(aa)aa ххор E6 B=xxop F6 aaaa B=M (aaaa) D=iiii LDD iiii CC - T T 0 -DC aa D=M(aa:aa+1)EC qoxx D=xxop aaaa FC D=M(aaaa:aaaa+1) LDS iiii 10CE S=iiii - T T Ø -10DE S=M(aa:aa+1) aa 10EE S=xxop qox x aaaa 10FE S=M(aaaa:aaaa+1) LDU iiii CE U=iiii - T T 5 -U=M(aa,aa+1)a a DE **XXOD** EE Ŭ=xxop aaaa FEU=M (aaaa:aaaa+1) LDX iiii 8E X=iiii T T 6 -9E aa X=M(aa:aa+1)qoxx AE X=xxop aaaa BE X=M(aaaa:aaaa+1)LDY iiii 108E Y=iiii - T T Ø aa 109E Y=M(aa:aa+1)10AE Y=xxop qoxx 10BE Y=M (aaaa:aaaa+1) aaaa LEAS S=effad xxop U=effad xxop **xxo**p 33 LEAU qoxx X=effad xxop LEAX qoxx 30 T LEAY qoxx 31 Y=effad xxop Т PULS r 1 35 pull register(s) from M(S) 3 3 3 3 3 3 ? PULU r 1 37 pull register(s) from M(U) ? ? ? ? ? ? ?

# SSB 6809 ASSEMBLER USER MANUAL

## ( 6809 store / push instructions )

| ine-         | Oper-                      | _                  | Function                                                                   | Status   |   |   |    |    |   |   |
|--------------|----------------------------|--------------------|----------------------------------------------------------------------------|----------|---|---|----|----|---|---|
| monic        | and                        | code               |                                                                            | F        | Н | I | N  | Z  | Ņ | ( |
| STA          | aa<br>xxop                 | 97<br>A7           | M(aa) = (A)<br>xxop=(A)                                                    |          | - | - | T  | T  | Ø | • |
| STB          | aaaa<br>aa<br>xxop         | B7<br>D7<br>E7     | M(aaaa) = (A)<br>M(aa) = (B)<br>xxop=(B)                                   | -        | - | - | T  | Į, | Ø |   |
| STD          | aaaa<br>aa<br>xxop         | F7<br>DD<br>ED     | M(aaaa) = (B)<br>M(aa:aa+1) = (D)<br>xxop=(D)                              | -        | - |   | T  | т  | Ň | , |
| STS          | aaaa<br>aa<br>xxop         | FD<br>10DF<br>10EF | M(aaaa:aaaa+1)=(D)                                                         | -        | - | - | T  | T  | Ø | , |
| STU          | aaaa<br>aa<br>xxop         | 10FF<br>DF<br>EF   |                                                                            | -        | - |   | T  | T  | Ø |   |
| STX          | aaaa<br>aa<br>xxop         | FF<br>9F<br>AF     | M(aaaa:aaaa+1) = (U)<br>M(aa:aa+1) = (X)<br>xxop= (X)                      | -        | _ | - | T  | T  | Ü |   |
| STY          | aaaa<br>aa<br>xxop<br>aaaa | BF<br>109F<br>10AF | M(aaa:aaa+1) = (X)<br>M(aa:aa+1) = (Y)<br>xxop=(Y)<br>M(aaaa:aaaa+1) = (Y) | -        | - | - | T. | T  | Ø |   |
| PSHS<br>PSHU | rl<br>rl                   | 34<br>36           | push register(s) onto M(S) push register(s) onto M(U)                      | <u>-</u> | - | - | _  | -  | - |   |

7

#### shift / rotate instructions ) Mne-Oper-Function Op-Status onic and code FHINZVC LSL Ø8 aa M(aa) = M(aa) A < 1- ? - T T ? T 68 qoxx xxop = xxop A < 178 M(aaaa) = M(aaaa) A < 1aaaa LSLA 48 A=(A) A<1? - T T ? T LSLB --58 B=(B) A < 1- ? - T T ? T LSR 04 M(aa) = M(aa) L > 1aa - - Ø T - T 64 qoxx xxop=xxop L> 1 74 aaaa M(aaaa) = M(aaaa) L> 1A=(A) L> 1 B=(B) 1> 1 **LSRA** 44 $\emptyset$ T - T LSRE 54 - Ø T - T ROL 09 M(aa) = M(aa) R < 1aa - T T ? T 69 xxop=xxop R< 1 qoxx 79 M(aaaa) = M(aaaa) R < 1aaaa ROLA 49 A=(A) R< 1 - T T ? T ROLB \_\_\_ 59 B=(B) R< 1 TT?T ROR Ø6 M(aa) = M(aa) R > 1aa - T T ? T дохх 66 xxop=xxop R> 176 aaaa M(aaaa) = M(aaaa) R > 1RORA 46 A=(A) R>1- T T ? T RORB 56 B=(B) R>1- T T ? T

## ( 6809 branching instructions )

```
ilne-
        Oper-
                 Cp-
                       Function
                                                                             Status
monic and
                 code
                                                                            FHINZV:
BCC
                       P=(P)+2+rr iff (C)=0
        rr
                 24
BCS
                 25
                       P=(P)+2+rr \ iff (C)=1
        rr
BEQ
        rr
                 27
                       P=(P)+2+rr iff
                                          (2)=1
BGE
        rr
                 2C
                       P=(P)+2+rr iff (N) xor (V)=0
BGT
        rr
                 2E
                       P = (P) + 2 + rr \text{ iff } (Z) \text{ or } [(N) \text{ xor } (V)] = \emptyset
BHI
                       P=(P)+2+rr \ iff (C) \ xor (2)=0
                 22
        rr
BIIS
                 .24
        rr
                       P = (P) + 2 + rr \text{ iff } (C) = \emptyset
BLE
        rr
                 2F
                       P=(P)+2+rr iff
                                           (Z) or [(N) xor (V)]=1
                       P=(P)+2+rr iff
P=(P)+2+rr iff
BLO
        rr
                 25
                                           (C)=1
BLS
        rr
                 23
                                           (C) or (Z)=1
BLT
                 2D
        rŗ
                       P=(P)+2+rr iff (N) xor (V)=1
BMI
                 2B
        rr
                       P=(P)+2+rr \ iff \ (N)=1
BNE
        rr
                 26
                       P = (P) + 2 + rr \text{ iff } (Z) = \emptyset
BPL
        rr
                 2A
                       P=(P)+2+rr iff (N)=\emptyset
BRA
                 20
                       P=(P)+2+rr ( always )
        rr
BRN
                 21
                       P=(P)+2 (a 2 byte no-op)
        rr
BVC
                 28
                       P=(P)+2+rr \text{ iff } (V)=0
        rr
BVS
                 29
        rr
                       P = (P) + 2 + rr \text{ iff } (V) = 1
JMP
                 ØE
                       P=00aa
        aa
                 6E
        qoxx
                       P=xxop
                 7E
                       P=aaaa
        aaaa
                 1024 P = (P) + 4 + rrr iff (C) = 0
LBCC
       rrrr
                 1025 P=(P)+4+rrrr iff (C)=1
LBCS
       rrrr
                1027 P=(P)+4+rrr iff (Z)=1
102C P=(P)+4+rrr iff (N) xor (V)=0
102E P=(P)+4+rrr iff (Z) or [(N) xor (V)]=0
LBEQ
       rrrr
LBGE
       rrrr
LBGT
       rrrr
LBHI
                 1022 P = (P) + 4 + rrr iff (C) xor (Z)
       rrrr
LBHS
       rrrr
                 1024 P = (P) + 4 + rrr iff
                                             (C) = \emptyset
LBLE
       rrrr
                 102F P=(P)+4+rrrr iff (Z) or [(N) xor (V)]=1
LBLO
       rrrr
                 1025 P = (P) + 4 + rrr iff (C) = 1
LBLS
                 1023 P = (P) + 4 + rrr iff
       rrrr
                                             (C) or (Z)=1
                 102D P = (P) + 4 + rrrr iff (N) xor (V) = 1
LBLT
       rrrr
LBMI
       rrrr
                102B P = (P) + 4 + rrrr iff (N) = 1
LBNE
       rrrr
                1026 P=(P)+4+rrr iff (Z)=0
LBPL
       rrrr
                102A P=(P)+4+rrr iff (N)=0
LBRA
                       P=(P)+3+rrrr (always)
       rrrr
LBRN
                1021 P=(P)+4 (a 4 byte no-op)
       rrrr
                1028 P = (P) + 4 + rrr iff (V) = 0
I.BVC
       rrrr
LBVS
                1029 P=(P)+4+rrrr iff (V)=1
       rrrr
```

12

**3**C

13

NOF

CWAI

SYNC

ii

#### 6809 subroutine & special function instructions Mne-Oper-0p-Function Status monic and code FHINZVC BSR 8D M(S-2) = (P)+2; P=(P)+2+rr; S=(S)-2rr JSR aa 9D M(S-2) = (P) + 2; P = 00aa; S = (S) - 2M(S-2) = (P) + 2; $P = x \times op$ ; S = (S) - 2xxop ΑD aaaa BD M(S-2) = (P) + 3; P = aaaa; S = (S) - 217 LBSR rrrr M(S-2)=(P)+3; P=(P)+3+rrrr; S=(S)-2SWI M(S-2) = (P)+1; P=M(\$FFFA); S=(S)-23F 103F M(S-2) = (P)+2; P=M(\$FFF4); S=(S)-2SWI2 SWI3 113F M(S-2) = (P) + 2; P=M(\$FFF2); S=(S) - 23B RTI P=M(S); S=(S)+23 3 3 3 3 3 3 RTS 39 P=M(S); S=(S)+2DEC ØA aa M(aa) = M(aa) - 1- T T ? -6A xxop xxop=xxop-1 7A aaaa M(aaaa) = M(aaaa) - 1DECA 4A A=(A)-1--TT?-DECB 5A B=(B)-1- T T? -INC ØC aa M(aa) = M(aa) + 1T T? -6C докк xxop=xxop+l aaaa 7C M(aaaa) = M(aaaa) + 1INCA 4C A=(A)+1TT? INCB 5C B = (B) + 1тт? .

P=(P)+1 ( 1 byte no-op )

Syncronize

clear & wait for interrupt

? ? ? ? ? ? ?

? ? ? ? ? ? ?

```
indexed addressing )
the value of the post-byte ( the 1st byte following the opcode )
for instructions using the indexed addressing mode is determined
by the format of the operand. Two formats exist: Simple indexing
and complex indexing. Simple indexing is used when the operand
is of the form:
      <e xp>, R
where <exp> is an expression in the range -16 to 15 but not equal
to zero, and R is one of the index registers "S", "U",
"Y". All other indexed addressing modes use the complex indexing
        The two post-byte formats are:
format.
         simple
                                complex
    Ø R R X X X X X
                           1 R R I T T T
     where
             RR = 00
                            for X register ( or PCR if TTTT = 110x )
                    01
                            for Y register
                    10
                            for U register
                    11
                            for S register
               or
  and
         T T T T = 0000
                            for single auto increment (R+)
                    0001
                            for double auto increment ( R++ )
                           for single auto decrement (R-) for double auto decrement (R-)
                    0010
                    0011
                    0100
                            for Ø offset or no offset
                            for register B is offset (B,R) for register A is offset (A,R)
                    0101
                    0110
                    1000
                            for 8 bit offset ( aa,R )
                    1001
                            for 16 bit offset ( aaaa,R )
                    1011
                            for register D is offset ( D,R )
                    1100
                            for 8 bit offset with PCR
                            for 16 bit offset with PCR
                    1101
                    1111
                            for extended indirect addressing
                or
  and
                            for direct addressing
                I = \emptyset
                            for indirect addressing
                or
 ( X X X X X is a 5 bit 2's compliment offset )
```

POST

BYTE

)



### APPENDIX C

### ( ERROR MESSAGES )

- 173 Invalid use of direct mode indicator. The direct mode indicator ("<") was used in the indirect extended addressing mode. The "<" is ignored.
- 174 Invalid auto increment/decrement format. Single auto increment or decrement was used in the indirect mode, or more than 2 "+" or "-" encountered.
- 175 Invalid index register format. One of the accumulators "A", "B", or "D" was used as the offset in the indexed mode, but was not followed by one of the index registers "S", "U", "X", or "Y".
- 176 Invalid expression for PSH/PUL The immediate expression following one of the instructions "PSHS", "PULS", "PSHU", or "PULU" contained symbols defined with other than the "REG" directive, contained an operator other than "!+" or contained no symbol following the "#".
- 177 Incompatable register for PSH/PUL instruction. The register list for the PSHS/PULS instructions cannot contain the register "S", and the register list for the PSHU/PULU instructions cannot contain the register "U".
- 178 Invalid register operand specification. An undefined register name was encountered in a register list or there are not exactly two register names in the register list for a TFR/EXG instruction or no register list was specified for a PSH/PUL instruction.
- 179 Incompatable register pair. The register pair of an EXG instruction was not the same size or the register pair of a TFR instruction specified a transfer from an 8 bit register to a 16 bit register.
- 202 Label or opcode error. The label or opcode symbol does not begin with an alphabetic character or a period.
- 205 Label error. The statement's label field is not terminated with a blank. This Usually occurs if an invalid character is used in the label.
- 207 Undefined opcode. The symbol in the opcode field is not a valid 6809 (or 6800) mnemonic nor is it a valid ASM09 directive.
- 208 Branch out of range. The operand resulted in a forward offset of >129 bytes or a backward offset of >126 bytes from the first byte of the branch instruction.

- 209 Illegal addressing mode. The specified addressing mode in the operand field is not valid for this instruction type.
- 210 Byte overflow. The operand's value exceeded 1 byte (6 bits). The most significant 8 bits of the 16 bit value of the expression must be all ones or all zeroes for a one byte field. (due to sign propagation of 2's compliment numbers)
- 211 Undefined symbol. A symbol was referenced in an operand field but has never occured in the lablel field of a correctly assembled instruction.
- 212 Directive operand error. A syntax error was detected in the operand field of a ASM09 directive.
- 214 FCB directive syntax error. The structure of the FCB is incorrect.
- 215 PDB directive syntax error. The structure of the PDB is incorrect
- 216 Directive operand error. The directive's operand field is missing, terminated by an invalid character, or an expression in the operand field contains an invalid operator.
- 217 Option error. An option in the operand field of the OPT directive is undefined.
- 219 No "END" statement. The end of the last source file has been encountered before an "END" directive. ASM09 has supplied the "END".
- 220 Phasing error. The value of the program counter during pass II is different from the value during pass I for the same instruction.
- 221 Symbol table overflow. The symbol table has overflowed. This is a FATAL pass I error which will cause ASM09 to suspend assembly.
- 222 Reserved symbol used. One of the reserved symbols ("A", "B", "X", "Y", "U", "S", "D", "CC", "DP", "PC", or "PCR") appeared in the label field or in the operand field of an instruction. These symbols can only be used in the operation field to modify a root mnemonic ("A" or "B") or in the operand field to specify indexed addressing.
- 223 Invalid label for directive. Depending on the directive, there must be or must not be a symbol in the label field of this instruction.
- 226 Illegal parenthesis. The parentheses "(" or ")" in an expression do not balance. EG there is/are more of one than the other.

- 227 Too many digits in a numeric constant. An overflow has occured during the evaluation of a numeric constant. May also occur if a sequence number is present / missing on a line in a file which has not / has sequence numbers.
- 229 Invalid starting execution address. The starting execution address given in the expression on the "END" statement is not valid.
- 233 Symbol name too large. A symbol of greater than 6 characters was incountered.
- 234 Multiply defined symbol. A reference was made to a multiply defined symbol.
- 235 Memory error. The "OPT MEM" directive was used and object code was going to be written into non-existant memory or into the memory occupied by ASM09. The write operation has been aborted & no further writes will be done.
- 236 Program counter overflow. The program counter overflowed beyond \$FFFF.
- 237 invalid terminator for sequence number. The character following a user supplied sequence number was not a blank.
- 241 Illegal symbol used in an expression. An undefined forward referend symbol was used in an expression. This can occur in the PCR indexing mode.
- 242 OPT directive error. Conflicting options were specified or the "OPT CRE" directive was encountered after the first symbol had been placed into the symbol table.
- 244 Illegal page or line length. The "OPT LLE=nnn" or "OPT P=nnn" directive(s) was(were) used with "nnn" being outside the allowable range.
- 247 Invalid operand terminator. The character following the legal part of an operand is not a valid terminator (usually a CR or a space). May also be caused by invalid indirect pairing (ie "[" & "]" not balanced).

# ( WARNING MESSAGES )

- Long branch not required. A long branch instruction was used to branch to an address within the range of -126 to +129. Although the long branch instruction could be changed to a short branch, it could result in other out-of-range short branches.
- Extended addressing should be used. Direct addressing was forced by using the "<" indicator. However, the direct-page psuedo register (set by the "SETDP" directive) indicated that the location was accessable via the extended addressing mode.
- Duplicate register specification. The same register was specified more than once in a register list. Register "D" specified with either "A" or "B" will give this warning.
- 4 Possible SETDP expression error. The most significant byte of an expression in a "SETDP" directive was not zero.
- 5 Extended addressing should have been used. Direct addressing was forced by using the "<" indicator.</p>
- 6 Possible transfer error. The TFR instruction was used to transfer from a 16 bit register to an 8 bit register. The result of such a transfer is to move the lower 8 bits & to transacte the upper 8 bits.

### APPENDIX D

## ( LISTING DESCRIPTION )

| COLUMN         | CONTENTS                                            |
|----------------|-----------------------------------------------------|
| 1-5            | Source line number                                  |
| 8:11<br>13:14  | Program Counter                                     |
| 15:16          | lst (or only) byte of op-code                       |
| 18:19          | 2nd byte of op-code (if any)                        |
| 20:21          | lst byte of operand<br>2nd byte of operand (if any) |
| 20.21          | for non-branch, non-indexed instructions:           |
| 18-19          | lst byte of operand                                 |
| 20:21          | 2nd byte of operand (if any)                        |
| <del>-</del>   | for non-branch, indexed instructions:               |
| 18:19          | index post-byte                                     |
| 21:22          | 1st byte of operand                                 |
| 23:24          | 2nd byte of operand (if any)                        |
|                | for branch instructions:                            |
| 18:19          | lst byte of relative branch offset                  |
| 20:21          | 2nd byte of offset (if any)                         |
| 23:26          | absolute address of target                          |
| •              | for 6800-equivalent instructions:                   |
| 18:19          | 2nd byte of translated instruction                  |
| 21:22<br>23:24 | 3rd byte of instruction (if any)                    |
| 23:24          | 4th byte of instruction (if any)                    |
| 23:26          | for directives like BSZ, EQU, ORG, ETC.:            |
| 23.20          | value of reduced operand expression                 |
| 28:33          | Label                                               |
| 35:40          | Operation                                           |
| 41:48          | Operand; longer operands extend into comment field  |
| 50:12b         | Comment(s)                                          |
|                |                                                     |

## CROSS REFERENCE CONCORDANCE FORMAT

| COLUMN<br>1 | CONTENTS Symbol's "type": U = udefined symbol M = multiply defined symbol S = "set" symbol                                                                                                                                                  |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4:7         | Hexadecimal value of symbol                                                                                                                                                                                                                 |
| 9:14        | The symbol                                                                                                                                                                                                                                  |
| 16:?        | List of source line numbers where the symbol has been referenced. An "*" appears after the line number of a symbol's definition. If the symbol is undefined, the "*" will appear after the line number of the last reference to the symbol. |

### APPENDIX E

### ( USEFUL INFORMATION )

### 1) USAGE OF SYSTEM'S DATE & TIME

In order to use the system's date / time facility, the vector at \$D2E2 (in a "\$C000" system) must point to somewhere other than the system's warm-start routine. ASM09 checks this, and if the vector is an effective "warm start", the "T" option is ignored. This vector should read the date / time hardware or do whatever is necessary to get a date & time string into the system's parameter table. These strings must be 15 or less bytes long (for the date) and 8 or less bytes long (for the time) and both must be terminated by a \$00. See the DOS69 manual for more details. In order to use the strings (initialized with "SET") with out having a date / time driver (or hardware), it is suggested that you change the vector (at \$D2E2 in a \$C000 system) to:

### \$39,\$00,\$00

This will cause ASM09 to presume that the date / time has been read. ASM09 will then retrive the bogus date / time which is in the system's tables. See the DOS69 listing for more detailed information. i

### 2) I/O BREAK, PAUSE, & RESUME

ASM09 will moniter the keyboard for a keypress during assembly. If one is detected, then the key is checked. If this key is one of the three control characters (see the DOS69 manual for information on changing the characters) defined by the system's parameter table, then ASM09 will take the appropriate action. If any other key is pressed, it will be ignored. The three pre-defined keys are:

char function

C causes assembly to be aborted

esc stops the assembly ( waits for start or abort )

esc starts the assembly again

This is useful to "throttle" the listing if it is going to a CRT.

