# Programming Manual altair 680b # **Table of Contents** | I. | INTRODUCTION page 3 | |------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | II. | SYSTEM DESCRIPTION page 5 | | III. | SOURCE LANGUAGE AND ADDRESSING MODES page 7 | | | Character Set page 7 Fields of the Source Statement page 8 | | | Addressing Modes | | IV. | INSTRUCTION SET | | ٧. | Condition Code Register Operations page 27 M6800 Instruction Set page 28-29 Hexadecimal Values of Machine Codes page 30 Octal Values of Machine Codes page 31 Decimal Values of Machine Codes page 32 Condition Code Register Instructions page 33 Number Systems page 34 Accumulator and Memory Operations page 38 Program Control Operations page 41 ARITHMETIC OPERATIONS page 53 | | | Number Systems | | ٧1. | SAMPLE PROGRAMS | Major portions of the Altair 680b Programming Manual have been reprinted by permission of Motorola Semiconductor Products, Inc., copyright 1975. • # I INTRODUCTION The Altair 680b Programming Manual describes the format of the 680b assembly code source language and the 6800 MPU instruction set and addressing modes. A brief overview of arithmetic programming techniques and some general purpose sample programs are also included. This manual is in no way intended to be a beginning course in computer programming. Figure 2-1 Microcomputer System Block Diagram Figure 2-2. Programming Model of M6800 # II SYSTEM DESCRIPTION In order to program a computer in machine language or assembly code, it is necessary to have at least a block diagram level understanding of the computer hardware. A general purpose microcomputer (see figure 2-1) consists of a microprocessing unit (MPU), a memory, and a number of input and output devices. These components are linked together by an address bus and a data bus. The computer memory is used to store instructions and data for use by the MPU. In the 680b, the memory is organized into 8 bit words called bytes. Each memory byte is assigned a unique 16 bit address. This address is used by the MPU to gain access to the contents of a particular memory byte. Input and output devices, such as Teletypes, CRT Terminals, and paper tape readers are used for communication between the computer and the external world. Each I/O device in a 680b system has one or more unique 16 bit addresses assigned to it. The MPU is responsible for controlling the microcomputer system and performing all arithmetic and logic operations. The MPU must be told what steps to execute to perform a given task. This is accomplished by storing a program into the computer's memory. Once a program is stored in memory, a register in the MPU called the Program Counter (PC) is loaded with the address of the memory byte which contains the first instruction of the program. When the computer is put into the run mode, the MPU puts the address contained in the PC on the address bus and reads the contents of that location via the data bus. The instruction that has been read is executed after the PC is incremented to point to the next instruction. This sequence is repeated until the processor is halted. The 680b MPU is a Motorola M6800 which operates on 8-bit binary numbers presented to it via the data bus. A given number (byte) may represent either data or an instruction to be executed, depending on where it is encountered in a program. The M6800 has 72 unique instructions, however, it recognizes and takes action on 197 of the 256 possibilities that can occur using an 8-bit word length. This larger number of instructions results from the fact that many of the executive instructions have more than one addressing mode. These addressing modes refer to the manner in which the program causes the MPU to obtain its instructions and data. The programmer must have a method for addressing the MPU's internal registers and all of the external memory locations. The complete executive instruction set and the applicable addressing modes are summarized in Figure 4-1, however, the addressing modes will be described in greater detail prior to introducing the instruction set in a later section. A programming model of the M6800 is shown in Figure 2-2. The programmable registers consist of: two 8-bit Accumulators; a 6-bit Condition Code Register; a Program Counter, a Stack Pointer, and an Index Register, each 16 bits long. #### III SOURCE LANGUAGE & ADDRESSING MODES While programs can be written in the MPU's language, that is, binary numbers, there is no easy way for the programmer to remember the particular word that corresponds to a given operation. For this reason, instructions are assigned a three letter mnemonic symbol that suggests the definition of the instruction. The program is written as a series of source statements using this symbolic language and then translated into machine language. The translation can be done manually using an alphabetic listing of the symbolic instruction set such as that shown in Appendix A. More often, the translation is accomplished by means of a special computer program referred to as an assembler. The source language for the M6800 microprocessing unit is built around 72 mnemonic instructions and 12 assembler directives. Section III deals with the details of the character set and format of the source language. #### CHARACTER SET The characters used in the source language for the 680b assembler form a sub-set of ASCII (American Standard Code for Information Interchange, 1968). The ASCII Code is shown in Figure 3-1. The following characters are recognized by the assembler. - 1. The alphabet A through Z The integers 0 through 9 - 3. Four arithmetic operators: - + \* / - Characters used as special prefixes: - (pounds sign) specifies the immediate mode of addressing (dollar sign) specifies a hexadecimal number - (commercial at) specifies an octal number (percent) specifies a binary number - ( apostrophe) specifies an ASCII literal character Characters used as special suffices: - B (letter B) specifies a binary number H (letter H) specifies a hexadecimal number O (letter O) specifies an octal number - Q (letter Q) specifies an octal number - 6. Four separating characters: - SPACE - Horizontal TAB - CR (carriage return) - , (comma) - The use of horizontal TAB is always optional, and can be replaced by SPACE. - A comment in a source statement may include any characters with ASCII hexadecimal values from 20 (SP) through 5F ( ). 8. In addition to the above, the assembler has the capability of reading strings of characters and of entering the corresponding 7-bit ASCII code into specified locations in the memory. This capability is provided by the assembler directive FCC (See Appendix B). Any characters corresponding to ASCII hexadecimal values 20 (SP) through 5F (\_\_) can be processed. This kind of processing can also be done, for a single ASCII character, by using the immediate mode of addressing with an operand in the form "#C". | BITS 4 thru 6 | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | <u>7</u> | |----------------|----|-----|-----|----|---|---|--------------|---|----------| | | 0 | NUL | DLE | SP | 0 | @ | P | | р | | | 1 | SOH | DC1 | ! | 1 | Α | Q | a | q | | | 2 | STX | DC2 | * | 2 | В | R | b | ī | | | 3 | ETX | DC3 | # | 3 | С | S | c | S | | | 4 | EOT | DC4 | \$ | 4 | D | T | d | t | | | 5 | ENQ | NAK | % | 5 | E | U | e | u | | BITS 0 thru 3< | 6 | ACK | SYN | & | 6 | F | V | f | v | | | 7 | BEL | ETB | , | 7 | G | W | g | w | | | 8 | BS | CAN | ( | 8 | Н | X | h | x | | | 9 | HT | EM | ) | 9 | I | Y | i | у | | | Α | LF | SUB | * | : | J | Z | j | z | | | В | VT | ESC | + | ; | ĸ | ] | k | { | | | С | FF | FS | , | < | L | Ì | 1 | 1 | | | D | CR | GS | - | = | M | ] | m | } | | | E | SO | RS | | > | N | < | n | * | | | F_ | SI | US | 1 | ? | 0 | <del>-</del> | 0 | DEL | Figure 3-1 ASCII Code ## FIELDS OF THE SOURCE STATEMENT A source statement includes from one to four fields. From left to right, the four fields are: (1) label (2) operator (mnemonic) (3) operand (4) comment The comment is optional, and may be used in most source statements. Comments are intended for the convenience of the programmer, and to facilitate documentation of the program. A label is required for some statements which are involved in the definition of symbols and, in some cases, at the destinations of branches and jump instructions. An operand field may or may not be present depending on the nature of the operator. The mnemonic operator must be present in any statement except when the statement consists only of a comment. With one optional exception (explained below), the successive fields within a statement are separated by, either: one or more SPACE characters horizontal TAB The use of the horizontal TAB is hardware-dependent in that its availability will depend on the particular type of terminal in use. The SPACE bar may always be used rather than the TAB key. #### CAUTION A SPACE in the first character position of a source statement is used to indicate that a label is not included in the statement. A label, if used, must begin in the first character position of the source statement. It follows from the above that, when typing a source program into a file in which the statements are identified by line numbers, there will be only one space following the line number if the statement includes a label. Two or more spaces following the line number will indicate that a label is not used. The exception to the foregoing rule relating to SPACE or horizontal TAB between the elements of a source statement applies to operators with dual addressing in the operand field (indicated by the column headed "Dual Operand" in Figure 3-2 and to certain other operators if they are functioning in the "accumulator mode" of addressing (indicated by the column headed "ACCX" in Figure 3-2. In these cases, the first character of the operand field is either A or B (indicating accumulator A or B), and the second character is a SPACE. The programmer then has the option of omitting the SPACE between the operator and the operand field. This results in an apparent four-character format, as for example "ADCA", "ASRB", "STAA", "TSTB", and similarly. #### Label Field An asterisk (\*) in the first character position of a statement causes the entire statement to become a comment. Otherwise, the comment will be preceded in the statement by one or more fields of the other three types, and the comment will occupy the last field in the statement. Except in some cases when it is used with the mnemonic operator EQU (see below) a label always corresponds to a numerical address in the programmable system. It provides a means of referring to that address by using a symbol identical with the label. The address represented by the label (or symbol) may be that of an instruction in the machine code or of a location in the memory where data is stored. | | (Dual Operand) | ACCX | hmmediate | Direct | Extended | Indexed | Inherent | Reletive | | (Due) Operand) | ACCX | Immediate | Direct | Extended | Indexed | Inherent | |-------------------|----------------|------|-----------|--------|----------|-------------|----------|----------|-----------------------------------------------|----------------|------|-------------|-------------|----------|---------|------------------------| | ABA | | • | • | ٠ | ٠ | ٠ | 2 | ٠ | INC | | 2 | • | • | 6 | 7 | • | | ADC | X | • | 2 | 3 | 4 | 5 | • | • | INS | | • | • | ٠ | • | • | 4 | | ADD | × | • | 2 | 3 | •4 | 5 | • | • | INX | | ٠ | • | • | • | • | 4 | | AND | × | • | 2 | 3 | 4 | 5<br>5<br>7 | • | • | JMP | | • | • | • | 3 | 4 | • | | ASL | | 2 | • | • | 6 | 7 | • | • | JSA | | ٠ | • | • | 9 | 8 | • | | ASR | | 2 | ٠ | ٠ | 6 | 7 | • | ٠ | LDA<br>LDS | × | • | 2<br>3<br>3 | 3 | 4 | 5 | • | | BCC | | • | • | • | ٠ | • | • | 4 | LDS | | • | 3 | 4 | 5<br>5 | 6 | ٠ | | BCS | | • | • | • | • | • | • | 4 | LDX | | • | | 4 | 5 | 6 | • | | BEA | | • | • | • | • | • | • | 4 | LSR<br>NEG<br>NOP<br>ORA<br>PSH<br>PUL<br>ROL | | 2 | ٠ | • | 6 | 7 | • | | BGE<br>BGT<br>BHI | | • | • | • | ٠ | • | • | 4 | NEG | | | • | ٠ | 6 | | 2 | | BGI | | • | • | • | • | • | : | 4 | OPA | × | : | 2 | 3 | 4 | 5 | • | | DIT<br>DIT | _ | • | 2 | 3 | 4 | 5 | : | 7 | PSH | ^ | 4 | • | • | - | • | : | | BLE | × | • | • | • | 7 | • | : | 4 | PU | | 4 | : | : | : | : | : | | BLS | | 7 | | • | - | | | 4 | ROL | | 2 | | | 6 | 7 | • | | ALT | | - | : | | | - | - | 4 | AOR<br>RTI<br>RTS | | 2 | | - | ě | 7 | | | BLT<br>BMI | | | | | | | • | 4 | RTI | | • | • | | • | | 10 | | RNE | | | | • | | • | • | 4 | RTS | | • | • | • | • | • | 5 | | BPL | | • | | | • | • | • | 4 | SBA | | • | • | • | • | • | 2 | | BPL<br>BRA | | ٠ | • | | ٠ | • | • | 4 | SBC | x | ٠ | 2 | 3 | 4 | 5 | • | | BSA | | • | • | | • | | • | 8 | SEC | | • | • | • | • | | 2 | | BVC | | • | • | • | • | • | • | 4 | SBA<br>SBC<br>SEC<br>SEI<br>SEV<br>STA<br>STS | | ٠ | • | • | • | • | 2 2 2 | | BVS | | • | • | • | • | • | • | 4 | SEV | | • | • | • | • | • | | | CBA | | • | • | • | • | • | 2 | ٠ | STA | × | ٠ | • | 4 | 5 | 6 | • | | CLC | | • | • | • | • | • | 2 2 2 | • | STS | | • | • | 5<br>5<br>3 | 6 | 7 | • | | CLI<br>CLR | | • | • | • | • | • | | • | STX | | • | • | 5 | 6 | 7 | • | | CLR | | 2 | • | • | 6 | 7 | • | • | SUB | × | • | 2 | | 4 | 5 | • | | CLV<br>CMP | | ٠ | • | • | ٠ | • | 2 | • | SWI | | • | • | • | • | • | 12 | | CMP | × | ٠ | 2 | 3 | 4 | 5 | • | • | IAB | | • | • | • | • | • | 2 | | COM | | 2 | • | • | 6 | 7 | ٠ | • | TAB<br>TAP<br>TBA | | • | • | • | • | • | 2 | | CPX | | • | 3 | 4 | 5 | 6 | 2 | • | TPA | | • | • | • | • | • | 12<br>2<br>2<br>2<br>2 | | DAA<br>DEC | | * | • | • | 6 | 7 | 2 | • | TOT | | 2 | • | • | 6 | 7 | 2 | | DES | | 2 | • | : | • | - ' | 4 | • | TST<br>TSX<br>TSX | | - | • | • | • | | • | | DEX | | • | • | _ | _ | : | 4 | • | TSY | | • | • | : | : | • | 4 | | EOR | · | • | 2 | 3 | 4 | 5 | : | - 3 | WAI | | : | • | : | • | • | 9 | | EUR | X | • | Z | 3 | • | 9 | • | • | ***** | | • | • | • | • | • | 3 | NOTE: Interrupt time is 12 cycles from the end of the instruction being executed, except following a WA1 instruction. Then it is 4 cycles. Figure 3-2 Instruction Addressing Modes and Execution Times (Times in Machine Cycles) The following rules apply to labels: - A label consists of from 1 to 6 alphanumeric characters. - The first character of a label must be alphabetic. - 3. A label must begin in the first character position of a statement. - 4. All labels within a program must be unique. - 5. A label must not consist of any one of the single characters A, B, or X. (These characters are reserved for special syntax, and refer to "accumulator A", "accumulator B", and "index register", respectively.) Labels are used in source programs in the following cases: - 1. A label may be included in any statement which is the destina - a. Any of the conditional branch instructions: BCC BCS BEQ BGE BGT BHI BLE BLS BLT BMI BNE BPL BVC BVS - b. The unconditional branch instruction: BRA, orc. The branch to a subroutine: BSR Correspondingly, the operand field of the branch instruction would consist only of a single symbol which would be identical with the label at the destination. In the case of the instruction BSR, the symbol in the operand field, identical with the label at the destination, could be regarded as, in effect, the name of the subroutine. 2. A label may be included in any statement which is the destination of either of the instructions: JMP (unconditional jump) or JSR (jump to subroutine) when the instruction is being used in the extended mode of addressing. Correspondingly, when used in the extended mode of addressing, the operand field of either of the instructions JMP and JSR $\,$ would consist only of a symbol which would be identical with the label at the destination. For JSR, this could be regarded as, in effect, the name of the subroutine. - 3. A label would be included in an assembler directive which specifies the location in memory corresponding to a symbol. This applies only to the directives: FCB FCC FDB - When used for this purpose, the label in the assembler directive would be identical with the corresponding symbol. - A label must be used in a statement which includes the assembler directive EQU. The label will be identical with the symbol which the EQU statement is defining. 5. In other cases, a label may be used in any executable instruction at the option of the programmer. Among the assembler directives EQU must always be written with a label; each of FCB, FCC, FDB, and RMB, may have a label; any other of the assembler directives must not be written with a label. (For further details on the assembler directives see Appendix $\ensuremath{\mathtt{B.}}$ ) ## Operator Field The mnemonic operators recognized by the assembler include 72 executable instructions. Each instruction is translated by the assembler into one to three bytes of machine code. The remaining mnemonic operators are assembler directives, of which four (FCB, FCC, FDB, and RMB) are translated into one or more bytes of machine code. The other assembler directives control the overall assembly process and are not translated individually into machine code. A functional classification of the mnemonic operators is shown in Figure 3-3. An alphabetical listing of the executable instructions is given, with brief definitions, in Figure 3-4. #### Executable Instructions Each of the executable instructions recognized in the source language consists of three alphabetic characters. (However, as when the first operand in the operand field is either A or B, the programmer has the option of joining the character A or B to the operator, which results in an apparent four-character format.) Figure 3-2 gives complete information stating which modes of addressing can be used with the different executable instructions. The table also shows the execution times in clock cycles. The assembly of an executable instruction results in from one to three bytes of machine code, depending on the addressing mode. This information is summarized in Figure 3-5. Detailed definitions of the executable instructions are given in Appendix A. $\,$ | I. | Оре | erations on 8-Bit Registers: | |------|----------------------------------------|-------------------------------------------------------------------------------------------------------------| | | A.<br>B.<br>C.<br>D.<br>E.<br>F.<br>G. | Shifts and Rotations ASL ASR LSR ROL ROR Logic Functions AND BIT COM EOR ORA Load and Store LDA STA PSH PUL | | II. | Jum | p and Branch Control: | | | Α. | Conditional BranchBCC BCS BEQ BGE BGT BHI BLE BLS BLT BMI BNE BPL BVC BVS | | | В. | Unconditional Branch and Jump .BRA NOP JMP | | | C. | Control of Subroutines BSR JSR RTS | | | D. | Control of Interrupts | | III. | Con | trol of Index Register and Stack Pointer: | | | A. | Index Register DEX INX LDX STX CPX | | | B. | Stack PointerDES INS LDS STS | | | C. | TransfersTSX TXS | | IV. | Con | trol of Condition Codes Register: | | | A.<br>B. | Bit Control | | V. | Ass | embler Directives | Figure 3-3 Functional Classification of the Mnemonic Operators | ABA | Add Accumulators | INS | Increment Stack Pointer | |-----|---------------------------------|------------|----------------------------------------------| | ADC | Add with Carry | INX | Increment Index Register | | ADD | Add | 1840 | | | AND | Logical And | JMP | Jump | | ASL | Arithmetic Shift Left | JSR | Jump to Subroutine | | ASP | Arithmetic Shift Right | LDA | Load Accumulator | | BCC | Branch if Carry Clear | LDS | Load Stack Pointer | | BCS | Branch if Carry Set | LÐX | Load Index Register | | BEQ | Branch if Equal to Zero | LSR | Logical Shift Right | | BGE | Branch if Greater or Equal Zero | NEG | Negate | | BGT | Branch if Greater than Zero | NOP | No Operation | | BHI | Branch if Higher | | , | | BIT | Bit Test | ORA | Inclusive OR Accumulator | | BLE | Branch if Less or Equal | PSH | Push Data | | BLS | Branch if Lower or Same | PUL | Pull Data | | BLT | Branch if Less than Zero | ROL | Rotate Left | | BMI | Branch if Minus | ROR | Rotate Right | | BNE | Branch if Not Equal to Zero | ATI | Return from Interrupt | | BPL | Branch if Plus | ATS | Return from Subroutine | | BAA | Branch Always | | | | BSR | Branch to Subroutine | SBA | Subtract Accumulators | | BVC | Branch if Overflow Clear | SBC | Subtract with Carry | | BVS | Branch if Overflow Set | SEC | Set Carry | | CBA | Compare Accumulators | SEI | Set Interrupt Mask | | CLC | Clear Carry | SEV<br>STA | Set Overflow | | CLI | Clear Interrupt Mask | | Store Accumulator | | CLR | Clear | STS | Store Stack Register | | CLV | Clear Overflow | SUB | Slore Index Register<br>Subtract | | CMP | Compare | SWI | Software Interrupt | | COM | Complement | • | ' | | CPX | Compare Index Register | TAB | Transfer Accumulators | | DAA | Decimal Adjust | TAP | Transfer Accumulators to Condition Code Reg. | | DEC | Decrement | TBA | Transfer Accumulators | | DES | Decrement Stack Pointer | TPA | Transfer Condition Code Reg. to Accumulator | | DEX | Decrement Index Register | TST | Test | | | · · | TSX | Transfer Stack Pointer to Index Register | | EOR | Exclusive OR | | Transfer Index Register to Stack Pointer | | INC | Increment | WAI | Wait for Interrupt | | | | | | Figure 3-4 Executable Instructions -- Alphabetic List | ADDRESSING MODE | NUMBER OF BYTES<br>OF MACHINE CODE | |---------------------------------------------|------------------------------------| | Inherent | 1 | | Accumulator (single operand) | 1 | | Relative | 2 | | Direct | 2 | | Indexed | 2 | | Immediate: | 2 | | 1. All instructions except CPX, LDS and LD) | 2 | | 2. Instructions CPX, LDS and LDX | 3 | | Extended | 3 | | | | Figure 3-5 # Operand Field The kind of information placed in the operand field depends on the particular mnemonic operator. For the 72 executable instructions the microprocessor uses various modes of addressing for obtaining the operands and saving the results of execution. The addressing mode is determined by the mnemonic operator combined with the information in the operand field. The addressing modes are summarized in Figure 3-2. The assembler recognizes numbers, symbols and expressions in the operand field. Dual operand instructions require either of the single characters A or B as the first operand. ### Numbers Numbers are accepted by the assembler in the following formats: | Number | (decimal) | |-----------|---------------| | \$ Number | (hexadecimal) | | Number H | (hexadecimal) | | 0 Number | (octal) | | Number 0 | (octal) | | Number Q | (octal) | | % Number | (binary) | | Number B | (binary) | where Number is a positive integer. A prefix "\$", "@", or "%" instructs the assembler to interpret the number as hexadecimal, octal, or binary, respectively. A suffix of "O" or "Q" indicate octal numbers while the suffix "N" indicates hexadecimal, and the suffix "B" indicates binary. When none of these prefixes or suffixes is used, the number is assumed to be decimal. In the case where the prefix is "\$" and the last character is "B" the assembler interprets the number as hexadecimal. Symbols Symbols when used in the operand field follow these rules. - 1. A symbol must not be any of the single characters A, B, or X. - 2. Subject to rule (1), a symbol may consist of from 1 to 6 alphanumeric characters, of which the first is alphabetic. The single character "\*" is a symbol which represents the - program counter. The special symbol "\*" represents the program counter. Its value is, therefore, equal to the numerical address of the first byte of machine code which results from the assembly of any source instruction which contains "\*" in the operand field. The single characters A, B, and X are reserved for special use in the source program, to represent accumulator A, accumulator B, and the index register. The single characters A or B must be used with dual operand instructions and may be used to indicate accumulator addressing. The single character X is indication of indexed addressing. All other symbols must be defined in the source program. There are three ways of defining a symbol, as follows: - 1. An executive instruction in the source program may include a label indentical with the symbol being defined. The value of the symbol is then the numerical address of the first byte of machine code which results from the executive instruction which includes the label. - 2. One of the assembler directives FCB, FCC, FDB, or RMB may be written with a label identical with the symbol being defined. The value of the symbol is then the numerical address of the first byte of machine code which results from the assembler directive (FCB, FCC, FDB, or RMB) which includes the label. - The symbol may be defined by using the assembler directive EQU. The mnemonic operator "EQU" is preceded by a label identical with the symbol being defined. The value of the symbol, represented by the label, is that of the operand which follows the mnemonic operator "EQU". The operand may be a number, another symbol, or an expression. #### Expressions An expression is a combination of symbols and/or numbers being separated one from the next by one of the arithmetic operators (+, -, \*, or /). The assembler evaluates expressions algebraically from left to right without parenthetical grouping, there being no heirarchy of precedence among the arithmetic operators. A fractional result, or intermediate result, if obtained during the evaluation of an expression, will be truncated to an integer value. The use of expressions in the source language does not imply any capability of the microprocessor to evaluate those expressions, since the expressions are evaluated during assembly and not during execution of the machine language program. 1 1 #### Evaluation of Symbols and Expressions The assembler must complete the numerical evaluation of symbols and expressions in two passes through a source program. Reflecting the two-pass characteristic of the assembly process, only one level of forward referencing is permitted in the use of symbols or expressions in the operand field of source statements. #### Comments Field A comment may be included in a source statement at the option of the programmer. The comment, if present, may contain any characters corresponding to ASCII hexadecimal values 20 (SP) through 5F (\_\_\_\_). Source statement comments do not affect the machine code which results from the assembly of a program. They are ignored by the assembler except for being included in the program listing. Comments may be used in source programs for aiding comprehension of the program, and for purposes of checkout and documentation. #### ADDRESSING MODES The assembler scans the operator and operand to determine the proper addressing mode. The addressing modes are: Inherent Addressing Relative Addressing Immediate Addressing Indexed Addressing Accumulator Addressing Extended Addressing Direct Addressing Dual Addressing Eleven of the executable instructions require addressing of two operands in the operand field. These instructions are indicated in Figure 3-2 by the column headed "Dual Operand". For all of these operators the first operand must be either accumulator A or accumulator B. This is specified respectively by A or B as the first character in the operand field, the second character in the operand field being a SPACE (OR TAB). For dual addressing the specification of the first operand (either A or B) is separated from that of the second operand by one or more SPACE characters (or alternatively by TAB). The second operand is specified in the operand field in accordance with the rules for immediate, direct, extended, or indexed addressing (as defined subsequently); depending on which modes of addressing are valid for the individual operators. (For the mnemonic operators which employ dual addressing it is permissible to omit the SPACE between the operator and the operand field.) Accumulator Addressing (single operand) Thirteen of the operators address a single operand from the operand field and can so address either accumulator A or accumulator B in the microprocessing unit. These operators are indicated by the column headed "ACCX" in Figure 3-2. This mode of addressing is specified by writing an operand field consisting only of the single character A or B, corresponding to accumulator A or accumulator B. (It is then permissible to omit the SPACE (or TAB) between the operator and the operand field, for this type of addressing.) For this type of addressing the assembly of a source instruction results in one byte of instruction in the machine language. (For operators PUL and PSH, the accumulator mode is the only valid mode of addressing. The remaining eleven operators capable of this mode of addressing can alternatively be used with extended or indexed addressing.) Inherent Addressing In many cases the mnemonic operator itself specifies one or more registers which contain operands or in which results are saved. For example, the operator ABA requires two operands which are located in accumulator A and accumulator B of the microprocessor. The operator also determines that the result of execution will be saved in accumulator A. For some executable instructions, all of the information which may be required for the addressing is contained in the mnemonic operator, and no operand field is used in the source statement. There are 25 such instructions. These are indicated by the column headed "inherent" in Figure 3-2. Assembly of this type of source instruction results in only one byte of machine language code. (Some other operators which contain addressing information inherently in the mnemonic code also require further addressing or operand information which is then placed in an operand field. Examples are the operators CPX, LDS, LDX, STS, and STX.) #### Immediate Addressing The operators with which the immediate mode of addressing is permissible are indicated by the column headed "immediate" in Figure 3-2. This mode of addressing is selected by beginning the specification of the corresponding operand (in the operand field of a source statement) with the pound character "#". With the immediate mode of addressing, the operand field of the source statement either contains the actual value of the operand, or it includes a symbol or an expression which has an algebraic value equal to the value of the operand. The operand may be specified in accordance with any of the following formats: - # Number # Symbol # Expression In the first three of these alternate forms the assembler will find or compute a numerical value of the operand. For any executive instruction in the immediate mode of addressing except CPX, LDS, or LDX, the numeric value must be an integer from 0 to 255 (decimal). For the operators CPX, LDS, or LDX, any value from 0 to 65535 (decimal) is valid. In the last of the alternative forms, #'C, the apostrophe instructs the Assembler to translate the next character into the corresponding 7bit ASCII code. The ASCII code so obtained is then the value of the operand. The single character "C" can be any character of the ASCII character set with hexadecimal value from 20 (SP) through 5F (\_\_\_\_). For the immediate mode of addressing, the assembler inserts the actual value of the operand into the machine code. Except for the three operators CPX, LDS, and LDX an instruction in the immediate mode is assembled into two bytes of machine code, and the value of the operand is entered in the second byte. When it is a number, the operand is entered in the memory in unsigned 8-bit binary code. When it is an ASCII character, the corresponding 7-bit ASCII code applies, using bits 0-6, and bit 7 is set to zero. For the three operators CPX, LDS, or LDX, used in the immediate mode, the source statement is assembled into three bytes of machine code. The numerical operand, which can have any value from 0 through FFFF, will be entered in the second and third bytes. The second byte will contain the most significant part of the operand, the third byte will contain the least significant part of the operand. Both parts are entered into the respective bytes of the memory in unsigned 8-bit binary code. The operators CPX, LDS, or LDX, in the immediate mode, are not normally used with an operand in the format "#'C". However, in such a case, the assembler would place the ASCII coded character "C" in the third byte of the machine code corresponding to the source instruction. When the immediate mode of addressing is used, the numerical address is in effect that of the second byte of machine code which results from assembly of the source instruction. Data flow for the immediate addressing mode is shown in Figure 3-6. Figure 3-6 Immediate Addressing Mode Data Flow Relative Addressing For the relative addressing mode to be valid, there is a rule which limits the distance in the machine language program from the branch instruction to the destination of the branch. The rule which applies to the relative addressing mode is that the address of the destination of the branch must be within the range specified by: (PC + 2) - 128 < D < (PC + 2) + 127 where: PC = address of the first byte of the branch instruction D = address of the destination of the branch instruction. When it is desired to transfer control beyond the range of the branch instructions, this can be done by using JMP (unconditional jump) or JSR (jump to subroutine). These instructions do not use the relative mode of addressing. The assembler translates a branch instruction into two bytes of the machine code. The second byte contains a relative address. This is stored as a number in 8-bit, two's complement, binary form, with decimal value in the range from -128 to +127. These numbers correspond to the limits of the range of a branch instruction, as described above. The relationship between the relative address and the absolute address of the destination of a branch instruction is expressed by: D = (PC + 2) + R where: PC = address of first byte of the branch instruction D = address of the destination of the branch instruction R = the 8-bit, two's complement, binary number, stored in the second byte of the branch instruction. The relative addressing mode is available only to the conditional branch instructions, the unconditional branch instruction BRA, and the branch to subroutine BSR. None of these source instructions can use any other mode of addressing. The three-character mnemonic instruction is, therefore, sufficient to determine for the assembler when the relative mode of addressing will be used. An example of the data flow for the relative addressing mode is shown in Figure 3-7. Indexed Addressing A column of Figure 3-2 indicates the instructions for which indexed addressing is valid. With this mode of addressing, the numerical address is variable and dependent on the contents of the index register. The current address is obtained whenever it is required during the execution of a program, rather than being pre-determined by the assembler as it is for the other addressing modes. The operand field of the source statement contains a numerical value which, when added to the contents of the index register during execution of the program, will provide the numerical address. Alternatively the operand field may contain a symbol or an expression which the assembler is able to replace by the value which is to be added to the contents of the index register. An example of the indexed addressing mode is shown in Figure 3-8. For indexed addressing the data for obtaining the numerical address may be written in any of the formats: X ,X Number,X Symbol,X Expression,X Figure 3-7 Relative Addressing Mode Data Flow Figure 3-8 Indexed Addressing Mode The single character "X" informs the assembler that the indexed mode is to be used, the character "X" being reserved to denote the index register. The format "X", when used alone, instructs the assembler that the address of the operand is identical with the contents of the index register. (This format has the same effect on the assembly as if "0,X" had been written.) If a symbol or an expression is used rather than a number, the assembler will find or compute a numerical value of that symbol or expression. The source program must then include other statements which define a numerical value for the symbol or which enable the assembler to compute a numerical value for the symbol or expression. Only values from zero to FF (hexadecimal) are valid. This value is added to the contents of the index register during execution to obtain the numerical address as shown in the following formula: D = numerical value + X where X = contents of index register D = numerical address For indexed addressing the source instruction is translated into two bytes of the machine code. The second byte contains the number, in unsigned 8-bit binary form, which is added during execution of the instruction to the contents of the index register. The number thus obtained is the numerical address (in accordance with the foregoing formula). Direct and Extended Addressing For direct addressing the source instruction is translated into two bytes of machine code. The second byte will contain the address in unsigned 8-bit binary form. For extended addressing the source instruction is translated into three bytes of machine language. The second of these bytes will contain the highest 8 bits of the address. The third byte will contain the lowest 8 bits of the address. The contents of the second and third bytes will both be coded in unsigned 8-bit binary form. For both direct and extended addressing, the address, which is placed by the assembler into the second or the second and third bytes of the machine code, is the absolute numerical address. As may be seen in Figure 3-2, there are several instructions for which the extended mode of addressing is valid but the direct mode is not. For these instructions, when using any of the following formats, Number Symbol Expression the assembler will select the extended mode of addressing whatever may be the value of the numerical address. The source statement will be translated into three bytes of the machine code. For those instructions which may use the direct mode of addressing as well as the extended mode, the assembler selects the mode according to the following rule: The assembler will select direct addressing if the numerical address is in the range from zero to 255 (decimal) and will select extended addressing if the numerical address exceeds 255 (decimal). Examples of the direct and extended addressing modes are shown in Figures 3-9 and 3-10. Figure 3-9 Direct Addressing Mode Data Flow Figure 3-10 Extended Addressing Mode Data Flow # ASSEMBLER DIRECTIVES The assembler directives allow the programmer control of the assembly of the executive instructions into machine code, including control of the allocation of memory, and assignment of values to data, when applicable. The assembler directives also provide for control of the sequencing of source programs through the assembler, and for control of the format of the assembler output. A functional classification of the assembler directives is given below: ł ţ | CODE | SUMMARY DEFINITION | FUNCTION | |---------------------------|----------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------| | ORG | Assign origin of program counter | Defines the numerical address of the first byte of a subsequent segment of the coded program. | | EQU | Equate a symbol to an operand | Equates a symbol to a numerical value, another symbol, or an expression. | | FCB<br>FCC<br>FDB<br>RMB | Form constant byte<br>Form constant characters<br>Form double constant byte<br>Reserve memory bytes | Assign values and addresses of data, and assign addresses of scratch areas of memory. | | END<br>Mon | Define end of source program<br>Return to console | Control the sequencing of source programs through the assembler. | | NAM<br>OPT<br>Page<br>SPC | Name the program or insert text<br>Assembler control options<br>Move paper to top of form<br>Vertical spacing of program listing | Format control<br>(Source program and/or<br>assembler listing) | # Assembler Directives - Operand Formating Detailed definitions are shown in Appendix B. The formats of the assembler directives operand field are summarized below: | FCB (2) EQU (1)<br>FDB (2) ORG (1)<br>RMB (1) SPC (1) | FCC<br>NAM<br>OPT | END<br>MON<br>PAGE | |-------------------------------------------------------|---------------------------------------------------------------------|---------------------------------------------------------------------------------| | Number | Special Format-<br>ting Rules | No<br>Operand | | Symbol<br>Expression | (see details of<br>the assembler dir-<br>ectives in Appendix<br>B.) | (Operand field is left blank or will be treated by the assembler as a comment.) | Notes: (1) Only one operand. (2) May have more than one operand, separated by commas. Labels Used with Assembler Directives A label must be included in any source statement which includes the assembler directive "EQU". The label must be identical with a symbol used elsewhere in the source program. The "EQU" directive is used to define the symbol, directly or indirectly. The significance of the label, in this case depends on that of the symbol with which it is identical. It can represent a numerical address, or data, or neither of these. In the latter case the label, and the corresponding symbol, would represent an algebraic quantity which appears in one or more expressions in the source program. A label may be included in any source statement which includes any of the assembler directives FCB, FCC, FDB, or RMB. These are the only assembler directives which are translated individually into one or more bytes of machine code. The label, if used, represents the address of the first byte of the machine code which results from the respective source statement. Any source statement which includes any assembler directive other than EQU, FCB, FCC, FDB or RMB, must not be written with a label. Comments Used with Assembler Directives The assembler directive "NAM" does not distinguish between the operand field and a comment. Both are treated by the assembler as continuous text. A comment may be used with any other assembler directive at the option of the programmer; however, comments with the SPC or PAGE assembler directives will not be printed (these two directives do not print). #### IV INSTRUCTION SET The M6800 instructions are each described in detail in Appendix A. This section will provide a brief introduction to the instructions and discuss their use in writing 680b programs. The instruction set is shown in summary form in Figure 4-1. Each of the 72 executable instructions of the source language assembles into from 1 to 3 bytes of machine code. The number of bytes depends on the particular instruction and on the addressing mode. The addressing modes which are available for use with the various executive instructions are indicated in Figure 3-2. The coding of the first (or only) byte, corresponding to an executable instruction, is sufficient to identify the instruction and the addressing mode. The hexadecimal equivalents of the binary codes, which result from the translation of the 72 instructions, in all valid modes of addressing, are shown in Figure 4-2. There are 197 valid machine codes, 59 of the 256 possible codes being unassigned. The octal and decimal equivalents of the machine language codes are shown similarly, in Figures 4-3 and 4-4. Microprocessor instructions are often divided into three general classifications: (1) memory reference, so called because they operate on specific memory locations; (2) operating instructions that function without needing a memory reference; (3) I/O instructions for transferring data between the microprocessor and peripheral devices. In many instances, the 6800 performs the same operation on both its internal accumulators and the external memory locations. In addition, the M6800 treats peripheral devices exactly like memory locations, hence, no I/O instructions as such are required. Because of these features, other classifications are more suitable for introducing the 6800 instruction set: (1) Accumulator and memory operations; (2) Program control operations; (3) Condition Code Register operations. #### CONDITION CODE REGISTER OPERATIONS The Condition Code Register (CCR), also called the Program Status Byte, will be described first since it is affected by many of the other instructions as well as the specific operations shown in Figure 4-6. The CCR is a 6-bit register within the MPU that is useful in controlling program flow during system operation. The bits are defined in Figure 4-5. The instructions shown in Figure 4-6 are available to the user for direct manipulation of the CCR. In addition, the MPU automatically sets or clears the appropriate status bits as many of the other instructions are executed. The effect of those instructions on the condition code register will be indicated as they are introduced and is also included in the Instruction Set Summary of Figure 4-1. | | | | | | | DORESSIRE MODES | | | | | | | | | 3 BOOLEAN/ARITHMETIC OPERATION | _ c | ONI | ). C1 | 900 | AE | ı. | | | |------------------------------|--------------|----------|--------------|-----|-----------|-----------------|-----|----------------------------------------|-----|-----|----------|----|-----|----------|--------------------------------|------------|--------------------------------------------|-------|-----|---------|----------------------------------------------|------------|----------| | ACCUMULATOR AN | O MEMORY | L | IMMED DIRECT | | | INDEX EXTIND | | | | | | | INH | ER | (All register labels | 1 | 4 | 3 | 2 | 1 | n | | | | OPERATIONS | MNEMONIC | 07 | ~ | # | OP | - | # | OP | ~ | # | GP | [~ | # | QP | 7 | # | refer to contents) | Ж | ١ | * | Z | v | c | | Add | ADDA | 8B | 2 | 2 | 98 | 3 | 2 | AB | 5 | 2 | 88 | 1 | 3 | Г | Г | Г | A+W-A | 1 | | : | 1 | ī | П | | | ADDB | CB | 2 | 2 | De | 3 | 2 | E6 | 5 | 2 | FB | 4 | 3 | 1 | l | | B+M→B | 1 2 | ٠ | ŧ | 1 | 1 | | | Add Acmbrs<br>Add with Carry | ABA<br>ADCA | 89 | , | ١, | 99 | ١, | 2 | AS | ١. | ١. | 89 | ١. | ١. | 18 | 2 | l t | A+B-A | 1 | ١• | 1 | 1 | | Ш | | Solo mile Catry | ADCB | CS | 1 2 | 2 | 09 | 3 | 2 | E9 | 5 | 2 | F9 | : | 3 | 1 | l | | A+M+C→A<br>B+M+C→B | ; | : | 1 | : | ; | ! | | And | ANDA | <b>M</b> | , | 2 | 94 | 3 | ; | A4 | 5 | 2 | 64 | 13 | 3 | I | | 1 | 0 + M + L - U | 1: | : | ; | 1 | i | : | | | ANDB | C4 | 2 | 2 | 04 | 3 | 2 | E4 | 5 | 2 | F4 | | ] 3 | 1 | | 1 | B • ₩ → B | | | i | ľ | , | | | Bit lest | BITA | 85 | 2 | 2 | 95 | 1 | 2 | A5 | 5 | 2 | 85 | 4 | 3 | 1 | | ļ | A- M | • | ٠ | ŧ | : | A | • | | | BITB | €5 | 2 | 2 | 05 | 1 | 2 | ES | 5 | 2 | F5 | 4 | 3 | 1 | | | B+M | • | • | t | 1 | R | • | | Clear | CLA<br>CLAA | | İ | ĺ | 1 | | - | 6F | , | 2 | 78 | 6 | 3 | l | ١. | | 00 → M | • | • | A | 5 | ۰ | N | | | CLRB | | | | 1 | | | | | ŀ | l | | l | 4F<br>5F | 2 2 | 1 | 06 ⊶A<br>0e →6 | • | • | R | s | 7 | 15 | | Compare | CMPA | 81 | 2 | 2 | 91 | 3 | 2 | A1 | 5 | z | 81 | 4 | ١, | 1 " | ١' | ' | A-M | : | : | R<br>\$ | \$ | " | I, | | 1 | CMPB | CI | 2 | 2 | 01 | 3 | 2 | E1 | 5 | 2 | F1 | 14 | ] 3 | l l | | | B - M | 1. | | : | ŀ | ١. | 1:1 | | Compare Acmitrs | CBA | | | l | l | ı | | i | l | | | | 1 | 11 | 2 | 1 | A - B | | | 1 | 1 | : | | | Complement, 1's | COM | | | l | l | l | | 63 | 7 | 2 | 73 | • | 3 | l | | | Ñ→₩ | • | • | : | ŧ | R | 8 | | | COMA | | 1 | l | l | l | | | 1 | | | | | 43 | 2 | ן ז | Ã→A | • | ٠ | ţ | ı | A | s | | Complement, 2's | COMB<br>NEG | | | | Į | l | | | l. | | ١ | ١. | ۱. | 53 | 2 | 1 | ē→B | • | • | 1 | ‡ | 8 | S | | (Negate ) | NEGA | } | 1 | | i | l | l | 60 | , | 2 | 70 | 6 | 3 | 40 | , | ۱. ا | 00 M M<br>00 A A | • | • | t | 1 | | <b>@</b> | | 1 | NEGB | ĺ | ļ | | l | 1 | | | | • | | 1 | | 50 | 2 | | M - B → B | : | : | : | \$<br>\$ | 00 | 0 | | Decimal Adiose A | DAA | İ | l | 1 | l | | | | | | | ļ | | 1 1 | | | Converts Benary Add. of BCD Characters | • | 1 | | | - 1 | _, | | Decimal Adjust, A | | | | | l | l | | | | | | 1 | 1 | 19 | ş | ' | into BCD Format | • | • | 1 | ı | 1 | <b>@</b> | | Gecrement | DEC | | | İ | l | | | 6A | 7 | 2 | 7A | 6 | 3 | ١ ا | | | M = 1 → M | • | ٠ | ‡ | * | 0 | • | | | DECA<br>DECB | | | | Į. | | | | ĺ | | | | ļ | 4A<br>5A | 2 2 | 1 | A – 1 → A<br>B – 1 → R | : | : | 1 | 1 | Õ | | | Exclusive OR | EORA | AS | 2 | ١, | 98 | ] 3 | 2 | BA | s | , | l Ba | ۱ | 3 | ) ^ | ' ا | ' | A + M → A | | • | ‡<br>‡ | 1 | <b>④</b> ℝ | | | 1 | FORB | C8 | 2 | 2 | 0.0 | ů | 2 | €B | 5 | 2 | FE | 4 | 3 | | | | B S M → B | | | : | ; | R | | | increment | INC | | | ļ | | | | 6C | 7 | 2 | 7C | 6 | 3 | | | | M + 1 → M | | • | : | ì, | 0 | • | | | INCA | | | | | | | | | ĺ | | | | 4C | 2 | ш | A+1→A | • | ٠ | : | : | <b>©</b> | • | | ļ | INCS | | | ĺ | l | | | | | | | ļ | | SC | 2 | 미 | 6 +1 B | • | • | 3 | : | ⊚ | • | | Lord Acmitr | LOAA | 86 | 2 | 2 | 96 | ] ] | 2 | A6 | 5 | 2 | 86 | 4 | 3 | | | | M → A<br>M → R | • | • | ; | : | A | | | Or, Inclusive | LDAB<br>Oraa | 8A | 2 | 2 2 | 06<br>9A | 3 | 2 2 | E6 | 5 | 2 | F6<br>BA | 1 | 3 | 1 | | | A+M-A | | | 1 | ; | R | | | Dr. McGare | ORAB | ÇA | ż | į | DA | 3 | 2 | EA | 5 | 7 | FA | 1 | 3 | | | | 8 + 4 → 8 | | | :1 | : | R | | | Push Data | PSHA | | - | - | | | - | | ľ | Ι. | | | ľ | ) at | 4 | $ \cdot $ | A - MSP. SP-1 -SP | | • | | | - | | | l | PSHB | | | | Ì | | | Ì | ١, | | | | | 37 | 4 | , | B → MSP, SP-1 → SP | • | • | • | • | • | ٠ | | Pull Data | PULA | | | | 1 | | | | | | | | | 32 | 4 | 1 | SP+1→SP, MSP →A | • | ٠ | • | ٠ | ٠ | ٠ | | | PULB | | | | Į | | | l | | | | | | 33 | 11 | 11 | SP + 1 → SP, MSP → B | • | • | • | • | • | • | | Rotate Left | ROL | | | | | | | B9 | , | 2 | 79 | 6 | 3 | ا ۱۰۰ | ٦ | ١,١ | MI [ 3 - 3 - 3 - 3 - 3 - 3 - 3 - 3 - 3 - 3 | | | : | 3 | ၜၟ႞ | : | | | ROLE | | | | | | | | | | | | | 49<br>59 | 2 2 | | * \_6 - \text{inning}_ | : | : | 1 | 1 | 9 | 1 | | Artete Right | AGR | | | | | | | 66 | 3 | 2 | 76 | 6 | 3 | "" | ١. | i i | Mi | • | | | 1 | ŏ | ; | | | RORA | | | | | | ١. | | | | | | | 46 | 2 | ۱, ا | v | • | | : | 1 | ŏ | ŧ | | | AGRB | | | | | | | | | | | | | 56 | 2 | ۱, ۱ | 18 g γ, → 20 | • | • | : [ | : | ۱ | : | | Shift Lelt, Arithmetic | ASL | | | | | | | 68 | , | 2 | 78 | 6 | 3 | ı | ļ | | # - | • | • | 1 | 1 | <b>•</b> | ‡ | | | ASLA | | | | | | | | | | | | | 48 | 2 | ! | v} | • | ٠ | : | : | စ္ကု | 1 | | Chile Bushe Australia | ASL8<br>ASR | | ļļ | | | | | 67 | , | 2 | 77 | 6 | 3 | 58 | 2 | 1 | e) | : | | ; | : | <b>⊚</b> | 1 | | Shift Right, Arethmetic | ASRA | | | | | | | Đ/ | | 1 | " | • | , | 47 | 2 | , | <u>v</u> \ | | | : | i | ္မ | | | 1 | ASRB | | | | | | | | | | | | | 57 | 2 | | 8 by by c | | • | ; | • | ŏl | | | Shift Right, Logic. | LSA | - 1 | | | | | | 64 | 7 | 2 | 74 | 8 | 3 | | İ | Ì | M) | • | • | # | | ŏl | | | 1 | LSRA | | | | li | | | | | | | | | 44 | 2 | 1 ا | v 0-mini - 0 | ٠ | ٠ | 4 | : | Θl | : | | | 1598 | 1 | | | | | | | | | | | l i | 54 | 2 | 1 | 8) | • | • | R | 1 | ◙ | 1 | | Store Acmitu. | STAA | | | | 97 | 11 | 2 | A7 | 6 | 2 | B7 | 5 | 3 | | - | Į | A → M | • | ٠ | : | 1 | A | • | | l | STAB | 60 | , [ | , 1 | (3)<br>90 | 4 | 2 | E7<br>AO | 6 | 2 | F7<br>B0 | 5 | 3 | Ιİ | - | | B → M<br>4 - M → 4 | • | : | : | : | | : | | Subcrect | SUBA<br>SUBB | CO | 2 | 2 | 00 | 3 | 2 | ED ED | 5 | 2 | FQ | 4 | 3 | | - [ | ŀ | A-M→A<br>B-M→S | | | : | | | ‡<br>‡ | | Subrect Admitts | SBA | -0 | ' | 1 | " | | • | " | | ١ | | 1 | | 10 | 2 | , | A - B → A | | | : | • | il | | | Subtr. with Carry | SBCA | 82 | , | 2 | 92 | 3 | 2 | A2 | 5 | 2 | 82 | 4 | 3 | " | 1 | İ | A-M-C→A | | · | ; | | il | | | j | SBCB | C2 | 2 | 2 | D2 | 3 | 2 | EŞ | 5 | 2 | F2 | 4 | 3 | - | - 1 | - 1 | B - M - C → 6 | • | ٠ | 1 | i | i | i | | Transfer Acmitrs | TAB | - 1 | | | | | | | | - [ | į | | | 16 | 2 | 1 | A-8 | • | ٠ | 1 | + | A | • | | | TBA | - 1 | ľ | 1 | | ŀ | | | | I | i | | | 17 | 2 | 3 | B→A | ٠ | ٠ | 1 | : | 8 | ٠ | | Test, Zero or Minus | TST | ŀ | | ı | ۱ ا | | | 60 | ' | 2 | 70 | 6 | 3 | _ | | . 1 | M ~ 00 | • | | | :1 | | Ð | | | TSTA<br>TSTB | J | | | | - | | | - 1 | - 1 | | | | 4D<br>50 | 2 | | A - 00<br>B - 00 | | | 1 | | A | R | | <u> </u> | 1218 | | | | | | | ــــــــــــــــــــــــــــــــــــــ | | | | | | 30 | 2 | <u>' </u> | p — vv | • | ٠, | ٠ | <u>* </u> | <u>"</u> | | 1 Figure 4-1 M6800 Instruction Set | INDEX REGISTER AND | STACK | Γ_ | IMMI | E D | | OIAE | CT | I | INDS | X | | EXT | ND | | (BH) | E A | ] | 5 | 4 | 3 | 2 | Ŀ | 0 | |------------------------|----------|-----|------|-----|-----|------|----|----|------|-----|----|-----|-----|--------|------|-----|------------------------------------------------|----|----|----|---|---|---| | POINTER OPERATIONS | MNEMONIC | 0P | ~ | # | OP. | - | £ | OP | ~ | # | Or | T- | # | QP | ~ | # | BOOLEAN/ARITHMETIC OPERATION | Н | 1 | N | z | ٧ | c | | Compere Index Reg | CPX | \$C | 7 | 3 | 9C | 4 | 1 | AC | 6 | 7 | 8C | 5 | 3 | $\Box$ | Γ | | (X <sub>H</sub> /X <sub>L</sub> ) = (M/M + 1) | | • | 0 | 1 | 0 | • | | Decrement Index Reg | DEX | li | i | | | | l | 1 | | 1 | l | l | l | 09 | 4 | 1 | X = 1 - X | • | ٠. | l٠ | t | ٠ | • | | Decrement Stack Prite | DES | li | l | 1 | | | l | 1 | | ] | l | l | l | 34 | 4 | 1 | SP - I → SP | ١. | ١. | ١. | ٠ | ٠ | • | | Increment Index Reg | iNX | l | ı | | | | | 1 | | 1 | ĺ | l | l | 08 | 4 | 1 | X + 1 - X | ٠. | ٠ | ١. | 1 | • | • | | Increment Stack Phili | INS | ; | 1 | | | | ı | 1 | | 1 | l | l | l | 31 | 4 | 1 | SP + 1 → SP | l٠ | ŀ٠ | l٠ | | ٠ | • | | Load Index Reg | LOX | CE | 3 | 3 | DΕ | 4 | 2 | EE | 6 | 2 | FE | 5 | 3 | Į | | | M → X <sub>H</sub> , (M + 1) → X <sub>L</sub> | • | ١. | 0 | 1 | R | • | | Load Stack Poli | LOS | a£ | 1 | 3 | 9£ | 4 | 2 | AE | 6 | 1 2 | 88 | 5 | 3 | | | | M → SPH, (M + 1) → SP1 | | ŀ | စြ | : | R | ٠ | | Store Index Reg | STX. | l | 1 | | QF | 5 | 2 | EF | 7 | z | FF | 6 | 3 | | | | X <sub>H</sub> M, X <sub>L</sub> (M + 1) | • | ٠. | Ю | 1 | R | • | | Store Stack Pour | 515 | l | 1 | | 9F | 5 | 2 | AF | , | 2 | ar | 6 | ] 3 | | İ | | SP <sub>M</sub> → M, SP <sub>L</sub> → (M + 1) | • | ۱. | l@ | ŧ | Ĥ | ٠ | | Inda Reg - Stack Patr | TX\$ | | 1 | | | | | 1 | | 1 | l | l | l | 35 | 4 | 1 | X = 1 → SP | ١. | ŀ | ١. | ٠ | ۰ | ٠ | | Stack Potr - Indix Reg | TSX | | | l | l | ŀ | | | ĺ | | ĺ | ĺ | l | 30 | 4 | 1 | SP + 1 - X | • | ٠ | • | ٠ | Ŀ | ٠ | | JUMP AND GRANCH | | | ELA' | TIVE | | INO | X | Г | EXT | 40 | | INHE | R | | 5 | 4 | 1 | 2 | 1 | 0 | 1 | |--------------------------|----------|----|------|------|----|-----|-----|----|-----|----|------------|------|---|---------------------------|---|----|--------------|----|----|-------|----| | <b>OPERATIONS</b> | MMEMONIC | 09 | ~ | # | OP | ~ | # | OP | ~ | zŧ | QP | ~ | # | BRANCH VEST | H | Ŀ | A | Z | ٧ | C | ] | | Branch Always | BRA | 20 | 4 | 2 | Г | | | | | Γ | | | | Hone | | • | • | • | ٠ | • | Ш | | Branch If Carry Ciner | 800 | 24 | 4 | 2 | | | l | l | ł | l | | | | C=0 | • | ۱. | [• | • | ١• | | Ш | | Branch It Carry Set | 805 | 25 | 4 | 2 | | 1 | l | ļ | 1 | ŀ | | | | C = 1 | ٠ | • | • | • | ۰ | • | Ш | | Branch If = Zero | 8EQ | 27 | 4 | 2 | | | l | l | 1 | Į | | | | Z = 1 | • | • | • | ۰ | ١. | • | Ш | | Branch If > Zero | BGE | 2C | 4 | 2 | | | ı | | l | l | | | | N → V = 0 | | • | ۱• | • | • | • | IJ | | Branch if > Zero | 8GT | 2£ | ٠ | 2 | | | ! | | l | l | | ļ | | Z + (N + V) = 0 | • | ٠. | ٠ | • | ١٠ | • | Ш | | Branch If Higher | BHI | 22 | 4 | 2 | 1 | | 1 | l | l | j | l | ł | Ì | c+z=0 | • | • | ۱۰ | • | • | • | П | | Branch If & Zero | BLE | 2F | 4 | 2 | 1 | | l | l | l | 1 | [ | 1 | Ì | Z + (N + V) = 1 | • | ١• | ļ٠ | | • | • | 1 | | Branch if Lower Dr Same | BLS | 23 | | 2 | • | | l | l | l | | | 1 | 1 | C + Z = 1 | | ۰. | I٠ | Ì٠ | ۰ | • | 11 | | Branch If < Zero | BLT | 20 | 4 | 2 | | | l | l | l | | | | 1 | N⊕V = I | ٠ | l٠ | I٠ | ۰ | • | • | Ш | | Branch If Minus | B#II | 28 | 4 | 2 | | | Į. | l | | | | | ľ | N = 1 | • | ۰ | ļ٠ | • | • | • | | | Branch If Not Equal Zero | BNE | 26 | 4 | 2 | | | l | l | ŀ | | | | | Z * 0 . | • | ļ٠ | ١٠ | ١. | • | • | Ш | | Branch H Overflow Clear | BVC | 28 | 4 | 2 | | | | l | } | l | | | | V = 0 | • | • | • | ١. | • | • | Ш | | Branch If Overflow Set | 878 | 29 | 4 | 2 | | ì | | l | } | l | 1 | | | V = 1 | | • | • | • | | • | Ш | | Branch II Plus | BPL | 2A | 4 | 2 | | | l | ł | | | | | | M = 0 | ٠ | • | • | • | | • | ı | | Branch To Subroutine | BSR | ao | 8 | 2 | | Ì | ı | 1 | [ | ı | 1 | | | l 1 | • | • | • | • | | • | Ш | | Jump | JMP | 1 | 1 | 1 | 5E | 4 | 1 2 | 7E | 3 | 3 | 1 | | | See Special Operations | | • | ١. | • | | ٠ | Ш | | Jump To Subrovime | JSR | 1 | 1 | | AD | l a | 2 | 80 | 9 | 3 | l l | | | ] ] | • | • | ļ٠ | • | | ١. | П | | No Operation | NOP | 1 | 1 | | ľ | ļ | ! | ı | Į | ı | 01 | 2 | 1 | Advances Prog. Cotr. Only | • | ۱. | ŧ٠ | • | ٠ | ŀ | Ш | | Agturn From Interrupt | RÍI | | | | ŀ | i | 1 | ı | l | ı | 38 | 10 | 1 | 1, | - | | - ( | ⊚. | _ | _ | Ш | | Return From Subroutine | RTS | | | l | l | 1 | 1 | 1 | l | ı | 39 | 5 | 1 | 11 | • | ١• | ۱٠ | ۰ | ۱۰ | 1. | П | | Software interrupt | 2Mi | | | l | Ì | l | l | 1 | l | | 3 <b>F</b> | 12 | 1 | See special Operations | | s | • | • | ٠ | • | ı | | Wait for Interrupt | WAI | I | | ı | ļ | I | l | 1 | I | ! | 3E | 9 | 1 | l' | | 10 | ) <b>i</b> • | | ۰ | · [ • | Ш | | CONDITIONS CODE R | EGISTER | $\Box$ | INHER | | BOOLEAN | 5 | 4 | 3 | 2 | 1 | 0 | c | |----------------------|----------|--------|-------|----|-----------|---|---|----|----|----|----|---| | DPERATIONS | MNEMONIC | OP. | ` | = | OPERATION | н | 1 | 15 | Z | ٧ | C | | | Diese Carry | CFC | ОC | 2 | 1 | 0 → 0 | • | • | • | • | ٠ | A | Ì | | Clear Interrupt Mask | CL∔ | 90 | 2 | 1 | 0 -1 | ٠ | A | ٠ | ٠ | ٠ | • | ı | | Cizar Gverflow | CLV | QA. | 2 | ١, | 0-v | ٠ | • | • | ٠ | R | | ı | | Set Carry | SEC | 00 | 2 | ١, | 1 - C | ٠ | • | • | ٠ | • | s | ı | | Set Interrupt Mask | SEI | 0F | 2 | , | 1 → I | • | s | ۰ | • | • | • | L | | Set Overflow | SEV | 08 | 2 | 1 | 1 → V | • | ٠ | ٠ | ٠. | \$ | • | ١ | | Acmitr A → CCR | TAP | 96 | 2 | 1 | A - CCA | - | | ( | 少∙ | _ | _ | 1 | | CCR → Acmile A | TPA | 07 | 2 | 1 | CCR →A | • | • | | • | ١. | ٠. | ı | LEGEND: OP Operation Code (Hexadecimal), Number of MPU Cycles; Number of Program Bytes, Arithmetic Plus; Arithmetic Minus; Bookean ANII; Concents of memory location pointed to be Stack Pointer; Boolean Inclusive OR; Besiees Exclusive OR; Complement of M; Transfer Into, Bit \* Zero: Byle = Zera, Half-carry from bit 3; interrupt mask Negative (sign bit) Zero (bytu) Carry from bit 3 Reset Always Set Always Test and set if Irus, cleared otherwise Not Affected CCR Condition Code Register Least Significant Most Significant CONDITION CODE REGISTER NOTES: (Bit vs) Test: Result \* 100000007 | Bir V | Test: Result = 100000007 | Bist C | Test: Result = 000000007 | Bist C | Test: Result = 000000007 | Bist C | Test: Decimal-salate of most significant BCD Character greater than nine? (Not cleared in previously set.) | Bist V | Test: Operand = 100000000 price to execution? | Bist V | Test: Operand = 0.111111 price to execution? | Bist V | Test: Deprand = 0.111111 price to execution? | Bist V | Test: Set operand = 0.111111 price to execution? | Bist V | Test: Set operand = 0.111111 price to execution? | Bist V | Test: Set operand = 0.111111 price to execution? | Bist V | Test: Result test shap zero? (Bist 15 - 1) | Load Condition Code Register from Stock. Issee Special Operations) | Bist V | Set when interrupt coccus. If previously set, a Non-Maskable Interrupt is required to and the want state. | Bist V | Set according to the convents of Accompliator A. | 00 | • | | 40 | NEG | A | 80 | SUB | Α | IMM | C0 | SUB | В | IMM | |------------|------------|---------------|-----------|------|-------------|----------|-------------|------|---------|-----|-------|------|---------| | 01 | NOP | | 41 | • | | 81 | CMP | A | IMM | CI | CMP | В | IMM | | 02 | • | | 42 | • | | 82 | SBC | ٨ | IMM | C2 | SBC | B | IMM | | 03 | • | | 43 | COM | A | 83 | • | | | C3 | • | | - 1 | | 04 | • | | 44 | LSR | A | 84 | AND | Α | IMM | C4 | AND | В | IMM | | 05 | • | | 45 | | | 85 | BIT | ٨ | IMM | C5 | BIT | В | IMM | | 06 | TAP | | 46 | ROR | A | 86 | LDA | A | IMM | C6 | LDA | B | IMM | | 07 | TPA | | 47 | ASR | A | 88 | • | •• | 1,41,44 | C7 | * | | | | 08 | INX | | 48 | ASL | Ä | 88 | EOR | A | IMM | C8 | EOR | В | IMM | | 09 | DEX | - | 49 | ROL | Ä | 89 | ADC | Â | IMM | C9 | ADC | B | IMM | | 0A | CLV | | 4A | DEC | Â | 8A | ORA | | IMM | ČÁ | ORA | В | IMM | | OB | SEV | i | | DEC | ^ | | | À | | CB | | В | IMM | | | | | 4B | | . 1 | 8B | ADD | Α | IMM | | ADD | D | TIATIAT | | OC | CLC | i | 4C | INC | Ă. | 8C | CPX | | IMM | CC | | | - 1 | | OD | SEC | | 4D | TST | A | 8D | BSR | | REL | CD | | | | | 0E | CLI | | 4E | • | | 8E | LDS | | IMM | CE | LDX | | IMM | | 0F | SEI | | 4F | CLR | A | 8F | • | | | CF | • | | i | | 10 | SBA | | 50 | NEG | B | 90 | SUB | A | DIR | DO | SUB | В | DiR | | 11 | CBA | | 52 | • | | 91 | CMP | Α | DIR | Di | CMP | В | DIR | | 12 | • | | 52 | • | | 92 | SBC | A | DIR | D2 | ŞBÇ | В | DIR | | 13 | • | | 53 | COM | В | 93 | | - | | D3 | • | | - 1 | | 14 | • | | 54 | LSR | В | 94 | AND | A | DIR | D4 | AND | В | DIR | | 15 | | | 55 | * | - | 95 | BIT | A | DIR | D5 | BIT | В | DIR | | 16 | TAB | I | 56 | ROR | В | 96 | LDA | Â | DIR | D6 | LDA | B | DIR | | 17 | TBA | I | 57 | ASR | В | 97 | STA | A | DIR | D7 | STA | В | DIR | | 18 | 10/ | | 58 | ASL | В | 98 | | | | D8 | EOR | B | DIR | | 19 | D4.4 | | | | | | EOR | Ă. | DIR | D9 | ADC | В | DIR | | | DAA | | 59 | ROL | В | 99 | ADC | A | DIR | | | | | | 1A | | | 5A | DEC | В | 9A | ORA | A | DIR | DA | ORA | В | DIR | | 1B | ABA | | 5B | • | | 9B | ADD | A | DIR | DB | ADD | В | DIR | | IC | • | | 5C | INC | В | 9C | CPX | | DIR | DC | • | | - 1 | | 1D | * | | 5D | TST | B | 9D | • | | | DD | • | | | | 1E | • | | 5E | • | | 9E | LDS | | DIR | DE | LDX | | DIR | | tF. | • | | 5F | CLR | В | 9F | <b>S</b> TS | | DIR | DF | STX | | DIR | | 20 | BRA R | REL | 60 | NEG | IND | A0 | SUB | Α | IND | EO | SUB | В | IND | | 21 | • | | 61 | • | | AI | CMP | A | IND | Ei | CMP | В | IND | | 22 | BHI P | REL | 62 | | | A2 | SBC | Ā | IND | E2 | SBC | В | IND | | 23 | | EL I | 63 | COM | IND | Ã3 | * | | | E3 | • | _ | | | 24 | | ŒL | 64 | LSR | IND | A4 | AND | A | IND | E4 | AND | В | IND 1 | | 25 | | EL | 65 | F-3K | IND | A5 | BIT | Â | IND | E.5 | BIT | B | IND | | 26 | | EL | | D/D | IND | | | | | E6 | LDA | B | IND | | 27 | | REL | 66 | ROR | | A6 | LDA | A | IND | E7 | STA | В | IND | | | | | 67 | ASR | IND | A7 | STA | A | IND | E8 | | | IND | | 28 | | EL | 68 | ASL | IND | A8 | EOR | Ą | IND | | EOR | В | | | 29 | | REL | 69 | ROL | IND | A9 | ADC | A | IND | E9 | ADC | В | IND | | 2 <b>A</b> | | REL | 6A | DEC | IND | AA | ORA | A | IND | EA | ORA | В | IND | | 2B | BMI R | REL | 6B | • | | AB | ADD | A | IND | EB | ADD | В | IND | | 2C | BGE R | REL [ | 6C | INC | IND | AC | CPX | | IND | EC | • | | - 1 | | 2D | BLT R | REL | 6D | TST | IND | AD | JSR | | IND | ED | • | | - 1 | | 2E | BGT R | REL | 6E | JMP | IND | AE | LDS | | IND | EE | LDX | | IND | | 2F | | EL | 6F | CLR | IND | AF | STS | | IND | EF | STX | | IND | | 30 | TSX | | 70 | NEG | EXT | BO | SUB | A | EXT | P0 | SUB | В | EXT ! | | 31 | INS | I | 71 | • | | Bi | CMP | Ä | EXT | Fi | CMP | В | EXT | | 32 | PUL A | 、 l | 72 | | | B2 | SBC | Ã | EXT | F2 | SBC | В | EXT | | 33 | PUL E | | 73 | СОМ | EVT | B3 | * | ^ | | F3 | * | - | | | 34 | DES | • | | | | B3<br>B4 | AND | A | EXT | F4 | AND | В | EXT | | | | l | 74 | LSR | EXT | | | | | F5 | BIT | В | EXT | | 35 | TXS | | 75 | | | B5 | BIT | Ā | EXT | | | | | | 36 | PSH A | | 76 | ROR | EXT | B6 | LDA | Ā | EXT | F6 | LDA | В | EXT | | 37 | PSH E | 3 j | 77 | ASR | EXT | B7 | STA | A | EXT | F7 | STA | В | EXT | | 38 | • | l | 78 | ASL | EXT | B8 | EOR | A | EXT | F8 | ADC | В | EXT | | 39 | RTS | l | 79 | ROL | EXT | B9 | ADC | A | EXT | F9 | ADC | В | EXT | | 3A | | | 7A | DEC | EXT | BA | ORA | Α | EXT | FA | ORA | В | EXT | | 3 <b>B</b> | RTI | | 7B | • | | BB | ADD | A: | EXT | FB | ADD | В | EXT | | 3C | | ŀ | 7C | INC | EXT | BC | CPX | | EXT | FC | • | | - 1 | | 3D | | | 7D | TST | EXT | BD | JSR | | EXT | FD | * | | - 1 | | 3E | WAI | l | 7E | JMP | EXT | BE | LDS | | EXT | FE | LDX | | EXT | | 3F | swi | l | 7F | CLR | EXT | BF | STS | | EXT | PF | STX | | EXT | | | | | ·*- | | | | | | | | | | | | Notes: 1 | . Addres | sing Modes: | | A == | | | IMM | | mediate | | REL = | | | | | | | | B = | Accumulator | R | DIR | | rect | _ | IND = | Inde | red | | 2 | 2. Unassij | gned code ind | licated b | y | | | EXT | = Ex | tended | - | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Figure 4-2 Hexadecimal Values of Machine Codes | 075 * 175 TST EXT 275 ISR EXT 374 * | | | | | | | | | | | | | | | | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|---------|---------------|---------|----------|--------|----------|-----|-------|-----|----------|-------|----------|-----|---------| | 100 101 102 102 103 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 104 | | | | | NE | G A | | | SUE | 3 A | IMN | 1 300 | SUE | В | IMM | | DOB - DOB COM A DOB SIR B IMM | | | | | : | | | | | | IMN | 1 30 | | | | | 006 | | | | | CO | МΔ | | | SBC | : A | i imn | | | В | | | 005 006 TAP | | | | | | | | | ΔNt | ٠. | . ILA | | | | | | 1906 174 106 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 | | | | 105 | • | | | | | | | | | | | | 100 INX | | | | | | | | 206 | | | | | | | | | DI | | | | | | | | | * | | | | | | D-III-L | | 012 CLV | | | | | | | | | | | | | | | | | 013 SEV | | | | | | | | | | | | | | | | | O15 SEC 114 INC A 214 CPX IMM 314 **** O16 O16 CLI O16 **** CLR A 215 BSR REL 315 **** IMM 316 LDX IMM O17 SEI O17 SEI O17 O17 SEI O17 | | | | 113 | * | • | | | | | | | | | | | 115 TST A | | | | | | | | | | | | | | , , | LIVING | | 0.07 SEI | | | | | TST | Α | | | | | REL | 315 | | | | | 120 | | | | | CLD | | | | LDS | | IMM | | LDX | | IMM | | O22 | | | | | | | | | CI ID | | DID | | * | | | | 122 | | CBA | | | • | | | | | | | | | | | | 123 COM B 223 COM B 223 COM B CO | | * | | | * | | | | | | | | | | | | 125 125 125 126 126 127 127 128 128 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 129 | | : | | | | | | | | | | | • | b | Dik | | 126 | | | | | LSR | В | | | | | | | AND | В | DIR | | 1 | | TAB | | | ROB | R | | | | | | | | | | | 030 | | TBA | | | | | | | | | | | | | | | 131 131 131 132 132 133 133 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 134 | | • | | | | | | | | | | | | | | | 133 ABA | | DAA | | | | | | 231 | | | | | | | | | 134 INC B 234 CPX DIR 333 ADD B DIR 1035 TST B 235 CPX DIR 335 CPX DIR 335 CPX DIR 335 CPX DIR 336 LDX DIR 337 CIR B 236 CPX DIR 336 LDX DIR 337 CIR B 237 STS DIR 337 STX DIR CPX DIR DIR CPX DIR DIR CPX D | | ABA | | | DEC | В | | | | | | | | | | | 035 | | * | | | INC | D | | | | Α | | | ADD | В | DIR | | 036 | | | | | | | | | UPX | | DIR | | * | | | | 137 CLR B 237 STS DIR 337 STX DIR 041 * 041 * 240 SUB A IND 340 SUB B IND 041 * 241 CMP A IND 341 CMP B IND 042 SBC A IND 342 SBC B IND 043 BLS REL 142 * 242 SBC A IND 342 SBC B IND 044 BCC REL 143 COM IND 243 * 242 SBC A IND 342 SBC B IND 044 BCC REL 144 LSR IND 244 AND A IND 344 AND B IND 046 BNE REL 145 * 245 BIT A IND 345 BIT B IND 046 BNE REL 146 ROR IND 246 LDA A IND 345 BIT B IND 047 BEQ REL 147 ASR IND 247 STA A IND 347 STA B IND 049 BEQ REL 150 ASL IND 250 EOR A IND 350 EOR B IND 051 BVS REL 151 ROL IND 251 ADC A IND 350 EOR B IND 052 BVS REL 152 DEC IND 252 ORA A IND 352 ORA B IND 053 BMI REL 152 DEC IND 252 ORA A IND 353 ADD B IND 054 BGE REL 155 TST IND 255 ISR IND 355 CRA B IND 055 BLT REL 155 TST IND 255 ISR IND 355 STX IND 057 BLE REL 156 JMP IND 256 LDS IND 356 LEX IND 057 BLE REL 156 JMP IND 256 LDS IND 356 LEX IND 057 BLE REL 157 CLR IND 257 STS IND 357 STX IND 058 BCT 160 NEG EXT 260 SUB A EXT 360 SUB B EXT 060 TSX 160 NEG EXT 266 SUB A EXT 361 CMP B EXT 065 PUL A 162 REXT 267 STA A EXT 366 LDA B EXT 065 PSH B 167 ASE EXT 266 BIT A EXT 371 ADC B EXT 070 A EXT 371 ADC B EXT 070 A EXT 371 ADC B EXT 070 A EXT 371 ADC B EXT 070 ASE EXT 270 CRA A EXT 371 ADC B EXT 070 A EXT 371 ADC B EXT 070 ASE EXT 271 ADC A EXT 373 ADD B EXT 070 ADC B EXT 070 ADC B EXT 070 ADC B EXT 070 ADC B EXT 070 ADC | | * | | | * | _ | | | LDS | | DIB | | LDY | | DID | | 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 141 | | * | | | | | | | | | | | | | | | 042 BHI REL 143 | | BKA | KEL | | NEG | IND | | | | | | | | В | | | 043 BLS REL 143 COM IND 243 S. | | BHI | RFI. | | | | | | | | | | | | | | 944 BCC REL | | | | | COM | IND | | | SBC | Α | IND | | SBC | В | IND | | 045 BCS REL | | | | 144 | | | | | AND | Α | IND | | AND | D | INID. | | 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 1970 | | | | | * | | | | | | | | | | | | 050 BVC REL 150 ASI IND 250 EOR A IND 347 STA B IND 051 BVS REL 151 ROL IND 251 ADC A IND 351 ADC B IND 052 BPL REL 152 DEC IND 252 ORA A IND 351 ADC B IND 053 BMI REL 153 DEC IND 252 ORA A IND 352 ORA B IND 054 BGE REL 154 INC IND 254 CPX IND 355 EOR B IND 055 BLT REL 155 TST IND 255 SSR IND 355 EOR B IND 056 BGT REL 156 JMP IND 256 LDS IND 356 LEX IND 057 BLE REL 157 CLR IND 257 STS IND 356 LEX IND 060 TSX I60 NEG EXT 260 SUB A EXT 360 SUB B EXT 061 INS 161 * 261 CMP A EXT 361 CMP B EXT 062 PUL A 162 * 262 SBC A EXT 362 SBC B EXT 063 PUL B 163 COM EXT 263 SUB A EXT 364 AND B EXT 064 DES 164 LSR EXT 264 AND A EXT 365 BIT B EXT 065 TXS 165 * 265 BIT A EXT 365 BIT B EXT 066 PSH A 166 ROR EXT 266 LDA A EXT 365 BIT B EXT 067 PSH B 167 ASR EXT 266 LDA A EXT 367 STA B EXT 070 * 170 ASL EXT 270 EOR A EXT 371 ADC B EXT 071 RTS 171 ROL EXT 271 ADC A EXT 372 ORA B EXT 072 ** 174 INC EXT 272 ORA A EXT 373 ADD B EXT 073 RTI 173 * 273 ADD A EXT 375 EXT 074 * 174 INC EXT 274 CPX EXT 375 EXT 075 SWI 176 CLR EXT 276 LDS EXT 376 LDX EXT 076 WAI 176 IMP EXT 275 STS EXT 375 EXT 077 SWI 177 CLR EXT 275 STS EXT 375 EXT 078 LEXT STS EXT STS EXT STS EXT STS EXT STS EXT 079 SWI 177 CLR EXT 275 STS EXT 375 EXT STS EXT 070 RES 1 Addressing Modes: A Accumulator B DIRC DIRC DIREC DIREC DIREC DIREC DIREC DIREC DIREC DIRE | | | | | | | | | | | IND | | | | | | 051 BVS REL 151 ROL IND 251 ADC A IND 350 EOR B IND 1052 BPL REL 152 DEC IND 252 CRA A IND 352 ORA B IND 1053 BPL REL 153 * | | | | | | | | | | | | | | | | | 052 BPL REL 152 DEC 1ND 252 ORA A 1ND 357 ORA B IND 053 BMI REL 153 * 253 ADD A 1ND 353 ADD B IND 054 BGF REL 154 INC 1ND 2554 CPX IND 354 * * * * * * * * * * * * * * * * * * * | | | | | | | | | | | | | | | | | 053 BMI REL | | | | | | | | | | | | | | | | | 150 150 151 152 151 151 151 151 151 152 152 152 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 153 | | | | | • | | | | | | | | | | | | 056 BGT REL 156 JMP IND 256 LDS IND 353 LEX IND 057 BLE REL 157 CLR IND 257 STS IND 353 LEX IND 060 TSX 160 NEG EXT 260 SUB A EXT 360 SUB B EXT 061 INS 161 * 261 CMP A EXT 360 SUB B EXT 062 PUL A 162 * 262 SBC A EXT 360 SBC B EXT 063 PUL B 163 COM EXT 264 AND A EXT 363 * 065 TXS 165 * 265 BIT A EXT 364 AND B EXT 066 PSH A 166 ROR EXT | | | | | | | | | CPX | | | | * | | | | 957 BLE REL | | | | | | | | | | | | | | | | | 060 TSX | | | | | | | - 1 | | | | | | | | | | 061 INS | | | | | | | | | | Δ | | | | | | | 062 PUL A 162 * 262 SBC A EXT 362 SBC B EXT 063 PUL B 163 COM EXT 263 * 363 * 064 DES 164 LSR EXT 264 AND A EXT 365 BIT B EXT 065 TXS 165 * 265 BIT A EXT 365 BIT B EXT 066 PSH A 166 ROR EXT 266 LDA A EXT 365 BIT B EXT 067 PSH B 167 ASR EXT 267 STA A EXT 367 STA B EXT 070 * 170 ASL EXT 270 EOR A EXT 370 EOR B EXT 071 RTS 171 ROL EXT 271 ADC A EXT 371 ADC B EXT 072 * 172 DEC EXT 272 ORA A EXT 372 ORA B EXT 073 RTI 173 * 273 ADD A EXT 374 ADD B EXT 074 * 174 INC EXT 274 CPX EXT 373 ADD B EXT 075 * 175 TST EXT 275 ISR EXT 375 * 076 WAI 176 IMP EXT 276 LDS EXT 376 LDX EXT 077 SWI 177 CLR EXT 277 STS EXT 377 STX EXT 078 A Addressing Modes A A A A A A A 079 A A A A A A A 070 A A A A A A 071 SWI 177 CLR EXT 277 STS EXT 377 STX EXT 072 A A A A A A A 073 A A A A A A 074 A A A A A 075 A A A A 076 A A A A 077 SWI 177 CLR EXT 277 STS EXT 377 STX EXT 078 A A A A A 079 A A A A 070 A A A A 071 A A A A 072 A A A 073 A A A 074 A A A 075 A A A 076 A A A 077 SWI 177 CLR EXT 277 STS EXT 377 STX EXT 078 A A A A 079 A A A A 070 A A A A 071 A A A 072 A A A 073 A A A 074 A A A 075 A A A 076 A A A 077 A A A 078 A A A 078 A A A 079 A A A 070 A A A 071 A A A 071 A A 072 A A A 073 A A 074 A A A | | | | | * | | | | | | | | | | | | 104 DES 164 LSR EXT 264 AND A EXT 364 AND B EXT 065 TXS 165 * | | | | | * | | j. | | | | | | | | | | 965 TXS | | | В | | | | 1 | | • | | | | • | | | | 966 PSH A 166 ROR EXT 266 LDA A EXT 366 LDA B EXT 267 STA A EXT 367 STA B EXT 267 STA A EXT 367 STA B EXT 267 STA A EXT 367 STA B EXT 267 STA A EXT 367 STA B EXT 267 STA A EXT 367 STA B EXT 270 EXT 271 ADC A EXT 370 EXT 272 DEC EXT 272 ORA A EXT 372 ORA B EXT 273 RT 1 173 ** 273 ADD A EXT 373 ADD B EXT 274 CPX EXT 374 ** 174 INC EXT 274 CPX EXT 374 ** 175 TST EXT 275 ISR EXT 375 ** 175 TST EXT 275 ISR EXT 375 LX EXT 376 LDX EXT 376 LDX EXT 376 LDX EXT 377 STX ST | | | | | LSK<br>* | EXT | | | | | | | | | | | 067 PSH B 167 ASR EXT 267 STA A EXT 306 EXT B EXT 070 * 170 ASL EXT 270 EOR A EXT 370 EOR B EXT 071 RTS 171 ROL EXT 271 ADC A EXT 371 ADC B EXT 073 RTI 172 DEC EXT 272 ORA B EXT 373 ADD A EXT 373 ADD B EXT 074 * 174 INC EXT 274 CPX EXT 373 ADD B EXT 075 * 175 TST EXT 274 CPX EXT 373 ADD B EXT 075 * 175 TST EXT 275 JSR EXT 375 * * | | | A İ | | ROR | EXT | ľ | | | | | | | | | | 070 | | | | 167 | ASR | | l | | | | | | | | | | 171 172 173 174 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 175 | | * | | | ASL | EXT | ı | 270 | EOR | | | | | | | | 073 RTI | | K12 | | | | | | | | | | | ADC | В | EXT | | 074 * 174 INC EXT 274 CPX EXT 373 ADD 8 EXT 975 975 * 175 TST EXT 275 ISR EXT 375 * 076 WAI 176 JMP EXT 276 LDS EXT 376 LDX EXT 377 STX EXT 077 SWI 177 CLR EXT 277 STS EXT 377 STX EXT 078 STS EXT 378 EXT 378 EXT 078 STS EXT 378 EXT 078 EXT 078 STS EXT 078 07 | | RTI | ĺ | | DEC. | CXI | | | | | | | | | | | 075 * 175 TST EXT 275 JSR EXT 375 * 076 WAI 176 JMP EXT 276 LDS EXT 376 LDX EXT 077 SWI 177 CLR EXT 277 STS EXT 377 STX EXT 078 STS EXT 378 STX EXT 079 STS EXT 378 STX EXT 079 STS EXT 079 STS EXT 079 STX EXT 079 STS EXT 079 STX EXT 079 STS EXT 079 STX EXT 079 STS EXT 079 STX EXT 079 STS EXT 079 STX EXT 079 STS EXT 079 STX 07 | 074 | * | | | INC | EXT | 1 | | | A | | | ADD<br>* | В | EXT | | 176 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 177 | 075 | * | | 175 | TST | EXT | i | | | | | | | | | | DISS. I. Addressing Modes: A = Accumulator A IMM Immediate REL Relative B = Accumulator B DIR Direct IND Indexed | 076 | | ì | | | EXT | ļ | 276 | LDS | | | | LDX | | EXT | | B = Accumulator B DIR = Direct IND = Indexed | | | | 177 | | | | | | | | | | | | | B = Accumulator B DIR = Direct IND = Indexed | otes: I | . Addre | ssing Modes: | | | | | | | | | | | Re | | | - CAI - Extended | 2 | . Unass | igned code in | dicated | | - ACCU | nsurator | D | | | | 1 | ND = | | | | | | | | | | | | | -AI | _ | PYICHOGO | | | | | Figure 4-3 Octal Values of Machine Codes | 000 | • | 064 | NEG | Α | 128 | SUH | A | IMM | 192 | SUB | В | IMM | |------------|---------------------------------------|------------|------|-------------|-----|------------|---|-----------|-----|-------|------|------------| | 001 | NOP | 065 | • | | 129 | CMP | ٨ | IMM | 193 | CMP | В | IMM | | 002 | • | 066 | • | | 130 | SBC | Α | IMM | 194 | SBC | В | IMM | | 003 | • | (167 | COM | A | 131 | • | | | 195 | • | | | | 004 | • | 068 | LSR | A | 132 | AND | Α | IMM | 196 | AND | В | IMM | | 005 | • | 069 | • | | 133 | BIT | Α | IMM | 197 | BIT | В | IMM | | 006 | TAP | 070 | ROR | A | 134 | LDA | Α | IMM | 198 | LDA | В | IMM | | 007 | TPA | 071 | ASR | A | 135 | * | | | 199 | * | | | | 008 | INX | 072 | ASL | A | 136 | EOR | Α | IMM | 200 | EOR | В | IMM | | 009 | DEX | 073 | ROL | A | 137 | ADC | A | IMM | 301 | ADC | В | IMM | | 010 | CLV | 074 | DEC | A | 138 | ORA | Α | IMM | 202 | ORA | В | IMM | | 011 | SEV | 075 | | | 139 | ADD | A | IMM | 203 | | В | IMM | | 012 | CLC | 076 | INC | A | 140 | CPX | | IMM | 204 | | - | | | 613 | SEC | 077 | TST | A | 141 | BSR | | REL | 205 | • | | | | 014 | CLI | 078 | | | 142 | LDS | | IMM | 206 | LDX | | IMM | | 015 | SEI | 079 | CLR | A | 143 | * | | | 207 | * | | ****** | | 016 | SBA | 080 | NEG | В | 144 | SUB | Α | DIR | 208 | SUB | В | DIR | | 017 | CBA | 081 | * | - | 145 | CMP | À | DIR | 209 | CMP | В | DIR | | 018 | • | 082 | * | i | 146 | SBC | Â | DIR | 210 | SBC | В | DIR | | 019 | • | 083 | COM | В | 147 | * | - | DIK | 211 | * | U | DIA | | 020 | • | 084 | LSR | В | 148 | AND | Α | DIR | 212 | AND | В | DIR | | 021 | | 085 | * | - | 149 | BIT | Â | DIR | 213 | BIT | В | DIR | | 022 | TAB | 086 | ROR | В | 150 | LDA | Â | DIR | 214 | LDA | В | | | 023 | TBA | 087 | ASR | В | 151 | STA | | DIR | 215 | STA | В | DIR<br>DIR | | 023 | 100 | 088 | ASL | В | 152 | | A | | 216 | | | | | 024 | DAA | 089 | ROL | В | 153 | EOR | Ā | DIR : | 217 | EOR | В | DIR | | | DAA<br>• | | | | | ADC | Ą | DIR | | ADC | В | DIR | | 026 | ,<br>, D.A. | 090 | DEC | В | 154 | ORA | Ą | DIR | 218 | ORA | В | DIR | | 027<br>028 | ABA | 091<br>092 | BIC. | | 155 | ADD | Α | DIR | 219 | ADD | В | DIR | | | | | INC | В : | 156 | CPX | | DIR | 220 | | | | | 029 | : | 093 | TST | В | 157 | | | | 221 | | | | | 030 | : | 094 | | _ | 158 | LDS | | DIR | 222 | LDX | | DIR | | 180 | - | 095 | CLR | B | 159 | STS | | DIR | 223 | STX | _ | DIR | | 032 | BRA REL | 096 | NEG | IND | 160 | SUB | A | IND | 224 | SUB | В | IND | | 033 | * | 097 | • | | 161 | CMP | A | IND | 225 | CMP | В | IND | | 034 | BHI REL | 098 | • | | 162 | SBC | Α | IND | 226 | SBC | В | IND | | 035 | BLS REL | 099 | COM | | 163 | * | | | 227 | | | | | 036 | BCC REL | 100 | LSR | IND | 164 | AND | Α | IND | 228 | AND | В | IND | | 037 | BCS REL | 101 | • | | 165 | BIT | Α | IND | 229 | BIT | В | IND | | 038 | BNE REL | 102 | ROR | IND | 166 | LDA | Α | IND | 230 | LDA | В | IND | | 039 | REQ REL | 103 | ASR | IND | 167 | STA | Α | IND | 231 | STA | В | IND | | 040 | BVC REL | 104 | ASL | IND | 168 | EOR | A | IND | 232 | EOR | В | IND | | 041 | BVS REL | 105 | ROL | IND | 169 | ADC | Α | IND | 233 | ADC | В | IND | | 042 | BPL REL | 106 | DEC | IND | 170 | ORA | Α | IND | 234 | ORA | В | IND | | 043 | BMI REL | 107 | • | | 171 | ADD | A | IND | 235 | | В | IND | | 044 | BGE REL | 108 | INC | IND | 172 | CPX | | IND | 236 | 4 | | | | 045 | BLT REL | 109 | TST | IND | 173 | JSR | | IND | 237 | | | | | 046 | BGT REL | 110 | JMP | IND | 174 | LDS | | IND | 238 | LDX | | IND | | 047 | BLE REL | 111 | CLR | IND | 175 | STS | | IND | 239 | STX | | IND | | 048 | TSX | 112 | NEG | EXT | 176 | SUB | Α | EXT | 240 | SUB | В | EXT | | 049 | INS | 113 | • | | 177 | CMP | A | EXT | 241 | CMP | В | EXT | | 050 | PUL A | 114 | * | | 178 | SBC | Ā | EXT | 242 | SBC | В | EXT | | 051 | PUL B | 115 | COM | EXT | 179 | | | | 243 | * | _ | | | 052 | DES | 115 | LSR | EXT | 180 | AND | A | EXT | 244 | AND | В | EXT | | 053 | TXS | 117 | • | | 181 | BIT | A | EXT | 245 | BIT | В | EXT | | 054 | PSH A | 118 | ROR | EXT | 182 | LDA | Â | EXT | 246 | LDA | В | EXT | | 055 | PSH B | 119 | ASR | EXT | 183 | STA | Â | EXT | 247 | STA | В | EXT | | 056 | • | 120 | ASL | EXT | 184 | EOR | Â | EXT | 248 | EOR | В | EXT | | 057 | RTS | 121 | ROL | EXT | 185 | ADC | Â | EXT | 249 | ADC | B | EXT | | 058 | * | 122 | DEC | EXT | 186 | ORA | Â | EXT | 250 | ORA | B | EXT | | 059 | RTI | 123 | * | -01 | 187 | ADD | Â | EXT | 251 | ADD | B | EXT | | 060 | * | 124 | INC | EYT | 188 | CPX | ^ | | 252 | * ADD | Ð | EAI | | 061 | | 125 | TST | EXT<br>EXT | 189 | | | EXT | 253 | | | | | 062 | WAI | 126 | JMP | EXT | 190 | JSR<br>LDS | | EXT | 254 | LDX | | EVT | | | | | CLR | | 191 | | | EXT | | | | EXT | | 063 | SWI . | 127 | | EXT | | STS | | EXT | 255 | STX | _ | EXT | | Notes: | <ol> <li>Addressing Modes:</li> </ol> | | A = | Accumulator | A | IMM | = | Immediate | | REL | ≖ Re | lative | : 1. Addressing Modes: A = Accumulator A | IMM = Immediate | REL = Relative | DIR = Direct | IND = Indexed | 2. Unassigned code indicated by "\*". | Extended | EXT = Extended | Figure 4-4 Decimal Values of Machine Codes | $b_5$ | b <sub>4</sub> | b <sub>3</sub> | b <sub>2</sub> | bı | <sub>P</sub> 0 | |-------|----------------|----------------|----------------|----|----------------| | H | I | N | Z | ٧ | С | - H = Half-carry; set whenever a carry from $b_3$ to $b_4$ of the result is generated by ADD, ABA, ADC; cleared if no $b_3$ to $b_4$ carry; not affected by other instructions. - I = Interrupt Mask; set by hardware or software interrupt of SEI instruction; cleared by CLI instruction. (Normally not used in arithmetic operations.) Restored to a zero as a result of an RT1 instruction if $\mathbf{l}_m$ stored on the stack is low. - N = Negative; set if high order bit (b<sub>7</sub>) of result is set; cleared otherwise. - Z = Zero; set if result = 0; cleared otherwise. - V = oVerflow; set if there was arithmetic overflow as a result of the operation; cleared otherwise. - C = Carry; set if there was a carry from the most significant bit ( ${\bf b_7}$ ) of the result; cleared otherwise. Figure 4-5 Condition Code Register | CONDITIONS CODE A | 5 | 4 | 3 | 2 | 1 | 0 | | | |----------------------|----------|----------------------|---|-----|-------------|------------|-----|---| | OPERATIONS | MNEMONIC | BOOLEAN<br>OPERATION | Н | 1 | N | z | ν | С | | Clear Carry | £rc | 0 → C | • | • | • | • | • | R | | Clear Interrupt Mask | CLI | 0 →1 | • | R | • | • | • | • | | Clear Overflow | CLV | 0 → V | • | • | • | • | R | • | | Set Carry | SEC | 1 → C | • | • | • | • | • | S | | Set Interrupt Mask | ŞEI | 1 →1 | • | s | • | • | • | • | | Set Overflow | SEV | 1 → V | • | • | • | • | l s | • | | AcmItr A → CCR | A→CCR | | | - ( | <b>-</b> (F | | | | | CCR → Acmitr A TPA | | CCR →A | • | • | • ] | <b>`</b> • | • | • | R = Reset Figure 4-6 Condition Code Register Instructions S = Set <sup>• =</sup> Not affected <sup>(</sup>ALL) Set according to the contents of Accumulator A. #### NUMBER SYSTEMS Effective use of many of the instructions depends on the interpretation given to numerical data, that is, what number system is being used? For example, the ALU always performs standard binary addition of two eight bit numbers using the 2's complement number system to represent both positive and negative numbers. However, the MPU instruction set and hardware flags permit arithmetic operation using any of four different representations for the numbers: (1) Each byte can be interpreted as a signed 2's complement number in the range -128 to +127: b7 b6 b5 b4 b3 b2 b1 b0 1 0 0 0 0 0 0 0 (-128 in 2's complement) 1111111 (-1 in 2's complement) 0 0 0 0 0 0 0 (0 in 2's complement) 0 0 0 0 0 0 0 1 (+1 in 2's complement) 0 1 1 1 1 1 1 1 (+127 in 2's complement) (2) Each byte can be interpreted as a signed binary number in the range -127 to +127: b7 b6 b5 b4 b3 b2 b1 b0 1111111 (-127 in signed binary) (-1 in signed binary) 10000001 (0 in signed binary) 0 0 0 0 0 0 0 0 (+1 in signed binary) 00000001 0 1 1 1 1 1 1 1 (+127 in signed binary) (3) Each byte can be interpreted as an unsigned binary number in the range 0 to 255: 27 26 25 24 23 22 21 20 b7 b6 b5 b4 b3 b2 b1 b0 0 0 0 0 0 0 0 0 (0 in unsigned binary) 1111111 (255 in unsigned binary) ``` 22 21 20 22 21 20 b<sub>7</sub> b<sub>6</sub> b<sub>5</sub> b<sub>4</sub> b<sub>3</sub> b<sub>2</sub> b<sub>1</sub> b<sub>0</sub> 0 0 0 0 0 0 0 0 (BCD 0) 00100111 (BCD 27) 1 0 0 1 1 0 0 1 (BCD 99) The two's complement representation for positive numbers is obtained simply by adding a zero (sign bit) as the next higher signifi- cant bit position: 27 26 25 24 23 22 21 20 a<sub>7</sub> a<sub>6</sub> a<sub>5</sub> a<sub>4</sub> a<sub>3</sub> a<sub>2</sub> a<sub>1</sub> a<sub>0</sub> 111111 (binary 127) 0 1 1 1 1 1 1 1 (+127 in 2's complement representation) 0 0 0 0 0 0 1 (binary 1) 100000000 (+1 in 2's complement representation) When the negative of a number is required for an arithmetic opera- tion, it is formed by first complementing each bit position of the pos- itive representation and then adding one. 64 32 16 8 4 2 1 a<sub>7</sub> a<sub>6</sub> a<sub>5</sub> a<sub>4</sub> a<sub>3</sub> a<sub>2</sub> a<sub>1</sub> a<sub>0</sub> 0111111 (+127 in 2's complement representation) 10000000 (1's complement) (add one) (-127 in 2's complement representation) 0000000 (0 in 2's complement representation) 11111111 (I's complement) (add one) ("0" is same in either notation) 0 0 0 0 0 (+1 in 2's complement representation) (1's complement) 1 1 1 1 1 1 1 0 (add one) (-1 in 2's complement representation) 35 ``` (4) Each byte can be thought of as containing two 4-bit binary coded decimal (BCD) numbers. With this interpretation, each byte can represent numbers in the range 0 to 99: Note that while +127 is the largest positive two's complement number that can be formed with 8 digits, the largest negative two's complement number is 10000000 or -128. Hence, with this number system, an eight bit byte can represent integers on the real number line between -128 and +127 and $a_7$ can be regarded as a sign bit; if $a_7$ is zero the number is positive, if $a_7$ is one the number is negative: Since much of the literature on arithmetic operations presents the information in terms of signed binary numbers, the difference between 2's complement and signed binary notation is of interest. Signed binary number notation also uses the most significant digit as a sign bit (0 for positive, I for negative). The remaining bits represent the magnitude as a binary number. An 8-bit byte in this notation represents integers on the real number line between -127 and +127: Comparing this to the 2's complement representation, the positive numbers are identical and the negative numbers are reversed, i. e., -127 in 2's complement is -1 in signed binary and vice versa. In normal programming of the MPU, the difference causes no particular problem since numerical data is automatically converted to the correct format during assembly of the program source statements. However, if during system operation, incoming data is in signed binary format, the program should provide for conversion. This is easily done by first complementing each bit of the signed binary number except the sign bit and then adding one: The MPU instruction set provides for a simple conversion routine. For example, the following program steps can be used: This routine assumes that the signed binary data is stored in accumulator A (ACCA). The program tests the sign bit and, if the number is negative (N=1), performs the required conversion. The contents of ACCA and the N bit of the Condition Code Register would be as follows after each step of a typical conversion: | Instr | N | a | a | a | a | a | a | a | a | | |-----------------|---|---|---|---|---|---|---|---|---|--------------------------| | TSTA | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | (-113 is signed binary) | | BPL NEXT | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | | | NEGA | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | (2's complement of ACCA) | | ORAA #%10000000 | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | (-113 in 2's complement) | Note that the sign bit status, N, is updated as the NEG and ORA instructions are executed. This is typical for many of the instructions; the Condition Code Register is automatically updated as the instruction is executed. ### ACCUMULATOR AND MEMORY OPERATIONS For familiarization purposes, the Accumulator and Memory operations can be further subdivided into four categories: (1) Arithmetic Operations; (2) Logic Operations; (3) Data Testing; and (4) Data Handling. Arithmetic Operations The Arithmetic Instructions and their effect on the CCR are shown in Figure 4-7. The use of these instructions in performing arithmetic operations is discussed in section V of this manual. | | | BOOLEAN/ARITHMETIC OPERATION | | COND. CODE REG. | | | | | | | | |-------------------|-----------|---------------------------------------------------------|---|-----------------|----|----|-----|-----|--|--|--| | ACCUMULATOR A | NO MEMORY | (All register labels | 5 | 4 | 3 | 2 | 1 | 0 | | | | | OPERATIONS | MNEMONIC | refer to contents) | H | 1 | N | z | ١ | С | | | | | Add | ADDA | A + M → A | ı | • | t | 1 | ı. | 1 | | | | | | ADOB | B + M → B | 1 | | t | 1 | 1 | į į | | | | | Add Acmitrs | ABA | A + B → A | 1 | ۱. | t | Ì | 1 | į | | | | | Add with Carry | ADCA | A+M+C→A | 1 | | ŧ | 1 | l i | ţ | | | | | | ADCB | 8 + M + C → B | 1 | | \$ | ŧ | t | 1 | | | | | Complement, 2's | NEG | 00 - M → M | • | | ‡ | ı | o | 2 | | | | | (Negate) | NEGA | 00 - A → A | | | ŧ | 1 | lŏ | ודו | | | | | | NEGB | 00 -8 →8 | | | t | 1 | 1 = | 2 | | | | | Decimal Adjust, A | DAA | Converts Binary Add. of BCD Characters into BCD Format* | • | | ‡ | 1 | 1 - | 3 | | | | | Subtract | SUBA | $A - M \rightarrow A$ | • | | î | ı, | ı | ı | | | | | | SUBB | B M → B | | | t | Ť | 1 | ı t | | | | | Subract Acmitrs. | SBA | A - B → A | | | t | i | t | ŧ | | | | | Subtr. with Carry | SBCA | $A - M - C \rightarrow A$ | | | t | î | i | t | | | | | | SBCB | $B - M - C \rightarrow B$ | | • | t | t | Í | t i | | | | <sup>\*</sup>Used after ABA, ADC, and ADD in BCD arithmetic operation; each 8-bit byte regarded as containing two 4-bit BCD numbers. DAA adds 0110 to lower half-byte if least significant number >1001 or if preceding instruction caused a Half-carry. Adds 0110 to upper half-byte if most significant number >1001 or if preceding instruction caused a Carry. Also adds 0110 to upper half-byte if least significant number >1001 and most significant number =9 (Bit set if test is true and cleared otherwise) - (Bit V) Test: Result = 10000000? - (Bit C) Test: Result = 000000000? - (Bit C) Test: Decimal value of most significant BCD Character greater than nine? (Not cleared if previously set.) Figure 4-7 Arithmetic Instructions Logic Operations The Logic Instructions and their effect on the CCR are shown in Figure 4-8. Note that the Complement (COM) instruction applies to memory locations as well as both accumulators. | | | BOOLEAN/ARITHMETIC OPERATION | C | COND. CODE REG. | | | | | | | | |------------------------|----------|------------------------------|---|-----------------|-----|-------|--------|----|--|--|--| | ACCUMULATOR AND MEMORY | | (All register labels | 5 | 4 | 3 | 2 | 1 | 0 | | | | | OPERATIONS | MNEMONIC | refer to contents) | Н | 1 | N | z | V | c | | | | | And | ANDA | A • M → A | • | • | 1 | 1 | R | ١. | | | | | | ANDB | 8 • M → 8 | • | | 1 | 1 | R | ŀ | | | | | Complement, 1's | CO₩ | M→M | | • | ‡ | ļ ŧ | A | s | | | | | | COMA | Ā→A | • | • | ‡ | l t | R | ١s | | | | | | COMB | B → B | | • | 1 ‡ | 1 | R | s | | | | | Exclusive OR | EORA | A ⊕ M → A | | • | 1 | 1 | R | | | | | | | EORB | $B \oplus M \rightarrow B$ | | • | t | l t | R | | | | | | Or, Inclusive | ORA | A+M→A | | | ı | t | R. | | | | | | | ORB | $B+M\to B$ | | | ľ | , , , | n<br>H | | | | | Figure 4-8 Logic Instructions Data Test Operations The Data Test instructions are shown in Figure 4-9. Bit Test (BIT) is useful for updating the CCR as if the AND function were executed but does not change the contents of the accumulator. The Test (TST) instruction also operates directly on memory and updates the CCR as if a comparison (CMP) to zero had been executed. | | | 0001 FANIA DITUNETIO OREO ATION | C | DNE | DE | REG | i. | | | |------------------------|----------|---------------------------------------------------|---|-----|----------|----------|------------|----|----| | ACCUMULATOR AND MEMORY | | BOOLEAN/ARITHMETIC OPERATION (All register labels | 5 | 4 | 3 | 2 | 1 | 0 | J, | | OPERATIONS | MNEMONIC | refer to contents) | Н | 1 | N | Z | ٧ | C | 1 | | Bit Test | BITA | A • M | • | • | 1 | \$ | R | • | 1 | | | 8178 | B◆M | • | • | <b>‡</b> | <b>‡</b> | R | • | ı | | Compare | CMPA | A – M | • | • | ŧ | ‡ | <b>‡</b> . | \$ | 1 | | 1 | CMPB | B M | • | ٠ | <b>‡</b> | \$ | <b> </b> ‡ | \$ | ı | | Compare Acmitrs | CBA | A - B | • | • | \$ | \$ | ‡ | \$ | ı | | Test, Zero or Minus | TST | M 00 | • | • | \$ | 1 | R | R | ı | | | TSTA | A 00 | • | • | 1 | 1 | R | R | I | | | TSTB | B - 00 | • | • | ‡ | <b>†</b> | R | R | 1 | Figure 4-9 Data Test Instructions # Data Handling Operations The Data Handling instructions are summarized in Figure 4-10. Note that the Clear (CLR), Decrement (DEC), Increment (INC), and Shift/Rotate instructions all operate directly on memory and update the CCR accordingly. | | | BOOLEAN/ARITHMETIC OPERATION | COND. CODE REG. | | | | | | | | | |----------------------------------------|----------|---------------------------------------------|-----------------|---|----------|------|--------------|----------|--|--|--| | ACCUMULATOR AN | D MEMORY | (All register labels | 5 | 4 | 3 | 2 | 1 | 0 | | | | | OPERATIONS | MNEMONIC | refer to contents) | Н | ı | N | z | ٧ | C | | | | | Clear | CLA | 00 → M | • | | R | S | 1 | R | | | | | | CLRA | 00 →A | • | • | R | S | R | R | | | | | | CLAB | 00 →B | • | • | R | s | A | R | | | | | Decrement | DEC | M – 1 → M | • | • | \$ | ŧ | Φ | • | | | | | | DECA | A – 1 → A | • | • | ‡ | \$ | Φ | • | | | | | | DECB | B – 1 → B | • | • | 1 | 1 | Φ | • | | | | | Increment | INC | M + 1 → M | | | <b>‡</b> | t | Ф | • | | | | | | INCA | A+1→A | | • | 1 | 1 | | • | | | | | | INCB | B + 1 → B | | • | ŧ | t | (a) | • | | | | | Load Acmitr | LDAA | M→A | • | • | \$ | 1 | R | • | | | | | | LDAB | M→B | • | • | \$ | \$ | R | • | | | | | Push Data | PSHA | A → M <sub>SP</sub> , SP – 1 → SP | • | • | • | • | • | • | | | | | | PSHB | 8 → MSP, SP-1 → SP | • | • | • | • | ļ • | • | | | | | Pull Data | PULA | SP+1→SP, MSP→A | • | • | • | • | + | • | | | | | | PULB | SP + 1 → SP, M <sub>SP</sub> → B | • | • | • | ٠ ا | • | • | | | | | Rotate Left | ROL | M) | • | • | ‡ | ‡ | ᡌ | ‡ | | | | | | ROLA | │ <mark>▲</mark> │└─∁ ← [IIIIIIII→ | • | • | 1 | 1 | ( <b>6</b> ) | ‡ | | | | | | ROLB | B) C 07 ← 20 | • | • | 1 | 1 | | \$ | | | | | Rotate Right | ROR | мլ | • | • | \$ | 1 | ΙŌ | \$ | | | | | • | RORA | A | | • | ŧ | 1 | 900 | t t | | | | | | RORB | B C by → bo | | • | \$ | 1 | 6 | <b>‡</b> | | | | | Shift Left, Arithmetic | ASL | M) _ | | • | \$ | 1 | 6 | ‡ | | | | | <del></del> | ASLA | A | | • | ¢ | 1 \$ | b | <b>‡</b> | | | | | | ASLB | B C by bo | • | • | \$ | t | 6 | | | | | | Shift Right, Arithmetic | ASR | M) | | • | \$ | 1 | 6 | ‡ | | | | | | ASRA | A } → □ | | | 1 | ‡ | 6 | \$ | | | | | | ASRB | B b7 b0 C | | • | 1 | 1 | 6 | 1 | | | | | Shift Right, Logic. | LSR | ค่า | | • | R | 1 | 16 | \$ | | | | | ****** ******************************* | LSRA | A 0 → (131111111111111111111111111111111111 | | • | R | 1 | 6 | <b>‡</b> | | | | | | LSRB | B b7 b0 C | | • | R | ‡ | 16 | \$ | | | | | Store Acmitr. | STAA | A→M | | • | \$ | ŧ | R | • | | | | | | STAB | B→M | | • | 1 | 1 | R | • | | | | | Fransfer Acmitrs | TAB | A→B | • | • | 1 | ‡ | R | • | | | | | | TBA | B→A | • | • | 1 | 1 | R | • | | | | - (Bit V) Test: Operand = 10000000 prior to execution? - (Bit V) Test: Operand = 01111111 prior to execution? - ⑥ (Bit V) Test: Set equal to result of N ⊕ C after shift has occurred. Figure 4-10 Data Handling Instructions ### PROGRAM CONTROL OPERATIONS Program Control operation can be subdivided into two categories: (1) Index Register/Stack Pointer instructions; (2) Jump and Branch operations. Index Register/Stack Pointer Operations The instructions for direct operation on the MPU's Index Register and Stack Pointer are summarized in Figure 4-11. Decrement (DEX, DES), increment (INX, INS), load (LDX, LDS) and store (STX, STS) instructions are provided for both. The Compare instruction, CPX, can be used to compare the Index Register to a 16-bit value and update the Condition Code Register accordingly. | INDEX REGISTER AND | STACK | | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------------|----------|---------------------------------------------------|---|---|----|---|----------|----| | POINTER OPERATIONS | MNEMONIC | BOOLEAN/ARITHMETIC OPERATION | н | - | N | z | v | C | | Compare Index Reg | CPX | $\{X_H/X_L\} = (M/M + 1)$ | • | • | 0 | t | <b>②</b> | • | | Decrement Index Reg | DEX | $X - 1 \rightarrow X$ | | • | • | t | • | ١. | | Decrement Stack Potr | DES | SP - 1 →SP | | • | | • | • | | | Increment Index Reg | INX | X + 1 → X | | • | • | t | • | | | Increment Stack Potr | INS | SP + 1 → SP | | • | • | • | ٠ | • | | Load Index Reg | LDX | $M \rightarrow X_{H_1} (M + 1) \rightarrow X_1$ | | • | 3 | ŧ | R | | | Load Stack Pntr | LO\$ | $M \rightarrow SP_H$ , $(M + 1) \rightarrow SP_1$ | • | • | ര് | ‡ | R | | | Store Index Reg | STX | $X_H \rightarrow M, X_1 \rightarrow (M+1)$ | • | • | Õ | ‡ | R | • | | Store Stack Pntr | STS | $SP_H \rightarrow M$ , $SP_1 \rightarrow (M+1)$ | | • | õ | ‡ | R | | | Indx Reg → Stack Pntr | TXS | X — 1 → SP | | • | • | • | • | | | Stack Pntr → Indx Reg | TSX | $SP + 1 \rightarrow X$ | • | • | • | • | • | | - (Bit N) Test: Sign bit of most significant (MS) byte of result = 1? - (Bit V) Test: 2's complement overflow from subtraction of LS bytes? - (Bit N) Test: Result less than zero? (Bit 15 = 1) Figure 4-11 Index Register and Stack Pointer Instructions The TSX instruction causes the Index Register to be loaded with the address of the last data byte put onto the "stack". The TXS instruction loads the Stack Pointer with a value equal to one less than the current contents of the Index Register. This causes the next byte to be pulled from the "stack" to come from the location indicated by the Index Register. The utility of these two instructions can be clarified by describing the "stack" concept relative to the M6800 system. The "stack" can be thought of as a sequential list of data stored in the 680b's read/write memory. The Stack Pointer contains a 16-bit memory address that is used to access the list from one end on a last-in-first-out (LIFO) basis in contrast to the random access mode used by the MPU's other addressing modes. The M6800 instruction set and interrupt structure allow extensive use of the stack concept for efficient handling of data movement, subroutines and interrupts. The instructions can be used to establish one or more "stacks" anywhere in read/write memory. Stack length is limited only by the amount of memory that is made available. Figure 4-12 Stack Operation, Push Instruction Figure 4-14 Program Flow for BSR Figure 4-15 Program Flow for JSR (Extended) Figure 4-16 Program Flow for JSR (Indexed) Figure 4-17 Program Flow for RTS Operation of the Stack Pointer with the Push and Pull instructions is illustrated in Figures 4-12 and 4-13. The Push instruction (PSHA) causes the contents of the indicated accumulator (A in this example) to be stored in memory at the location indicated by the Stack Pointer. The Stack Pointer is automatically decremented by one following the storage operation and is "pointing" to the next empty stack location. The Pull instruction (PULA or PULB) causes the last byte stacked to be loaded into the appropriate accumulator. The Stack Pointer is automatically incremented by one just prior to the data transfer so that it will point to the last byte stacked rather than the next empty location. Note that the PULL instruction does not "remove" the data from memory; in the example, la is still in location (m+1) following execution of PULA. A subsequent PUSH instruction would overwrite that location with the new "pushed" data. Execution of the Branch to Subroutine (BSR) and Jump to Subroutine (JSR) instructions causes a return address to be saved on the stack as shown in figures 4-14 through 4-16. The stack is decremented after each byte of the return address is pushed onto the stack. For both of these instructions, the return address is the memory location following the bytes of code that correspond to the BSR and JSR instruction. The code required for BSR or JSR may be either two or three bytes, depending on whether the JSR is in the indexed (two bytes) or the extended (three bytes) addressing mode. Before it is stacked, the Program Counter is automatically incremented the correct number of times to point at the location of the next instruction. The Return from Subroutine instruction, RTS, causes the return address to be retrieved and loaded into the Program Counter as shown in Figure 4-17. There are several operations that cause the status of the MPU to be saved on the stack. The Software Interrupt (SWI) and Wait for Interrupt (WAI) instructions as well as the maskable (IRQ) and non-maskable (NMI) hardware interrupts all cause the MPU's internal registers (except for the Stack Pointer itself) to be stacked as shown in Figure 4-21. MPU status is restored by the Return from Interrupt, RTI, as shown in Figure 4-21. Jump and Branch Operations The Jump and Branch instructions are summarized in Figure 4-18. These instructions are used to control the transfer of operation from one point to another in the control program. The No Operation instruction, NOP, while included here, is a jump operation in a very limited sense. Its only effect is to increment the Program Counter by one. It is useful during program development as a "stand-in" for some other instruction that is to be determined during debug. It is also used for equalizing the execution time through alternate paths in a control program. Execution of the Jump Instruction, JMP, and Branch Always, BRA, effects program flow as shown in Figure 4-19. When the MPU encounters the Jump (indexed) instruction, it adds the offset to the value in the Index Register and uses the result as the address of the next instruction to be executed. In the extended addressing mode, the address of the next instruction to be executed is fetched from the two locations immediately following the JMP instruction. The Branch Always (BRA) instruction is similar to the JMP (extended) instruction except that the relative addressing mode applies. The opcode for the BRA instruction requires one less byte than JMP (extended) but takes one more cycle to execute. | JUMP AND BRANCH | | | 5 | 4 | 3 | 2 | ī | l o | |--------------------------|--------------|---------------------------|-------------|---|-----|---------|-----|-----| | DPERATIONS | MNEMONIC | BRANCH TEST | Н | - | N | Z | V | c | | Branch Always | BRA | None | • | • | | • | • | ١. | | Branch If Carry Clear | всс | C = 0 | • | | | | • | | | Branch If Carry Set | BCS | C = 1 | • | • | | | | ١. | | Branch If = Zero | BEQ | Z = 1 | | • | | | | ١. | | Branch If ≥ Zero | BGE | N + V = O | • | • | | • | | | | Branch If > Zero | BGT | Z + (N + V) = 0 | | • | • | | • | | | Branch If Higher | ВНІ | C + Z = 0 | | • | • | • | • | | | Branch If | BLE | Z + (N + V) = 1 | | • | ٠ | • | | • | | Branch If Lower Or Same | BLS | C + Z = 1 | i • l | • | • | • | • | | | Branch If < Zero | BLT | N ⊕ V = 1 | • | • | • | • | • | | | Branch If Minus | BM1 | N = 1 | • | • | • | • | • | | | Branch If Not Equal Zero | BNE | Z = 0 | • | • | • | • | • | | | Branch If Overflow Clear | BVC | V = 0 | | • | • | • | • | | | Branch If Overflow Set | BVS | V = 1 | • | • | • | • | • | | | Branch If Plus | B <b>P</b> L | N = 0 | | • | • | • | • | | | Branch To Subroutine | BSR | ì | • | • | • | • | • | | | Jomp | JMP | See Special Operations | • | • | • | • | • | | | Jump To Subroutine | JSR | J | • | • | • | • | • | | | No Operation | NOP | Advances Prog. Cntr. Only | | | • | | | Ļ | | Return From Interrupt | RTI | | | | 6 | ) | | 1 | | Return From Subroutine | RTS | ] | • ! | • | • 1 | ر<br>•۱ | • 1 | | | Software Interrupt | SWI | See special Operations | <b>.</b> • | s | | ا٠ | | | | Wait for Interrupt | WAI | J | • | മ | | | | | Figure 4-18 Jump and Branch Instructions <sup>(</sup>All) Load Condition Code Register from Stack. (See Special Operations) (2) (Bit 1) Set when interrupt occurs. If previously set, a Non-Maskable Interrupt (Bit I) Set when interrupt occurs. If previously set, a Non-Maskable Interrupt is required to exit the wait state. Figure 4-19 Program Flow for Jump and Branch Instructions The effect on program flow for the Jump to Subroutine (JSR) and Branch to Subroutine (BSR) is shown in Figures 4-14 through 4-16. Note that the Program Counter is properly incremented to be pointing at the correct return address before it is stacked. Operation of the Branch to Subroutine and Jump to Subroutine (extended) instruction is similar except for the range. The BSR instruction requires less opcode than JSR (2 bytes versus 3 bytes) and also executes one cycle faster than JSR. The Return from Subroutine, RTS, is used at the end of a subroutine to return to the main program as indicated in Figure 4-17. The effect of executing the Software Interrupt, SWI, and the Wait for Interrupt, WAI, and their relationship to the hardware interrupts is shown in Figure 4-20. SWI causes the MPU contents to be stacked and then fetches the starting address of the interrupt routine from the memory locations that respond to the addresses FFFA and FFFB. Note that as in the case of the subroutine instructions, the Program Counter is incremented to point at the correct return address before being stacked. The Return from Interrupt instruction, RTI, (figure 4-21) is used at the end of an interrupt routine to restore control to the main program. The SWI instruction is useful for inserting break points in the control program, that is, it can be used to stop operation and put the MPU registers in memory where they can be examined. The WAI instruction is used to decrease the time required to service a hardware interrupt; it stacks the MPU contents and then waits for the interrupt to occur, effectively removing the stacking time from a hardware interrupt sequence. Figure 4-20 Program Flow for Interrupts Figure 4-21 Program Flow for RT1 The conditional branch instructions, Figure 4-22, consist of seven pairs of complementary instructions. They are used to test the results of the preceding operation and either continue with the next instruction in sequence (test fails) or cause a branch to another point in the program (test succeeds). Four of the pairs are used for simple tests of status bits N, Z, V, and $\ensuremath{\text{C:}}$ - (1) Branch On Minus (BMI) and Branch On Plus (BPL) tests the sign bit, N, to determine if the previous result was negative or positive, respectively. - (2) Branch On Equal (BEQ) and Branch On Not Equal (BNE) are used to test the zero status bit, Z, to determine whether or not the result of the previous operation was equal to zero. These two instructions are useful following a Compare (CMP) instruction to test for equality between an accumulator and the operand. They are also used following the Bit Test (BIT) to determine whether or not the same bit positions are set in an accumulator and the operand. - (3) Branch On Overflow Clear (BVC) and Branch On Overflow Set (BVS) tests the state of the V bit to determine if the previous operation caused an arithmetic overflow. - (4) Branch On Carry Clear (BCC) and Branch On Carry Set (BCS) tests the state of the C bit to determine if the previous operation caused a carry to occur. BCC and BCS are useful for testing relative magnitude when the values being tested are regarded as unsigned binary numbers, that is, the values are in the range 00 (lowest) to FF (highest). BCC following a comparison (CMP) will cause a branch if the (unsigned) value in the accumulator is higher than or the same as the value of the operand. Conversely, BCS will cause a branch if the accumulator value is lower than the operand. The fifth complementary pair, Branch On Higher (BHI) and Branch On Lower or Same (BLS) are in a sense complements to BCC and BCS. BHI tests for both C and Z=0; if used following a CMP, it will cause a branch if the value in the accumulator is higher than the operand. Conversely, BLS will cause a branch if the unsigned binary value in the accumulator is lower than or the same as the operand. The remaining two pairs are useful in testing results of operations in which the values are regarded as signed two's complement numbers. This differs from the unsigned binary case in the following sense: In unsigned, the orientation is higher or lower; in signed two's complement, the comparison is between larger or smaller where the range of values is between -128 and +127. Branch On Less Than Zero (BLT) and Branch On Greater Than Or Equal To Zero (BGE) test the status bits for N + V = 1 and N + V = 0, respectively. BLT will always cause a branch following an operation in which two negative numbers were added. In addition, it will cause a branch following a CMP in which the value in the accumulator was negative and the operand was positive. BLT will never cause a branch following a CMP in which the accumulator value was positive and the operand negative. BGE, the complement to BLT, will cause a branch following operations in which two positive values were added or in which the result was zero. The last pair, Branch On Less Than Or Equal Zero (BLE) and Branch On Greater Than Zero (BGT) test the status bits for $Z \oplus (N+V)=1$ and $Z+(N \oplus V)=0$ , respectively. The action of BLE is identical to that for BLT except that a branch will also occur if the result of the previous result was zero. Conversely, BGT is similar to BGE except that no branch will occur following a zero result. ``` BMN : N = 1 ; BEQ : Z = 1 ; BPL : N = φ ; BNE : Z = φ ; BVC : V = φ ; BCC : C = φ ; BVS : V = 1 ; BCS : C = 1 ; BHI : C + Z = φ ; BLT : N ⊕ V = 1 ; BLS : C + Z = 1 ; BGE : N ⊕ V = φ ; BLE : Z + (N ⊕ V) = 0 ; ``` Figure 4-22 Conditional Branch Instructions ### V. ARITHMETIC OPERATIONS ## NUMBER SYSTEMS The ALU (Arithmetic Logic Unit) always performs standard binary addition of two eight bit numbers with the numbers represented in 2's complement form. However, the MPU instruction set and hardware flags permit arithmetic operation using any of four different representations for the numbers: (1) Each byte can be interpreted as a signed 2's complement number in the range -127 to +127: (+127 in 2's complement representation) (2) Each byte can be interpreted as an unsigned binary number in the range 0 to 255: (3) Each byte contains one 4-bit BCD number in the 4 LSBITS, the 4MS bits are zeros. This is referred to as unpacked BCD and can represent numbers in the range of 0-9: 0 1 1 1 1 1 1 1 Must always be zero (4) Each byte can be thought of as containing two 4-bit binary coded decimal (BCD) numbers. With this interpretation, each byte can represent numbers in the range 0 to 99: Each of these number systems will be illustrated with programming examples after the condition code flags and instruction set have been introduced in more detail. ### THE CONDITION CODE REGISTER $$^{b_5}$$ $^{b_4}$ $^{b_3}$ $^{b_2}$ $^{b_1}$ $^{b_0}$ Condition Code Register - H = $\frac{\text{Half-carry}}{\text{ted}}$ ; set whenever a carry from $b_3$ to $b_4$ of the result is generated; cleared otherwise. - I = Interrupt Mask; set by an interrupt or SEI instruction; cleared by CLI instruction. (Normally not used in arithmetic operations). - N = Negative; set if high order bit $(b_7)$ of result is set; cleared otherwise. - Z = Zero; set if result = 0; cleared otherwise. - V oVerflow; set if there was arithmetic overflow as a result of the operation; cleared otherwise. - C <u>Carry</u>; set if there was a carry from the most significant bit (b<sub>7</sub>) of the result; cleared otherwise. ## **OVERFLOW** The description of most of the condition code bits is straight forward. However, overflow requires clarification. Arithmetic overflow is an indication that the last operation resulted in a number beyond the $\pm 127$ range of an 8-bit byte. Overflow can be determined by examining the sign bits of the operands and the result as indicated in Table 5-1 where the results for addition of A + B is shown. | Row | <u>a<sub>7</sub></u> | <u> </u> | r <sub>7</sub> | <u>V</u> | | |-----|----------------------|----------|----------------|----------|-------------| | 1 | 0 | 0 | 0 | 0 | | | 2 | 0 | 0 | 1 | 1 | | | 3 | 0 | 1 | 0 | 0 | | | 4 | 0 | 1. | 1 | 0 | | | 5 | 1 | 0 | 0 | 0 | (A + B) = R | | 6 | 1 | 0 | 1 | 0 | | | 7 | 1 | 1 | 0 | 1 | | | 8 | 1 | 1 | 1 | 0 | | TABLE 5-1: Overflow for Addition If the sign bits of the operands, $a_7$ and $b_7$ , are different (rows 3 through 6 of the Table) no overflow can occur and the V flag is clear after the operation. If the operand sign bits are alike and the result exceeds the byte capacity, the sign bit of the result $(r_7)$ will change and the overflow bit will be set. This is illustrated in the following example. The example follows actual ALU operation in that the starting number A is initially in the accumulator but is replaced by the result of the current operation. V 7 6 5 4 3 2 1 0 0 0 0 1 1 0 1 1 0 A = +54; 1 0 0 0 0 1 1 1 B = -121; (negative numbers are in 2's complement notation) 0 ] 0 ] 1 ] 1 0 1 $R_0$ = A + B = -67; (signs of A & B different; no overflow) 0 1 0 1 1 1 1 0 1 $R_0 = -67$ ; 1 1 0 1 1 1 1 1 B = -33; 0 1 0 0 1 1 1 0 0 $R_1 = R_0 + B = -100$ ; (Signs alike but byte capacity not exceeded; no overflow) V 7 6 5 4 3 2 1 0 1 0 0 1 1 1 0 0 $R_1 = -100$ ; 1 1 1 0 0 0 0 0 B = -32; 1 0 1 1 1 1 0 0 $R_2$ = +124 (Signs of $R_1$ & B alike and sign of result occurred) Here the capacity of the register has been exceeded and the result is +124 rather than -32. Overflow is said to have occurred. In subtraction operations, the possibility of overflow exists whenever the operands differ in sign. Overflow conditions for A - B are illustrated in Table 5-2. | Row | <b>a</b> 7 | <del>5</del> 7 | r <sub>7</sub> | ٧ | | |-----|------------|----------------|----------------|---|-------------| | 1 | 0 | 0 | 0 | 0 | | | 2 | 0 | 0 | 1 | 1 | | | 3 | 0 | 1 | 0 | 0 | | | 4 | 0 | 1 | 1 | 0 | (A - B) = R | | 5 | 1 | 0 | 0 | 0 | | | 6 | 1 | 0 | 1 | 0 | | | 7 | 1 | 1 | 0 | 1 | | | 8 | 1 | 1 | 1 | 0 | | TABLE 5-2 Overflow for Subtraction Note that Table 5-2 is identical to the addition table except that $b_7$ has been replaced by $b_7$ . This is explained by the fact that the ALU performs subtraction by adding the negative of the subtrahend B to the minuend A. Hence, the ALU first forms the 2's complement of B and then adds. The subtraction table with $b_7$ negated then reflects the sign bits of two numbers that are to be added. If $a_7$ and $a_7$ are alike, overflow will occur if the byte capacity is exceeded. ## THE ARITHMETIC INSTRUCTIONS Table 5-3 summarizes the instructions used primarily for arithmetic operations. The effect of each operation on memory and the MPU's Accumulators is shown along with how the result of each operation effects the Condition Code Register. The carry bit is used as a carry for addition and as a borrow for subtraction and is added to the Accumulators with the Add With Carry Instructions and subtracted from the Accumulators in the Subtract With Carry instructions. | | | | | | | | A | DBRE | SSIMO | MO | DES | | | | | | • GOOLEAN/ARITHMETIC OFERATION | _ c | <b>8</b> 9 | D. C | OE | Æ | G. | |-------------------------|----------|----|----|----|----|------|----|------|-------|-----|------|-----|----|----|-----|-----|-----------------------------------------------------------|-----|------------|------|----|-----|-----| | ACCUMULATOR AN | YADMAN D | | MM | €Đ | | OURE | CT | Ι. | INO | EX | | EXT | NO | | INH | EĦ | (All register labels | 5 | 4 | 1 | 2 | ŀ | 0 | | OPERATIONS | MNEMONIC | QP | ~ | # | QP | ~ | # | 0# | ~ | # | OP. | ~ | # | 0 | ~ | # | refer to contents) | Н | 1 | N | z | v | C | | Add | AUDA | 88 | 2 | 2 | 9B | 3 | 2 | ΑĐ | 5 | 2 | 88 | 4 | 3 | | | | A + M + A | 1 | • | ţ | : | 1 | 1 | | | ADDB | ÇB | 2 | 2 | 08 | 3 | 2 | €B | 5 | 2 | FB | 4 | 3 | | | | B+M -6 | 1: | • | 1 | 1 | 1 | ; | | Add Acmitrs | ABA | | l | ı | | | | 1 | ı | l | l | 1 | | 18 | 2 | ţ 1 | A+B-+A | 1: | ۰ ا | ţ | t | 1 | : | | Add with Carry | ADCA | 89 | 2 | 2 | 99 | 3 | Z | A9 | 5 | 2 | 85 | 4 | 3 | | | 1 | A+M+C-A | 1 | ١. | ‡ | t | 1 | ł | | | ADCB | C9 | 2 | 2 | 09 | 3 | 2 | E9 | 5 | 2 | F9 | | 3 | | | i | 8 + M + C → B | 1 | ۱. | ŧ | 1 | ļ | ļŧ | | Complement, 1's | COM | i | 1 | i | 1 | | | 63 | 7 | ] 2 | į 73 | 6 | 3 | | 1 | l | [Ñ→M | • | ٠. | 1 | 1 | Ŕ | s | | | CDMA | | | | 1 | | | ! | l | į | Ī | | | 43 | 2 | 1 | Ä→A | • | • | t | t | R | \$ | | | COMB | l | | | 1 | ŀ | | | l | ľ | [ | | | 53 | 2 | 1 | 8 → 8 | • | • | t | t | R | S | | Complement, 2's | NEG | | 1 | l | 1 | | | 60 | 1 | 2 | 70 | 6 | 3 | | | l | aa - m → m | ٠. | • | : | : | Ю | lŒ | | (Negate | NEGA | | l | 1 | 1 | | | | | l | l | 1 | | 40 | 2 | ١, | 00 - A → A | • | • | : | ŧ | Ю | lē | | | NEGB | 1 | l | | ŀ | | 1 | | ŀ | l | 1 | Į. | | 50 | 2 | 1 | 00 - 6 - 6 | • | • | 1 | ţ | ΙĐ | Œ | | Documal Adjust, A | DAA | | | Ì | | | ĺ | | | | | | | 19 | 2 | ١, | Converts Binary Add. of BCO Characters<br>into BCD Formal | • | ١. | : | ı | ŧ | 0 | | Roiste Left | ROL | | 1 | l | 1 | ĺ | | 69 | 7 | 2 | 79 | 6 | 1 | | | | M1 | • | ٠. | ţ | t | ᡌ | 1 | | | ROLA | ŀ | l | l | 1 | | | | l | l | l | 1 | | 49 | 2 | ı | A i=g = mmmm = i | | • | ţ | ŧ | 16 | ŀ | | | ROLB | | I | l | ſ | | | | | Ì | | 1 | | 59 | 2 | 1 | B C 67 - 60 | | • | 1 | t | 6 | | | Rotate Right | ROR | | | Į. | l | | ŀ | 66 | 1 | 2 | 76 | 6 | 3 | | | l | M ] | | • | : | t | 6 | l t | | | RORA | | ' | 1 | l | | ŀ | | l | l | l | i | | 46 | 2 | • | v¦r-å → mmmb | • | • | ŧ | ţ | 6 | 1 | | | RORB | | l | 1 | l | | | | ŀ | l | l | 1 | | 56 | 2 | 1 | 8 ⊂ ייי סי | | • | ŧ | ŧ | 6 | l t | | Shilt Luft, Arithmetic | ASL | | | ĺ | l | | 1 | 68 | , | 2 | 78 | 6 | 3 | | | l | M | • | • | 1 | : | 6 | t | | | ASLA | | | Į. | l | | | | 1 | l | l | | | 48 | 2 | 1 | A | • | • | 1 | ; | (6) | 1: | | | ASLB | | | [ | l | ł | İ | | 1 | l | | | ! | 58 | 2 | 1 | 8 6 63 80 | • | • | 1 | 1 | 6 | 1 | | Shift Right, Arithmetic | ASA | | | ľ | l | 1 | | 67 | 7 | 2 | 77 | 6 | 3 | | | 1 | M) → | • | | \$ | 1 | 6 | 1 | | | ARRA | | | ŀ | l | l | | l | | l | ĺ | | | 47 | 2 | 1 | v r→quumm → n | | | t | 1 | 6 | l t | | | ASAB | | | | l | | | | l | | | | | 57 | 2 | 1 | a by bo c | • | | \$ | ; | 6 | 1 | | Shift Right, Logic | r28 | | ļ | | l | l | | 64 | 7 | 2 | 74 | 6 | 3 | | | | M} _ | | ٠ | R | 1 | 6 | ŀ | | | LSRA | | | | l | | | 1 | | | | | | 44 | 2 | 1 | A 0+000000 - 0 | • | • | R | İ | 6 | t | | | LSAB | | | | ļ | | | 1 | | | | | | 54 | 2 | 1. | B py '' C | | | R | 1 | 6 | 1 | | Subtract | SUBA | 80 | 2 | 2 | 90 | 3 | 2 | AO | 5 | 2 | 80 | 4 | 3 | | | | A - H → A | | | ŧ | t | T | 1 | | | \$88 | CO | 2 | 2 | DO | 3 | 2 | £Ο | 5 | 2 | FQ. | 4 | 3 | | | | 8 - M -+8 | | | ı | t | ŀ | 1 | | Subract Acmites | SBA | | | | 1 | | | | | | | | | 10 | 2 | 1 | A - 8 - A | | | ĺ. | i | | ŀ | | Setar, with Carry | SBCA | 82 | 2 | 2 | 92 | 3 | 2 | A2 | 5 | 2 | 82 | 4 | 3 | | | | A-M-C→A | | | t | í | ı. | ; | | | 8282 | C2 | 2 | ž | 02 | 3 | 2 | E2 | 5 | 7 | F2 | | 3 | | | ı | B - M - C → B | | ا آ ا | ı | 1 | [ | ı: | # LEGENO: - OP Operation Code (Hexadecimal); ~ Number of MPU Cycles; - Number of Program Bytes: - Arithmetic Plus; Arithmetic Minus; - Boolsen ANO; - MSP Contents of memory location pointed to be Stack Pointer; - Baalean Inclusive OR; Baalean Exclusive OR; - Transfer into; - Bit = Zero; - 00 Byta = Zero; - Half-carry from bit 3; interrupt mask - Zero (byte) Overflow, 2's complement Carry from bit 7 - Reset Always - Set Always Test and set if true, closeed otherwise Not Affected - CCA Condition Cade Register - LS Least Significant MS Mapt Significant # CONDITION CODE REGISTER NOTES: - (Bit stiff feet is true and cleared otherwise) (Bit V) Test: Result = 100000007 (Bit C) Test: Result = 00000007 (Bit C) Test: Result = 000000007 (Bit C) Test: Octional Wals of most significant 8CD Character greater than (Not cleared if previously set.) - (Bit V) Test: Set equal to result of N $\oplus$ C after shift has occurred. Table 5-3 Arithmetic Instructions The Decimal Adjust instruction, DAA, is used in BCD addition to adjust the binary results of the ALU. When used following the operations, ABA, ADD, and ADC on BCD operands, DAA will adjust the contents of the accumulator and the C bit to represent the correct BCD Sum. Table 5-4 shows the details of the DAA instruction and how it affects and is effected by the Condition Code Register bits. Operation: Adds hexadecimal numbers 00, 06, 60, or 66 to ACCA, and may also set the carry bit, as indicated in the following table: | State of<br>C-Bit<br>Before DAA<br>(Col. 1) | Upper<br>Half-Byte<br>(Bits 4—7)<br>(Col. 2) | Initial<br>Half-Carry<br>H-Bit<br>(Col. 3) | Lower<br>Half-Byte<br>(Bits 0-3)<br>(Col. 4) | Number Added<br>to ACCA<br>by DAA<br>(Col. 5) | State of<br>C-Bit<br>After DAA<br>(Col. 6) | |---------------------------------------------|----------------------------------------------|--------------------------------------------|----------------------------------------------|-----------------------------------------------|--------------------------------------------| | 0 | 0-9 | 0 | 0-9 | 00 | 0 | | 0 | 08 | 0 | A-F | 06 | 0 | | 0 | 09 | 1 | 0–3 | 06 | 0 | | 0 | AF | 0 | 0-9 | 60 | 1 | | 0 | 9-F | 0 | A-F | 66 | 1 | | 0 | A-F | 1 | 0-3 | 66 | 1 | | 1 | 0-2 | 0 | 0–9 | 60 | 1 | | 1 | 0-2 | 0 | A-F | 66 | 1 | | 1 | 0-3 | 1 | 0-3 | 66 | i | NOTE: Columns (1) to (4) of the above table represent all possible cases which can result from any of the operations ABA, ADD, or ADC, with initial carry either set or clear, applied to two binary-coded-decimal operands. The table shows hexadecimal values. # Effect on Condition Code Register: - H Not affected. - I Not affected. - $N_{\parallel}$ Set if most significant bit of the result is set; cleared otherwise. - Z Set if all bits of the result are cleared; cleared otherwise. - V Not defined. - C Set or reset according to the same rule as if the DAA and an immediately preceding ABA, ADD, or ADC were replaced by a hypothetical binary-coded-decimal addition. Table 5-4 Effect of DAA Instruction Use of Arithmetic Instructions Typical use of the arithmetic instructions is illustrated in the following examples: The ABA instruction adds the contents of ACCB to the contents of ACCA: | ACCA | 10101010 | (\$AA) | |-------|----------|----------------------| | ACCB | 11001100 | (\$CC) | | ACCA | 01110110 | (\$76) with a carry. | | CARRY | 1 | | The ADCA instruction adds the operand data and the carry bit to ACCA: ACCA 1 0 1 0 1 0 1 0 \$AA OPERAND DATA 1 1 0 0 1 1 0 0 CC CARRY ACCA 0 1 1 1 0 1 1 \$77 with carry CARRY In both of these examples, the 2's complement overflow bit, V, will be set as shown in Table 5-5. | | b <sub>7</sub> | b <sub>7</sub> | ь <sub>7</sub> | |-------|----------------------|-----------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | carry | ÁCC | ACC | OPERAND (OR ACCB) | | after | after | before | before | | 0 | 0 | 0 | 0 | | 0 | 1 | 0 | 0 | | 0 | 1 | 0 | 1 | | 1 | 0 | 0 | 1 | | 0 | 1 | 1 | 0 | | 1 | 0 | 1 | 0 | | 1 | 0 | 1 | 1 | | 1 | 1 | 1 | 1 | | | after<br>0<br>0<br>0 | carry ACC after after 0 0 0 1 0 1 1 0 0 1 1 0 | carry ACC ACC after after before 0 0 0 0 1 0 0 1 0 1 0 0 0 1 1 1 0 0 0 1 1 1 0 1 | TABLE 5-5 Truth Table for "Add with Carry" The SUBA instruction subtracts the operand data from ACCA: ACCA 0 1 1 0 0 0 1 0 1 \$65 OPERAND DATA 1 0 0 0 0 1 1 1 1 \$87 ACCA 1 1 0 1 1 1 0 \$DE with a borrow BORROW 1 The SBCA instruction subtracts the operand and the borrow (carry) it from $\mbox{ACCA}.$ The 2's complement overflow and carry bits are set in accordance with Table 5-6 as a result of a subtraction operation. | 2's | | b <sub>7</sub> | b <sub>7</sub> | b <sub>7</sub> | |------------|-------|----------------|----------------|----------------| | complement | carry | ACCA | ACCA | OPERAND | | overflow | after | after | before | before | | 0 | 0 | 0 | 0 | 0 | | 0 | 1 | 1 | 0 | 0 | | 0 | 1 | 0 | 0 | 1 | | 1 | , 1 | 1 | 0 | 1 | | 1 | 0 | 0 | 1 | 0 | | 0 | 0 | 1 | 1 | 0 | | 0 | 0 | 0 | 1 | 1 | | 0 | 1 | 1 | 1 | 1 | | | | | | | TABLE 5-6 Truth Table for "Subtract with Borrow" # ADDITION AND SUBTRACTION ROUTINES Most applications will require that the arithmetic instruction set be combined into more complex routines that operate on numbers larger than one byte. If more than one number system is used, routines must be written for each, or conversion routines to some common base must be used. In many cases, however, it is more efficient to write a specialized routine for each system requirement, i.e., hexadecimal (HEX) versus unpacked BCD multiplication, etc. In this section, several algorithms will be discussed with specific examples showing their implementation with the M6800 instruction set. The basic arithmetic operations are binary addition and subtraction: | ETA = GAMMA | ALPHA - B | eta = gamma | ALPHA + BI | |-------------|-----------|-------------|------------| | ALPHA | LDAA | ALPHA | LDAA | | BETA | SUBA | BETA | ADDA | | GAMMA | STAA | GAMMA | STAA | These operations are so short that they are usually programmed in line with the main flow. Addition of single packed BCD bytes requires only one more instruction. The DAA instruction is used immediately after the ADD, ADC, or ABA instructions to adjust the binary generated in accumulator A (ACCA) to correct BCD value: | | | LDAA | ALPHA | | |----------|------|------------------------|---------|---------------------------------------------------------------------| | | | ADDA | BETA | | | | | DAA | | | | Ĉarry | ACCA | STAA | GAMMA | | | X | 67 | 0110 0111 | =ACCA | | | <u>X</u> | +79 | <u>carry 0111 1001</u> | =MEMORY | | | 0 | 146 | 0 1110 0000 | =ACCA | binary result | | | 46 | 1 0100 0110 | =ACCA | after DAA; the carry bit will also be set because of the BCD carry. | Since no similar instruction is available for BCD subtraction, 10's complement arithmetic may be used to generate the difference. The follow routine performs a BCD subtraction of two digit BCD numbers: LDAA #\$99 SUBA BETA (99-BETA) = ACCA SEC carry = 1 ADCA ALPHA ACCA + ALPHA + C = ACCA DAA DECIMAL ADJUST (-100) STAA ALPHA-BETA = GAMMA The routine implements the algorithm defined by the following equations. ALPHA - BETA = GAMMA Gamma ALPHA + (99-BETA) - 99 = GAMMA 9's COMPLEMENT OF BETA ALPHA + (99-BETA + 1) - 100 = GAMMA 10's COMPLEMENT OF BETA One is added to the 9's complement of the subtrahend by setting the carry bit to find the 10's complement of BETA which is then added to the minuend ALPHA and saved in ACCA. The DAA instruction adjusts the result in ACCA to the proper BCD values before storing the difference in GAMMA. Since 100 has been added (99 + 1) to the subtrahend by finding the 10's complement, 100 must also be subtracted. This is accomplished by the DAA instruction since the resulting carry is discarded. Multiple precision operations mean that the data and results require more than one byte of memory. The simplest multiple precision routines are addition and subtraction of 16 bit binary or 2's complement numbers. This is often called double precision since 2 consecutive bytes are required to store 16 binary bits of information. The following routines illustrate these functions: | LDAA | ALPHA + 1 | | |------|-----------|---------------------------------------------| | LDAB | ALPHA | | | ADDA | BETA + 1 | ADD LS BYTES | | ADCB | BETA | ADD MS BYTES WITH CARRY FROM LS BYTES | | STAA | GAMMA +1 | | | STAB | GAMMA | | | | | | | LDAA | ALPHA + 1 | | | LDAB | ALPHA | | | SUBA | BETA + 1 | SUBTRACT LS BYTES | | SBCB | BETA | SUBTRACT MS BYTES WITH BORROW FROM LS BYTES | | STAA | GAMMA + 1 | | | STAB | GAMMA | | Four digit BCD addition can be accomplished in a similar fashion with the use of the DAA instruction. The following routine has been expanded to a 2N digit addition where N is the max number of packed BCD bytes used: | START | CLC | | |-------|------|---------| | | LDX | #N | | L00P | LDAA | ALPHA,X | | | ADCA | BETA,X | | | DAA | | | | STAA | GAMMA,X | | | DEX | | | | BNE | LOOP | NOTE: ALPHA, BETA, and GAMMA must be in the direct addressing range and adjusted for offset for this example (See indexed addressing for further details). This routine uses indexed address to select the bytes to be added, starting with the least significant. The carry is cleared at the start and is affected only by the DAA and ADCA instructions. This allows the carry to be included in the next byte addition. Expanding subtraction to multiple precision is accomplished in a manner similar to the single byte case; 10's complement arithmetic is used. A suitable routine is shown in the Assembly Listing of Figure 5-7. ``` 00010 NAM DSUB16 00030 OPT SYMB 00060 0000 SUBTRH EOU Λ 00070 8000 MINUEN EQU 8 08000 0010 RSLT EQU 16 00090 0100 ORG 256 00092 * DECIMAL SUBTRACT SUBROUTINE FOR 16 DECIMAL DIGIT * THIS ROUTINE SUBTRACTS THE SUBTRAHEND ("SUBTRH") * FROM THE MINUEND ("MINUEN") AND PLACES THE 00094 00095 00096 * DIFFERENCE IN "RSLT". 00097 * THE MEMORY ALLOCATION IS AS FOLLOWS: 00097 ADDRESS RANGE LSB SUBTRAHEND 00097 1-8 8 00097 MINUEND 9-16 16 00097 DIFFERENCE 17-24 24 ADDRESS VALUES ARE DECIMAL 00100 0100 CE 0008 DSUB LDX #8 SET BYTE COUNTER 00110 0103 86 99 DSUB1 LDA A #$99 SUB A SUBTRH,X FIND 9'S COMPLEMENT STA A RSLT,X USE "RSLT" AS TEMP STORE 00120 0105 A0 00 00130 0107 A7 10 00140 0109 09 DEX DECREMENT BYTE COUNTER 00150 010A 26 F7 DSUBT LOOP UNTIL LAST BYTE BNE RESTORE BYTE COUNTER 00160 010C CE 0008 LDX #8 00170 010F 0D SEC SET CARRY TO ADD 1 TO COMPL 00180 0110 A6 08 DSUB2 LDA A MINUEN,X LOAD MINUEND 00190 0112 A9 10 ADC A RSLT,X ADD COMPLEMENT SUBTRAHEND 00200 0114 19 DAA DECIMAL ADJUST 00210 0115 A7 10 STORE DIFFERENCE STA A RSLT,X 00220 0117 09 DEX DECREMENT BYTE COUNTER 00230 0118 26 F6 BNE DSUB2 LOOP UNTIL LAST BYTE 00240 011A 39 RETURN TO HOST PROGRAM 00251 * THE EXECUTION TIME OF THIS SUBROUTINE IS 00252 384 MPU CYCLES EXCLUDING THE RTS. 00254 END SYMBOL TABLE DSHB 0100 DSUB? 0103 DSUB2 0110 MINUEN 0008 RSLT SUBTRH 0000 ``` Figure 5-7 Decimal Subtract Assembly Listing This routine first finds the 9's complement of the subtrahend and stores it in the result buffer. The carry is then set to add 1 to the 9's complement, making it the 10's complement which is then added to the minuend and stored in the result buffer. Note that this routine has 2 loops, the first to calculate the 9's complement, the second to add and decimal adjust the result. The decimal add and subtract routines operate on 10's complement numbers as well as packed BCD numbers. A number is known to be negative in 10's complement form when the most significant digit in the most significant byte is a 9. When in the 10's complement form, this digit is reserved for the sign and the actual number of magnitude digits is one less than 2 times the number of bytes. A routine similar to the above subtract program will convert the 10's complement number to decimal magnitude with sign for display or output purposes: | DCONV | CLR | SINFLG | CLEAR SIGN FLAG | |--------|------|----------|----------------------| | | LDAA | RESULT+1 | GET MSBYTE | | | BPL | END | POSITIVE: END | | | LDX | #8 | NEGATIVE: | | DCONV1 | LDAA | #\$99 | | | | SUBA | RSLT,X | SUBTRACT RESULT FROM | | | STAA | RSLT,X | ALL 9's INCLUDING | | | DEX | | SIGN DIGIT | | | BNE | DCONVI | | | | LDX | #8 | | | | CLRA | | | | | SEC | | | | DCONV2 | ADCA | RSLT,X | ADD 1 TO RESULT | | | DAA | | | | | STAA | RSLT,X | | | | DEX | | | | | BNE | DCONV2 | | | | DEC | SINFLG | SET SIGN FLAG | | END | RTS | | RETURN | | | | | | The sign flag would be used to indicate plus when clear and minus when not clear. ### MULTIPLICATION Multiplication increases programming complexity. In addition to the addition and subtraction instructions, the use of the shift and rotate instructions is required. The general algorithm for binary multiplication can be illustrated by a short example: - (1) Test the least significant multiplier bit for 1 or 0. - (a) If it is 1, add the multiplicand to the result, then 2. - (b) If it is 0, then 2. - (2) Shift the multiplicand left one bit. - (3) Test the next more significant multiplier bit; then la or lb. | DECIMAL | BINARY | | | |----------|--------------|-----|-------------------------------------------------------------------| | 13<br>11 | 1101<br>1011 | _ | MULTIPLICAND MULTIPLIER LSB = 1; ADD MULTIPLICAND TO RE- SULT (A) | | | 1101 | (A) | | | 13 | 1107 | (B) | SHIFT MULTIPLICAND LEFT ONE BIT (B) | | | 100111 | (C) | LSB+1 = 1; ADD MULTIPLICAND TO RESULT (C) | | 13 | 1101 | (D) | SHIFT MULTIPLICAND LEFT ONE BIT (D) | | | 1701 | (E) | LSB+2 = 0; SHIFT MULTIPLICAND LEFT 1 (E) | | 143 | 10001111 | (F) | LSB+3 = 1; ADD MULTIPLICAND TO RESULT (F) | | | 128 + 15 = | 143 | | Signed binary numbers in 2's complement form cannot be multiplied without correcting for the cross product terms which are introduced by the 2's complement representation of negative numbers. There is an algorithm which generates the correct 2's complement product. Since positive binary numbers are correct 2's complement notations, they also may be multiplied using this procedure. It is called Booth's Algorithm. Simply stated the algorithm says: - Test the transition of the multiplier bits from right to left assuming an imaginary 0 bit to the immediate right of the multiplier. - (2) If the bits in question are equal, then 5. - (3) If there is a 0 to 1 transition, the multiplicand is subtracted from the product, then 5. - (4) If there is a 1 to 0 transition, the multiplicand is added to the product, then 5. - (5) Shift the product right one bit with the MSBit remaining the same. (This has the same effect as shifting the multiplicand left in the previous example). - (6) Go to 1 to test the next transition of the multiplier. The following example (Figure 5-8) shows the typical steps involved in an actual calculation. A flow chart and assembly listing for a multiplication program using the M6800 instruction set are shown in Figures 5-9 and 5-10, respectively. Figure 5-8 Multiplication Using Booth's Algorithm Figure 5-9 Flow Chart for Booth's Algorithm ``` 01000 NAM MULT16 00020 OPT NOPAGE 00030 THIS ROUTINE MULTIPLIES TWO 16 BIT 2'S 00040 COMPLIMENT NUMBERS USING BOOTH'S ALGORITHM 00050 00060 THE MULTIPLIER = Y = Y(MSB),Y(LSB) = Y,Y+1 THE MULTIPLICAND =XX=XX(MSB),XX(LSB) = XX,XX+1 THE PRODUCT = U = U(MSB),U+1,U+2,U+3 00070 00080 00090 THE TEST BYTE FOR Y(LSB-1) = FF 00100 00110 ORG $80 00120 0080 00130 0080 0002 00140 0082 0002 RMB 2 XX RMB 00150 0084 0004 υ RMB FF 1 00160 0088 0001 RMB 00170 THE MULTIPLIER AND THE MULTIPLICAND MUST BE * 00180 STORED IN Y AND XX RESPECTIVELY, THEN A JSR TO MULT16 WILL GENERATE THE 2'S COMPLIMENT PRODUCT 00190 00200 OF Y AND XX IN U. 00210 00220 00230 THE MULTIPLICAND WILL BE UNCHANGED, THE MULTIPLIER WILL BE DESTROYED. 00240 00250 00260 0400 ORG $400 ``` Figure 5-10 Assembly Listing for Booth's Algorithm (Sheet 1 of 2) ``` 00270 0400 CE 0005 MULT16 LDX #5 CLEAR THE WORKING REGISTERS 00280 0403 4F CLR A 00290 0404 A7 83 STA A U-1,X 00300 0406 09 00310 0407 26 FB DEX LP1 BNE 00320 0409 CE 0010 00330 040C 96 81 00340 040E 84 01 LDX #16 LDA A Y+1 INIT'L SHIFT COUNTER TO 16 GET Y(LSBIT) AND A #1 SAVE Y(LSBIT) IN ACCB DOES Y(LSBIT) = Y(LSB-1) ? 00350 0410 16 TAB 00360 0411 98 88 EOR A FF JEQ SHIFT TST B BEO YES: GO TO SHIFT ROUTINE NO: DOES Y(LSBIT) = 0 ? 00370 0413 27 1D 00380 0415 5D 00390 0416 27 DE BEQ ADD YES: GO TO ADD ROUTINE LDA A U+1 00400 0418 96 85 NO: SUBTRACT MULTIPLICAND 00410 041A D6 84 LDA B U PRODUCT WITH THE MSBYTES LINED UP 00420 0410 90 83 SUB A XX+1 00430 041E D2 82 SBC B XX 00440 0420 97 85 STA A U+1 STA B U 00450 0422 D7 84 00460 0424 20 OC BRA SHIFT THEN GO TO SHIFT ROUTINE LDA A U+1 ADD THE MULTIPLICAND TO THE PRODUCT WITH THE MSBYTES ADD 00470 0426 96 85 00480 0428 D6 84 LDA B U 00490 042A 9B 83 ADD A XX+1 LINED UP 00500 042C D9 82 ADC B XX 00510 042E 97 85 STA A U+1 00520 0430 D7 84 STA B U FF Y 00530 0432 7F 0088 SHIFT CLR CLEAR THE TEST BYTE ROR SHIFT THE MULTIPLIER RIGHT 00540 0435 76 0080 ROR Y+1 ONE BIT WITH THE LSBIT 00550 0438 76 0081 00560 043B 79 0088 ROL FF INTO THE LSBIT OF FF 00570 043E 77 0084 SHIFT THE PRODUCT RIGHT ONE ASR BIT, THE MSB REMAINING THE 00580 0441 76 0085 ROR U+1 ROR 00590 0444 76 0086 11+2 00600 0447 76 0087 ROR U+3 DEX DECREMENT THE SHIFT COUNT 00610 044A 09 LP2 IF NOT O CONTINUE 00620 044B 26 BF BNE 00630 044D 39 RTS 00640 END ``` Figure 5-10 Assembly Listing for Booth's Algorithm (Sheet 2 of 2) # DIVISION A flow chart for binary division is shown in Figure 5-11. The assembly listing of the program is given in Figure 5-12. The algorithm used for this straight forward binary division is as follows: - (1) Left justify the divisor byte. - (2) If the MS byte of the dividend is less than the divisor byte, shift quotient left one bit with the LS bit = 0; then 4. - (3) If the MS byte of the dividend is greater than or equal to the divisor, (2)shift the quotient left one bit with the LS Bit = 1; (b) subtract the divisor from the MS byte of the dividend, the result being stored in the MS byte of the dividend; then 4. - (4) Shift the dividend left one bit with the LS Bit = 0, and the MS Bit going into the carry. - (5) If the carry is set, go to 3a. - (6) If the carry is not set, go to 2a. The process continues until the number of quotient shifts equals $8\,\pm\,$ number of shifts required to left justify the divisor. ``` 0PT 00100 00000 NAM XKDTVD 00010 OPT NOPAGE 00020 5900 ORG B5900 SUBROUTINE TO DIVIDE AN UNSIGNED 4 DIGIT HEX NUMBER [16 BIT BINARY] BY AN UNSIGNED 2 DIGIT HEX NUMBER [8 BIT BINARY]. 00030 00040 00050 00060 THE DIVISOR = X = XKDVSR = [F9] THE DIVIDEND = Y(M),Y(L) 00070 00080 00090 =XKDVND,XKDVND+1 00100 =[FA,FB] THE QUOTIENT = Q(M),Q(L) =XKQUOT,XKQUOT+1 =[FC,FD] THE SHIFT COUNTER = S = ACCB THE LEFT DISPLACEMENT OF THE REMAINDER = XKDSPL 00110 00120 00130 00140 00150 00160 00170 THE DIVISOR AND THE DIVIDEND MUST BE LOADED INTO XKDVSR AND XKDVND,XKDVND+1 RESPECTIVELY 00180 00190 00200 THEN A JSR TO XKDIVD. 00210 THE REMAINDER WILL BE IN Y(M) [XKDVND], SHIFTED LEFT THE # OF BITS INDICATED IN XKDSPL THE DIVISOR WILL BE BINARILY LEFT JUSTIFIED 00220 00230 00240 ``` Figure 5-12 XKDIVD Assembly Listing (Sheet 1 of 2) ``` 00260 5900 C6 08 XKDIVD LDA B INIT'L S=8 00270 5902 7F 00FC CLR XKQUOT ZERO QUOTIENT BUFFER 00280 5905 7F 00FD CLR XKQUOT+1 00290 5908 5C DVDLOP INC B S-S+1 00300 5909 Cl 10 CMP B #16 ₽00310 590B 2E 34 BGT DVDERR IF S>16 DIVIDE ERROR IF S<16 LEFT SHIFT DIVISOR 00320 590D 73 00F9 XKDVSR ASL 00330 5910 24 F6 BCC DVDLP0 IF C=0 CON'T LOOP 00340 5912 D7 FE STA B XKDSPL IF C=1 XKDSPL = SHIFT COUNT 00350 5914 76 00F9 SHIFT THE DIVISOR BACK 1 ROR XKDVSR 00360 SHIFT COUNT NOW IN ACCB 00370 DIVISOR LEFT JUST. IN X 00380 5917 96 FA LDA A XKDVND 00390 5919 91 F9 DVDLP1 CMP A XKDVSR IF THE DIVIDEND<DIVISOR 00400 591B 25 0D DON'T SUBTRACT BCS DVNSUB 00410 591D 0D DVDLP2 SEC IF THE DIVIDENT >OR=DIVISOR 00420 591E 79 00FD ROL XKQUOT+1 SHIFT Q LEFT 1 BIT WITH LSB = 1 00430 5921 79 00FC XKOUOT ROL 00440 5924 90 F9 SUB A XKDV$R Y(M) = Y(M) - X 00450 5926 97 FA STA A XKDVND 00460 5928 20 07 BRA DVSHFT 00470 592A 0C DVNSUB CLC SHIFT Q LEFT WITH 00480 592B 79 00FD ROL XKQUOT+1 LSB = 0 00490 592E 79 00FC ROL XKQUOT 00500 5931 5A DVSHFT DEC B 00510 5932 27 12 BEQ DVDEND IF S = 0 STOP IF S>O SHIFT DIVIDEND 00520 5934 OC CLC 00530 5935 79 00FB XKDVND+1 ROL LEFT ONE BIT; LSB=0 00540 5938 79 00FA ROL XKDVND MSB INTO CARRY 00550 593B 95 FA LDA A XKDVND 00560 593D 25 DE BOA DVDLP2 IF C = 1 GO TO LOOP 2 DVDLP 7 00570 593F 20 D8 BRA GO TO LOOP 1 00580 5941 CE FFFF DVDERR #$FFFF LDX 00590 5944 DF FC STX XKQUOT 00600 5946 D6 FE DVDEND LDA B XKDSPL GET SHIFT COUNT INTO ACCB 00610 5948 CO 09 SUB B #9 XKDSPL = XKDSPL-9 XKDSPL 4 #4 00620 594A C1 04 CMP B 00630 5940 25 02 BCS DVDLP3 YES: GO TO RETURN NO: XKDSPL=XKDSPL-4 SUB B 00640 594E CO 04 #4 DISPLACEMENT OF REMAINDER DVDLP3 XKDSPL 00650 5950 D7 FE STA B 00660 STORED IN XKDSPL 00670 5952 39 RTS END 00680 ``` Figure 5-12 XKDIVD Assembly Listing (Sheet 2 of 2) # NOTE Section V is, by no means, comprehensive. It is intended to provide some examples that can be used as is or that will suggest the direction for modifying them for other specialized applications. | | | - | |---|--|--------| | | | | | | | | | | | ل ا | | | | 1 | | | | 1 | | • | | i<br>I | | | | 1 | | | | ! | | | | i<br>I | | | | | | | | 1 | | | | | | | | İ | | | | | | | | d | | | | | | | | | | | | : | | | | | | | | i | | | | | | | | | | | | : | | | | | | | | | | | | | | | | | | | | Ų | | | | : | | | | | | | | İ | ``` 00100 00200 00300 NAM PUNCH PUNCH MOTOROLA HEX FORMAT TAPES 00400 00500 USE MONITOR'S J COMMAND TO START EXECUTION * ENTER ADDRESS OF FIRST BYTE TO PUNCH * ENTER ADDRESS OF LAST BYTE TO PUNCH * MONITOR ROUTINES * ADDRESSES ARE FOR ACIA VERSION OF MONITOR ** OUTCH OUT2H BADDR OUTS CRLF SFF81 SFF6D SFF62 SFF82 SFFAB EQU EQU EQU EQU EQU 0000 ORG 0 * DATA RECORD FORMAT 9 3000 0D 0001 0A 00001 0A 00002 00 00004 531 00005 FF 02 00004 531 00006 FF 02 00008 00 00008 00 00008 00 00008 00 00008 00 00008 00 00008 00 00008 00 00008 00 00008 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 00010 00 FORM FCB $D,$A,0,0,'S,'1,$FF 2 2 1 GETADR BEGADR GETADR LASADR LEDTRL #FORM-1 BEGADR RMB LASADR RMB NUMBYT RMB BSR STX BSR 92699 32709 92899 93899 931999 931999 931999 931999 931999 94109 94109 94109 94109 94109 94109 94109 94109 94109 94109 94109 94109 94109 95109 95109 95109 95109 95109 95109 95109 95109 95109 95109 95109 95109 95109 95109 95109 95109 95109 FIRST ADDR TO PUNCH LAST ADDR TO PUNCH GET FIRST ADDR STORE IT GET LAST ADDR STORE IT PUNCH LEADER POINT TO PUNCH FORMAT PUN PUNØ X PUN1 OUTCH PUN0 LASADR+1 BEGADR+1 LASADR BEGADR BEBAG EING HIGH ORDER BIT SET - DONE PUNCH CHARACTER PUN1 SUB LOW ORDER BYTES SUB HIGH ORDER BYTES BEGADR PUN2 #16 PUN3 #15 NUMBYT #4 OUT2H LOTS MORE TO PUNCH LESS THAN 16 TO PUNCH? NO, SO PUNCH 16 STORE #OF BYTES TO PUNCH-1 PUN2 PUN3 PUNCH BYTE COUNT POINT TO BEGADE PUNCH ADDRESS PNCH2 PNCH2 BEGADR PNCH2 NUMBYT POINT TO DATA PUNCH DATA MORE TO PUNCH THIS RECORD? ``` continued over ``` 05700 0046 2A F9 05800 0048 DF 07 05900 004A 43 06000 004B BD F60D 06100 004E 09 06200 004F 9C 06300 0055 C6 C3 06500 0055 BD FF81 06600 0055 BD FF81 06600 0055 BD 87 07100 0055 BD 87 07100 0055 BD 87 07100 0055 BD 87 07100 0055 BD 87 07100 0055 BD 87 07500 0055 BD 87 07500 0055 BD 87 07500 0055 BD 75 07500 0055 BD 87 07500 0055 BD 87 07500 0055 BD 87 07500 0055 BD 87 07500 0055 BD 87 07500 0065 07600 0066 BD 87 07600 0066 BD 87 07600 0066 BD 87 07900 0076 BD 87 08800 0074 BD 87 08800 0075 BD 87 08800 0075 BD 87 08800 0075 BD 87 08800 0075 BB 87 08900 0075 BB 87 09900 0075 BD 07000 0075 BD 87 07000 0075 BD 87 07000 0075 BD 87 07000 0075 BD 87 07000 0075 BD 87 07000 007 PUN4 BEGADR BPL STX COM A JSR DEX CPX BNE LDA B JSR LDA B JSR BSR JMP STORE NEW START ADDRESS FORM 1'S COMP OF CHECKSUM PUNCH CHECKSUM ADJUST POINTER ARE WE DONE? NO, KEEP ON PUNCHING YES, PUNCH EOF OUT2H LASADR PUN #'S OUTCH #'9 OUTCH LEDTRL CRLF PUNCH TRAILER RETURN TO PROM MONITOR ** SUBROUTINE TO PUNCH 50 NULLS LEDTRL LDA A CLR B LED1 JSR DEC A BNE RTS #50 OUTCH PUNCH A NULL KEEP PUNCHING RETURN TO CALLER LED1 ** PUNCH 2 HEX DIGITS POINTED * TO BY X REG AND UPDATE CHECKSUM ** LDA B ABA PSH A TBA JSR PUL A INX RTS GET BYTE TO PUNCH UPDATE CHECKSUM SAVE CHECKSUM COPY BYTE TO A PUNCH BYTE RESTORE CHECKSUM BUMP BYTE POINTER RETURN TO CALLER OUT2H ** READ ADDRESS FORM TTY INTO X REG JSR LDA B JSR JSR RTS END OUTS # '? OUTCH BADDR SEND SPACE SEND QUESTION MARK GET ADDRESS RETURN TOTAL ERRORS 00000 ``` ``` NAM MEMITEST * ALTAIR 680B MEMORY TEST PROGRAM USE MONITOR'S J COMMAND TO START EXECUTION AT 0019 ** ENTER ADDRESS OF FIRST LOCATION TO TEST 900199 900110 900111 900121 900113 900114 900115 900116 900116 900117 900117 900118 900118 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 900119 90 * ENTER ADDRESS OF LAST ADDRESS TO TEST * MONITOR ROUTINES * ADDRESSES ARE FOR ACIA VERSION OF MONITOR ** OUTCH OUT2H BADDR OUTS MONIT ORG RMB RMB $14 1 1 STACK XHIGH XLOW LSTBYT X REG HIGH ORDER X REG LOW ORDER LAST BYTE TO CHECK RMB INIT STACK POINTER GET FIRST ADDR STORE IT GET LAST ADDR ADJUST IT STORE IT POINT TO FIRST BYTE #STACK GETADR XHIGH GETADR CO LSTBYT XHIGH X X OKMEM #%1101 OUTCH #@12 OUTCH XHIGH OUT2H XLOW OUT2H BUMP WRITE TEST PATTERN CHECK WRITTEN PATTERN DID WE READ WHAT WE WROTE? NO,SEND CR AND LF "@" STORE X REGISTER PRINT HIGH BYTE OF ADDRESS PRINT LOW BYTE OF ADDRESS LDA A JSR BRA INC B BNE DONE WITH THIS SYTE INCREMENT TEST PATTERN ALL PATTERNS TESTED? OKMEM NXTPAT INX CPX BNE BUMP YES, BUMP BYTE POINTER LSTBYT NXTBYT MONIT ALL BYTES TESTED? YES, RETURN TO PROM MONITOR SUBROUTINE TO GET ADDRESS INTO X REG 0053 BD FF82 0056 C6 3F 0058 BD FF81 0058 BD FF62 005E 39 OUTS #'? OUTCH BADDR JSR LDA B PRINT A SPACE PRINT A QUESTION MARK JSR JSR GET ADDRESS RETURN TO CALLING PROGRAM ``` TOTAL ERRORS 00000 ``` พดไสด 00200 00310 00400 * ALTAIR 680B HEXADECIMAL MEMORY DUMP PROGRAM * LOAD VIA PROM MONITOR USE MONITOR'S J COMMAND TO START EXECUTION AT 0005 * ENTER ADDRESS OF FIRST BYTE TO DUMP * ENTER ADDRESS OF LAST BYTE TO DUMP * TYPE ANY CHARACTER TO ABORT WHILE RUNNING * CONTROL RETURNS TO THE PROM MONITOR 01600 01700 01800 00F3 01900 00F3 FF 02000 02100 02200 TURN OFF TTY ECHO DURING LOAD * MONITOR ROUTINES * ADDRESSES ARE FOR ACIA VERSION OF MONITOR TEMP FOR HIGH SYTE OF X TEMP FOR LOW BYTE OF X ADDRESS OF LAST BYTE TO DUMP COLUMN COUNTER GET FIRST ADDR STORE IT GET LAST ADDR ADJUST IT FOINT TO FIRST BYTE SEND CRLF GETADR XHI GETADR LSTBYT LSTBYI XHI #@15 OUTCH #@12 OUTCH #17 COUNT XHI XHI OUT2H INIT COUNTER PRINT ADDRESS XLO OUT2H COUNT CRLF OUTS X OUT2H SEND A SPACE BYTE TO A PRINT IT BUMP POINTER ARE WE DONE? YES, RETURN TO MONITOR NO, WANT TO QUIT? LSTBYT JMONIT POLCAT NXTBYT $F001 MONIT YES, READ CHAR FROM BUFFER AND RETURN TO MONITOR WITH ADDRESS OUTCH BADDR SEND SPACE SEND QUESTION MARK GET ADDDRESS RETURN 0/400 07500 07600 00F3 07700 00F3 00 07800 * RESTORE TTY ECHO AFTER LOAD ORG ``` רם TOTAL ERRORS 00000 # appendix A Instruction Set | | · | | |--|---|--| | | | | | | | | | | | | # APPENDIX A **Definition of the Executable Instructions** # A.1 Nomenclature The following nomenclature is used in the subsequent definitions. - (a) Operators ()= contents of = is transferred to "is pulled from stack" = "is pushed into stack" = Boolean AND - = Boolean (Inclusive) OR **Exclusive OR** = Boolean NOT - (b) Registers in the MPU - ACCA = Accumulator A - ACCB = Accumulator B - ACCX = Accumulator ACCA or ACCB - CCCondition codes register ΙX Index register, 16 bits - IXH Index register, higher order 8 bits IXL Index register, lower order 8 bits - PC Program counter, 16 bits - PCH Program counter, higher order 8 bits PCL Program counter, lower order 8 bits - SP Stack pointer SPH = Stack pointer high SPL = Stack pointer low - (c) Memory and Addressing - = A memory location (one byte) - M + 1 = The byte of memory at 0001 plus the address of the memory location indicated by "M." - Rel = Relative address (i.e. the two's complement number stored in the second byte of machine code corresponding to a branch instruction. - (d) Bits 0 thru 5 of the Condition Codes Register | | | of the constitution could hegister | | |---|---|-------------------------------------|---------| | C | _ | Carry — borrow | bit 0 | | V | = | Two's complement overflow indicator | bit — 1 | | Z | = | Zero indicator | bit — 2 | | N | = | Negative indicator | bit 3 | | I | = | Interrupt mask | bit — 4 | | Н | = | Half carry | bit — 5 | | | | | | - (e) Status of Individual Bits BEFORE Execution of an Instruction - An = Bit n of ACCA (n=7,6,5,...,0) - Bn = Bit n of ACCB (n=7,6,5,...,0) - IXHn = Bit n of IXH (n=7,6,5,...,0) - IXLn = Bit n of IXL (n=7,6,5,...,0) - Mn = Bit n of M (n=7,6,5,...,0) - SPHn = Bit n of SPH (n=7,6,5,...,0) - SPLn = Bit n of SPL (n=7,6,5,...,0) - Xn = Bit n of ACCX (n=7,6,5,...,0) - (f) Status of Individual Bits of the RESULT of Execution of an Instruction - (i) For 8-bit Results - Rn = Bit n of the result (n = 7,6,5,...,0) This applies to instructions which provide a result contained in a single byte of memory or in an 8-bit register. - (ii) For 16-bit Results - RHn = Bit n of the more significant byte of the result - (n = 7, 6, 5, ..., 0) - RLn = Bit n of the less significant byte of the result - (n = 7, 6, 5, ..., 0) This applies to instructions which provide a result contained in two consecutive bytes of memory or in a 16-bit register. # A.2 Executable Instructions (definition of) Detailed definitions of the 72 executable instructions of the source language are provided on the following pages. # Add Accumulator B to Accumulator A **ABA** Operation: $ACCA \leftarrow (ACCA) + (ACCB)$ Description: Adds the contents of ACCB to the contents of ACCA and places the result in ACCA. Condition Codes: H: Set if there was a carry from bit 3; cleared otherwise. I: Not affected. N: Set if most significant bit of the result is set; cleared otherwise. Z: Set if all bits of the result are cleared; cleared otherwise. V: Set if there was two's complement overflow as a result of the operation; cleared otherwise. C: Set if there was a carry from the most significant bit of the result; cleared otherwise. Boolean Formulae for Condition Codes: $H = A_3.B_3+B_3.\overline{R}_3.+\overline{R}_3.A_3$ $N = R_7$ $N = R_7$ $Z = \overline{R}_7 \cdot \overline{R}_6 \cdot \overline{R}_5 \cdot \overline{R}_4 \cdot \overline{R}_3 \cdot \overline{R}_2 \cdot \overline{R}_1 \cdot \overline{R}_0$ $V = A_7 \cdot B_7 \cdot \overline{R}_7 + \overline{A}_7 \cdot \overline{B}_7 \cdot R_7$ $C = A_7 \cdot B_7 + B_7 \cdot \overline{R}_7 + \overline{R}_7 \cdot A_7$ | Addressing | Execution Time | Number of bytes of | Coding of First (or or byte of machine cod | | | |------------|-----------------|--------------------|--------------------------------------------|------|------| | Modes | (No. of cycles) | machine code | HEX. | ост. | DEC. | | Inherent | 2 | 1 | 1B | 033 | 027 | # **ADC** #### Add with Carry Operation: $ACCX \leftarrow (ACCX) + (M) + (C)$ Description: Adds the contents of the C bit to the sum of the contents of ACCX and M, and places the result in ACCX. Condition Codes: H Set if there was a carry from bit 3; cleared otherwise. 1: Not affected. N: Set if most significant bit of the result is set; cleared otherwise. Z: Set if all bits of the result are cleared; cleared otherwise. V: Set if there was two's complement overflow as a result of the operation; cleared otherwise. C: Set if there was a carry from the most significant bit of the result; cleared otherwise. Boolean Formulae for Condition Codes: $H = X_3.M_3 + M_3.\overline{R}_3 + \overline{R}_3.X_3$ $N = R_7$ $Z = \overline{R}_7.\overline{R}_6.\overline{R}_5.\overline{R}_4.\overline{R}_2.\overline{R}_2.\overline{R}_1.\overline{R}_0$ $V = X_7.M_7.\overline{R}_7 + \overline{X}_7.\overline{M}_7.R_7$ $C = X_7.M_7 + M_7.\overline{R}_7 + \overline{R}_7.X_7$ # Addressing Formats: See Table A-1 Addressing Modes, Execution Time, and Machine Code (hexadecimal/octal/ decimal): (DUAL OPERAND) | Add | lressing | Execution Time | Number of<br>hytes of | • | | Number of byte of machine co | | |-----|----------|-----------------|-----------------------|------|------|------------------------------|--| | 1 | lodes | (No. of cycles) | machine code | HEX. | OCT. | DEC. | | | Α | IMM | 2 | 2 | 89 | 211 | 137 | | | A | DIR | 3 | 2 | 99 | 231 | 153 | | | A | EXT | 4 | 3 | В9 | 271 | 185 | | | A | IND | 5 | 2 | A9 | 251 | 169 | | | В | IMM | 2 | 2 | C9 | 311 | 201 | | | В | DIR | 3 | 2 | D9 | 331 | 217 | | | В | EXT | 4 | 3 | F9 | 371 | 249 | | | В | IND | 5 | 2 | E9 | 351 | 233 | | # **Add Without Carry** # **ADD** Operation: $ACCX \leftarrow (ACCX) + (M)$ Description: Adds the contents of ACCX and the contents of M and places the results in ACCX. Condition Codes: H: Set if there was a carry from bit 3; cleared otherwise. I: Not affected. N: Set if most significant bit of the result is set; cleared otherwise. Z: Set if all bits of the result are cleared; cleared otherwise. V: Set if there was two's complement overflow as a result of the operation; cleared otherwise. C: Set if there was a carry from the most significant bit of the result; cleared otherwise. Boolean Formulae for Condition Codes: $H = X_3.M_3 + M_3.\overline{R}_3 + \overline{R}_3.X_3$ $N = R_7$ $Z = \overline{R}_7.\overline{R}_6.\overline{R}_5.\overline{R}_4.\overline{R}_3.\overline{R}_2.\overline{R}_1.\overline{R}_0$ $V = X_7.M_7.\overline{R}_7 + \overline{X}_7.\overline{M}_7.R_7$ $C = X_7.M_7 + M_7.\overline{R}_7 + \overline{R}_7.X_7$ #### Addressing Formats: See Table A-1 Addressing Modex, Execution Time, and Machine Code (hexadecimal/octal/ decimal); #### (DUAL OPERAND) | Add | lressing | Execution Time | | | of First (<br>f machin | | |-----|----------|-----------------|--------------|------|------------------------|------| | M | lodes | (No. of cycles) | machine code | HEX. | OCT. | DEC. | | Α | IMM | 2 | 2 | 8B | 213 | 139 | | Α | DIR | 3 | 2 | 9B | 233 | 155 | | Α | EXT | 4 | 3 | BB | 273 | 187 | | Α | IND | 5 | 2 | AB | 253 | 171 | | В | IMM | 2 | 2 | СВ | 313 | 203 | | В | DIR | 3 | 2 | DB | 333 | 219 | | В | EXT | 4 | 3 | FB | 373 | 251 | | В | IND | 5 | 2 | EB | 353 | 235 | # **AND** Logical AND Operation: $ACCX \leftarrow (ACCX) \cdot (M)$ Description: Performs logical "AND" between the contents of ACCX and the contents of M and places the result in ACCX. (Each bit of ACCX after the operation will be the logical "AND" of the corresponding bits of M and of ACCX before the operation.) Condition Codes: H: Not affected. I: Not affected. N: Set if most significant bit of the result is set; cleared otherwise. Z: Set if all bits of the result are cleared; cleared otherwise. V: Cleared. C: Not affected. Boolean Formulae for Condition Codes: $N = R_7$ $Z = \overline{R}_7 . \overline{R}_6 . \overline{R}_5 . \overline{R}_4 . \overline{R}_3 . \overline{R}_2 . \overline{R}_1 . \overline{R}_0$ V = 0 Addressing Formats: See Table A-1 | Add | ressing | Execution Time | Number of byte of machine of | | | | |-----|---------|-----------------|------------------------------|------|------|------| | | odes | (No. of cycles) | machine code | HEX. | OCT. | DEC. | | Α | IMM | 2 | 2 | 84 | 204 | 132 | | Α | DIR | 3 | 2 | 94 | 224 | 148 | | Α | EXT | 4 | 3 | B4 | 264 | 180 | | Α | IND | 5 | 2 | A4 | 244 | 164 | | В | IMM | 2 | 2 | C4 | 304 | 196 | | В | DIR | 3 | 2 | D4 | 324 | 212 | | В | EXT | 4 | 3 | F4 | 364 | 244 | | В | IND | 5 | 2 | E4 | 344 | 228 | #### Arithmetic Shift Left **ASL** Operation: Description: Shifts all bits of the ACCX or M one place to the left. Bit 0 is loaded with a zero. The C bit is loaded from the most significant bit of ACCX or M. Condition Codes: H: Not affected. - I: Not affected. - N: Set if most significant bit of the result is set; cleared - Z: Set if all bits of the result are cleared; cleared otherwise. - V: Set if, after the completion of the shift operation, EITHER (N is set and C is cleared) OR (N is cleared and C is set); cleared otherwise. - C: Set if, before the operation, the most significant bit of the ACCX or M was set; cleared otherwise. Boolean Formulae for Condition Codes: $\begin{array}{l} N = R_7 \\ Z = \overline{R}_7.\overline{R}_6.\overline{R}_5.\overline{R}_4.\overline{R}_3.\overline{R}_2.\overline{R}_1.\overline{R}_9 \\ V = N \ \oplus \ C = [N.\overline{C}] \bigodot [\overline{N}.C] \end{array}$ (the foregoing formula assumes values of N and C after the shift operation) $C = M_7$ Addressing Formats See Table A-3 | Addressing | Execution Time | Number of<br>bytes of<br>machine code | Coding of First (or onl<br>byte of machine code | | | |------------|-----------------|---------------------------------------|-------------------------------------------------|------|------| | Modes | (No. of cycles) | | HEX. | OCT. | DEC. | | Α | 2 | 1 | 48 | 110 | 072 | | В | 2 | 1 | 58 | 130 | 088 | | EXT | 6 | 3 | 78 | 170 | 120 | | IND | 7 | 2 | 68 | 150 | 104 | # **ASR** Operation: Description: Shifts all bits of ACCX or M one place to the right. Bit 7 is held constant. Bit 0 is loaded into the C bit. Condition Codes: H: Not affected. I: Not affected. - N: Set if the most significant bit of the result is set; cleared otherwise. - Z: Set if all bits of the result are cleared; cleared otherwise. - V: Set if, after the completion of the shift operation, EITHER (N is set and C is cleared) OR (N is cleared and C is set); cleared otherwise. - C: Set if, before the operation, the least significant bit of the ACCX or M was set; cleared otherwise. Boolean Formulae for Condition Codes: $N = \mathbf{R}_7$ $Z = \overline{\mathbf{R}}_7.\overline{\mathbf{R}}_6.\overline{\mathbf{R}}_5.\overline{\mathbf{R}}_4.\overline{\mathbf{R}}_3.\overline{\mathbf{R}}_2.\overline{\mathbf{R}}_1.\overline{\mathbf{R}}_6$ $V = N \oplus C = [N.\overline{C}.] \odot [\overline{N}.C]$ (the foregoing formula assumes values of N and C after the shift operation) $C = M_0$ Addressing Formats: See Table A-3 | Addressing | Execution Time | Number of<br>bytes of<br>machine code | Coding of First (or<br>byte of machine | | | |------------|-----------------|---------------------------------------|----------------------------------------|------|------| | | (No. of cycles) | | HEX. | OCT. | DEC. | | Α | 2 | 1 | 47 | 107 | 071 | | В | 2 | 1 | 57 | 127 | 087 | | EXT | 6 | 3 | 77 | 167 | 119 | | IND | 7 | 2 | 67 | 147 | 103 | # **Branch if Carry Clear** **BCC** Operation: $PC \leftarrow (PC) + 0002 + Rel \text{ if } (C)=0$ Description: Tests the state of the C bit and causes a branch if C is clear. See BRA instruction for further details of the execution of the branch. Condition Codes: Not affected. Addressing Formats: See Table A-8. Addressing Modes, Execution Time, and Machine Code (hexedecimal/octal/decimal): | Addressing | Execution Time (No. of cycles) | Number of<br>bytes of<br>machine code | Coding of First (or only)<br>byte of machine code | | | |------------|--------------------------------|---------------------------------------|---------------------------------------------------|------|------| | Modes | | | HEX. | ост. | DEC. | | REL. | 4 | 2 | 24 | 044 | 036 | # **Branch if Carry Set** **BCS** Operation: $PC \leftarrow (PC) + 0002 + Rel if (C)=1$ Description: Tests the state of the C bit and causes a branch if C is set. See BRA instruction for further details of the execution of the branch. Condition Codes: Not affected. Addressing Formats: See Table A-8. | Addressing | Execution Time | Number of bytes of | Coding of First ( | | | |------------|-----------------|--------------------|-------------------|------|------| | Modes | (No. of cycles) | machine code | HEX. | OCT. | DEC. | | REL | 4 | 2 | 25 | 045 | 037 | **BEQ** Branch if Equal Operation: $PC \leftarrow (PC) + 0002 + Rel \text{ if } (Z) = 1$ Description: Tests the state of the Z bit and causes a branch if the Z bit is set See BRA instruction for further details of the execution of the branch. Condition Codes: Not affected. Addressing Formats: See Table A-8. Addressing Modes, Execution Time, and Machine Code (hexadecimal/octal/ decimal): | Addressing<br>Modes | Execution Time (No. of cycles) | Number of bytes of | Coding of First (or only) byte of machine code | | | |---------------------|--------------------------------|--------------------|------------------------------------------------|------|------| | | | machine code | HEX. | OCT. | DEC. | | REL | 4 | 2 | 27 | 047 | 039 | # Branch if Greater than or Equal to Zero **BGE** Operation: $PC \leftarrow (PC) + 0002 + Rel if (N) \oplus (V) = 0$ i.e. if $(ACCX) \ge (M)$ (Two's complement numbers) Description: Causes a branch if (N is set and V is set) OR (N is clear and V is clear). If the BGE instruction is executed immediately after execution of any of the instructions CBA, CMP, SBA, or SUB, the branch will occur if and only if the two's complement number represented by the minuend (i.e. ACCX) was greater than or equal to the two's complement number represented by the subtrahend (i.e. M). See BRA instruction for details of the branch. Condition Codes: Not affected. Addressing Formats: See Table A-8. | Addressing | Execution Time | Number of bytes of | | of First (<br>f machin | | |------------|-----------------|--------------------|------|------------------------|------| | Modes | (No. of cycles) | machine code | HEX. | ост. | DEC. | | REL | 4 | 2 | 2C | 054 | 044 | **BGT** #### Branch if Greater than Zero Operation: $PC \leftarrow (PC) + 0002 + Rel \text{ if } (Z) \bigcirc [(N) \oplus (V)] = 0$ i.e. if (ACCX) > (M) (two's complement numbers) Description: Causes a branch if [ Z is clear ] AND [(N is set and V is set) OR (N is clear and V is clear)]. If the BGT instruction is executed immediately after execution of any of the instructions CBA, CMP, SBA, or SUB, the branch will occur if and only if the two's complement number represented by the minuend (i.e. ACCX) was greater than the two's complement number represented by the subtrahend (i.e. M). See BRA instruction for details of the branch. Condition Codes: Not affected. Addressing Formats: See Table A-8. | Addressing | Execution Time | Number of<br>bytes of | | Coding of First (<br>byte of machin | | |------------|-----------------|-----------------------|------|-------------------------------------|------| | Modes | (No. of cycles) | machine code | HEX. | OCT. | DEC. | | REL | 4 | 2 | 2E | 056 | 046 | # Branch if Higher BHI Operation: $PC \leftarrow (PC) + 0002 + Rel if (C)$ , (Z)=0 i.e. if (ACCX) > (M) (unsigned binary numbers) Description: Causes a branch if (C is clear) AND (Z is clear). If the BHI instruction is executed immediately after execution of any of the instructions CBA, CMP, SBA, or SUB, the branch will occur if and only if the unsigned binary number represented by the minuend (i.e. ACCX) was greater than the unsigned binary number represented by the subtrahend (i.e. M). See BRA instruction for details of the execution of the branch. Not affected. Condition Codes: Addressing Formats: See Table A-8. Addressing Modes, Execution Time, and Machine Code (hexadecimal/octal/ decimal): | Addressing | Execution Time | Number of bytes of | _ | oding of First ( | | |------------|-----------------|--------------------|------|------------------|------| | Modes | (No. of cycles) | machine code | HEX. | OCT. | DEC. | | REL | 4 | 2 | 22 | 042 | 034 | BIT Bit Test Operation: $(ACCX) \cdot (M)$ Description: Performs the logical "AND" comparison of the contents of ACCX and the contents of M and modifies condition codes accordingly. Neither the contents of ACCX or M operands are affected. (Each bit of the result of the "AND" would be the logical "AND" of the corresponding bits of M and ACCX.) Condition Codes: H: Not affected. I: Not affected. N: Set if the most significant bit of the result of the "AND" would be set; cleared otherwise. Z: Set if all bits of the result of the "AND" would be cleared; cleared otherwise. V: Cleared. C: Not affected. Boolean Formulae for Condition Codes: $\begin{array}{l} N = R_7 \\ Z = \overline{R}_7.\overline{R}_6.\overline{R}_5.\overline{R}_4.\overline{R}_3.\overline{R}_2.\overline{R}_1.\overline{R}_0 \end{array}$ V = 0 Addressing Formats: See Table A-1. | Addm | occi <b>n</b> a | Execution Time | Number of bytes of | Coding of First (<br>byte of machin | | | |---------------------|-----------------|----------------|--------------------|-------------------------------------|------|-----| | Addressing<br>Modes | (No. of cycles) | machine code | HEX. | OCT. | DEC. | | | | IMM | 2 | 2 | 85 | 205 | 133 | | Α | DIR | . 3 | 2 | 95 | 225 | 149 | | Α | EXT | 4 | 3 | B5 | 265 | 181 | | Α | IND | 5 | 2 | A5 | 245 | 165 | | В | IMM | 2 | 2 | C5 | 305 | 197 | | В | DÌR | 3 | 2 | D5 | 325 | 213 | | В | EXT | 4 | 3 | F5 | 365 | 245 | | В | IND | 5 | 2 | E5 | 345 | 229 | # Branch if Less than or Equal to Zero BLE Operation: $PC \leftarrow (PC) + 0002 + Rel \text{ if } (Z) \bigcirc [(N) \bigoplus (V)] = I$ i.e. if $(ACCX) \leq (M)$ (two's complement numbers) Description: Causes a branch if [Z is set] OR [(N is set and V is clear) OR (N is clear and V is set)]. If the BLE instruction is executed immediately after execution of any of the instructions CBA, CMP, SBA, or SUB, the branch will occur if and only if the two's complement number represented by the minuend (i.e. ACCX) was less then or equal to the two's complement number represented by the subtrahend (i.e. M). See BRA instruction for details of the branch. Condition Codes: Not affected. Addressing Formats: See Table A-8. | Addressing | Execution Time | Number of bytes of | Coding of First (or byte of machine | | | |------------|-----------------|--------------------|-------------------------------------|------|------| | Modes | (No. of cycles) | machine code | HEX. | ост. | DEC. | | REL | 4 | 2 | 2F | 057 | 047 | **BLS** Branch if Lower or Same Operation: $PC \leftarrow (PC) + 0002 + Rel \text{ if } (C)\bigcirc(Z) = 1$ i.e. if $(ACCX) \le (M)$ (unsigned binary numbers) Description: Causes a branch if (C is set) OR (Z is set). If the BLS instruction is executed immediately after execution of any of the instructions CBA, CMP, SBA, or SUB, the branch will occur if and only if the unsigned binary number represented by the minuend (i.e. ACCX) was less than or equal to the unsigned binary number represented by the subtrahend (i.e. M). See BRA instruction for details of the execution of the branch. Condition Codes: Not affected. Addressing Formats: See Table A-8. | Addressing | Execution Time | Number of | | Coding of First ( byte of machin | | |------------|-----------------|--------------|------|----------------------------------|------| | Modes | (No. of cycles) | machine code | HEX. | OCT. | DEC. | | REL | 4 | 2 | 23 | 043 | 035 | #### Branch if Less than Zero **BLT** Operation: $PC \leftarrow (PC) + 0002 + Rel if (N) \oplus (V) = 1$ i.e. if (ACCX) < (M) (two's complement numbers) Description: Causes a branch if (N is set and V is clear) OR (N is clear and V is set). If the BLT instruction is executed immediately after execution of any of the instructions CBA, CMP, SBA, or SUB, the branch will occur if and only if the two's complement number represented by the minuend (i.e. ACCX) was less than the two's complement number represented by the subtrahend (i.e. M). See BRA instruction for details of the branch. Condition Codes: Not affected. Addressing Formats: See Table A-8. | Addressing | Execution Time | Number of bytes of | byte of machin | | | |------------|-----------------|--------------------|----------------|------|------| | Modes | (No. of cycles) | machine code | HEX. | OCT. | DEC. | | REL | 4 | 2 | 2D | 055 | 045 | **BMI** **Branch if Minus** Operation: PC+- (PC) + 0002 + Rel if (N) = 1 Description: Tests the state of the N bit and causes a branch if N is set. See BRA instruction for details of the execution of the branch. Condition Codes: Not affected. Addressing Formats: See Table A-8. Addressing Modes, Execution Time, and Machine Code (hexadecimal/octal/decimal): | Addressing | Execution Time | Number of<br>bytes of | | of First (<br>f machin | (or only)<br>e code | |------------|-----------------|-----------------------|------|------------------------|---------------------| | Modes | (No. of cycles) | machine code | HEX. | ост. | DEC. | | REL | 4 | 2 | 2B | 053 | 043 | **BNE** Branch if Not Equal Operation: $PC \leftarrow (PC) + 0002 + Rel \text{ if } (Z) = 0$ Description: Tests the state of the Z bit and causes a branch if the Z bit is clear. See BRA instruction for details of the execution of the Branch. Condition Codes: Not affected. Addressing Formats: See Table A-8. | | Addressing | Execution Time | Number of bytes of | | of First<br>f machin | (or only)<br>ne code | |---|------------|-----------------|--------------------|------|----------------------|----------------------| | l | Modes | (No. of cycles) | machine code | HEX. | ост. | DEC. | | Ì | REL | 4 | 2 | 26 | 046 | 038 | **Branch if Plus** **BPL** Operation: $PC \leftarrow (PC) + 0002 + Rel if (N) = 0$ Description: Tests the state of the N bit and causes a branch if N is clear. See BRA instruction for details of the execution of the branch. Condition Codes: Not affected. Addressing Formats: See Table A-8. Addressing Modes, Execution Time, and Machine Code (hexadecimal/octal/ decimal): | Addressing | Execution Time | Number of<br>bytes of | | Coding of First (obyte of machine | | |------------|-----------------|-----------------------|------|-----------------------------------|------| | Modes | (No. of cycles) | machine code | HEX. | HEX. OCT. | DEC. | | REL | 4 | 2 | 2A | 052 | 042 | # **Branch Always** **BRA** Operation: $PC \leftarrow (PC) + 0002 + Rel$ Description: Unconditional branch to the address given by the foregoing formula, in which R is the relative offset stored as a two's complement number in the second byte of machine code corresponding to the branch instruction. Note: The source program specifies the destination of any branch instruction by its absolute address, either as a numerical value or as a symbol or expression which can be numerically evaluated by the assembler. The assembler obtains the relative address R from the absolute address and the current value of the program counter PC. Condition Codes: Not affected. Addressing Formats: See Table A-8. | Addressing | Execution Time | Number of<br>bytes of | | Coding of First (or only byte of machine code HEX. OCT. DEC. | | |------------|-----------------|-----------------------|------|--------------------------------------------------------------|-----| | Modes | (No. of cycles) | machine code | HEX. | | | | REL | 4 | 2 | 20 | 040 | 032 | # **BSR** #### **Branch to Subroutine** Operation: PC ← (PC) ± 0002 ↓ (PCL) $SP \leftarrow (SP) - 0001$ ↓ (PCH) $SP \leftarrow (SP) - 0001$ $PC \leftarrow (PC) + Rel$ Description: The program counter is incremented by 2. The less significant byte of the contents of the program counter is pushed into the stack. The stack pointer is then decremented (by 1). The more significant byte of the contents of the program counter is then pushed into the stack. The stack pointer is again decremented (by 1). A branch then occurs to the location specified by the program. SEE BRA instruction for details of the execution of the branch. Condition Codes: Not affected. Addressing Formats: See Table A-8. | Addressing | Execution Time | Number of bytes of | | of First<br>f machin | (or only)<br>e code | | |------------|-----------------|--------------------|------|----------------------|---------------------|--| | Modes | (No. of cycles) | machine code | HEX. | ост. | DEC. | | | REL | 8 | 2 | 8D | 215 | 141 | | # Branch to Subroutine # **EXAMPLE** | | | | Memory<br>Location | Machine<br>Code (Hex) | Assembler Language<br>Label Operator Operand | | | | |----|--------|--------------|--------------------|-----------------------|----------------------------------------------|----------|---------|--| | Α. | Before | p | | | Lanci | Operator | Operand | | | | PC | ์ ← | \$1000<br>\$1001 | 8D<br>50 | | BSR | CHARLI | | | | SP | <b>←</b> | \$EFFF | | | | | | | В. | After | | | | | | | | | | PC | $\leftarrow$ | \$1052 | ** | CHARLI | *** | ***** | | | | SP | <b>←</b> | \$EFFD | | | | | | | | | | \$EFFE | 10 | | | | | | | | | \$EFFF | 02 | | | | | # Branch if Overflow Clear **BVC** Operation: $PC \leftarrow (PC) + 0002 + Rel \text{ if } (V) = 0$ Description: Tests the state of the V bit and causes a branch if the V bit is clear. See BRA instruction for details of the execution of the branch. Condition Codes: Not affected. Addressing Formats: See Table A-8. | Addressing | Execution Time | Number of bytes of | Coding of First (or only)<br>byte of machine code | | | |------------|-----------------|--------------------|---------------------------------------------------|------|------| | Modes | (No. of cycles) | machine code | HEX. | OCT. | DEC. | | REL | 4 | 2 | 28 | 050 | 040 | **BVS** Branch if Overflow Set Operation: $PC \leftarrow (PC) + 0002 + Rel \text{ if } (V) = 1$ Description: Tests the state of the V bit and causes a branch if the V bit is See BRA instruction for details of the execution of the branch. Condition Codes: Not affected. Addressing Formats: | Addressing | Execution Time | Number of<br>bytes of | Coding of First (or only)<br>byte of machine code | | | | |------------|-----------------|-----------------------|---------------------------------------------------|------|------|--| | Modes | (No. of cycles) | machine code | HEX. | ост. | DEC. | | | REL | 4 | 2 | 29 | 051 | 041 | | # **Compare Accumulators** **CBA** Operation: (ACCA) - (ACCB) Description: Compares the contents of ACCA and the contents of ACCB and sets the condition codes, which may be used for arithmetic and logical conditional branches. Both operands are unaffected. Condition Codes: H: Not affected. I: Not affected. N: Set if the most significant bit of the result of the subtraction would be set; cleared otherwise. Z: Set if all bits of the result of the subtraction would be cleared; cleared otherwise. V: Set if the subtraction would cause two's complement overflow; cleared otherwise. C: Set if the subtraction would require a borrow into the most significant bit of the result; clear otherwise. Boolean Formulae for Condition Codes: $\begin{aligned} N &= R_7 \\ Z &= \overline{R}_7.\overline{R}_6.\overline{R}_5.\overline{R}_4.\overline{R}_3.\overline{R}_2.\overline{R}_1.\overline{R}_0 \end{aligned}$ $V = A_7, \overline{B}_7, \overline{R}_7 + \overline{A}_7, B_7, R_7$ $C = \overline{A}_7.B_7 + B_7.R_7 + R_7.\overline{A}_7$ | Addressing | Execution Time | Number of bytes of | Coding of First (or only) byte of machine code | | | | |------------|-----------------|--------------------|------------------------------------------------|------|------|--| | Modes | (No. of cycles) | machine code | HEX. | OCT. | DEC. | | | INHERENT | 2 | 1 | 11 | 021 | 017 | | # **CLC** # Clear Carry Operation: C bit ← 0 Description: Clears the carry bit in the processor condition codes register. Condition Codes: H: Not affected. I: Not affected. N: Not affected. Z: Not affected. V: Not affected. C: Cleared Boolean Formulae for Condition Codes: C = 0 Addressing Modes, Execution Time, and Machine Code (hexadecimal/octal/ decimal): | Addressing | Execution Time | Number of bytes of | Coding of First (or only)<br>byte of machine code | | | | |------------|-----------------|--------------------|---------------------------------------------------|------|------|--| | Modes | (No. of cycles) | machine code | HEX. | OCT. | DEC. | | | INHERENT | 2 | 1 | 0C | 014 | 012 | | # CLI # Clear Interrupt Mask Operation: I bit $\leftarrow 0$ Description: Clears the interrupt mask bit in the processor condition codes register. This enables the microprocessor to service an interrupt from a peripheral device if signalled by a high state of the "Interrupt Request" control input. Condition Codes: H: Not affected. I: Cleared. N: Not affected. Z: Not affected. V: Not affected. C: Not affected. Boolean Formulae for Condition Codes: | Addressing | Execution Time | Number of bytes of | Coding of First (or only)<br>byte of machine code | | | | |------------|-----------------|--------------------|---------------------------------------------------|------|------|--| | Modes | (No. of cycles) | machine code | HEX. | ост. | DEC. | | | INHERENT | 2 | 1 | 0E | 016 | 014 | | ### Clear # **CLR** Operation: $\mathsf{ACCX} \gets 00$ or: $M \leftarrow 00$ Description: The contents of ACCX or M are replaced with zeros. Condition Codes: H: Not affected. I: Not affected. N: Cleared Z: Set V: Cleared C: Cleared Boolean Formulae for Condition Codes: N = 0Z = 1 $\mathbf{V} = \mathbf{0}$ $\mathbf{C} = \mathbf{0}$ Addressing Formats: See Table A-3. | Addressing | Execution Time | Number of bytes of | Coding of First (or or<br>byte of machine cod | | | |------------|-----------------|--------------------|-----------------------------------------------|------|------| | Modes | (No. of cycles) | machine code | HEX. | ост. | DEC. | | Α | 2 | 1 | 4F | 117 | 079 | | В | 2 | 1 | 5F | 137 | 095 | | EXT | 6 | 3 | 7 <b>F</b> | 177 | 127 | | IND | 7 | 2 | 6F | 157 | 111 | # **CLV** ### Clear Two's Complement Overflow Bit Operation: V bit ← 0 Description: Clears the two's complement overflow bit in the processor condition codes register. Condition Codes: H: Not affected. l: Not affected. N: Not affected. Z: Not affected. V: Cleared. C: Not affected. Boolean Formulae for Condition Codes: V = 0 | 434 | E Tri | Coding of byte of n | | | | |---------------------|--------------------------------|---------------------|------|------|------| | Addressing<br>Modes | Execution Time (No. of cycles) | machine code | HEX. | ост. | DEC. | | INHERENT | 2 | 1 | 0A | 012 | 010 | ### Compare **CMP** Operation: (ACCX) - (M) Description: Compares the contents of ACCX and the contents of M and determines the condition codes, which may be used subsequently for controlling conditional branching. Both operands are unaffected. Condition Codes: H: Not affected. I: Not affected. N: Set if the most significant bit of the result of the subtraction would be set; cleared otherwise. Z: Set if all bits of the result of the subtraction would be cleared; cleared otherwise. V. Set if the subtraction would cause two's complement overflow; cleared otherwise. C: Carry is set if the absolute value of the contents of memory is larger than the absolute value of the accumulator, reset otherwise. Boolean Formulae for Condition Codes: $N = R_7$ $Z = \overline{R}_7.\overline{R}_6.\overline{R}_5.\overline{R}_4.\overline{R}_3.\overline{R}_2.\overline{R}_1.\overline{R}_0$ $V = \underline{X}_7.\overline{M}_7.\overline{R}_7 + \overline{X}_7.M_7.R_7$ $C = \overline{X}_7.M_7 + M_7.R_7.R_7.\overline{X}_7$ Addressing Formats: See Table A-1. Addressing Modes, Execution Time, and Machine Code (hexadecimal/octal/ (DUAL OPERAND) | Addressing | | Iressing Execution Time | Number of<br>bytes of | Coding of First (or only) byte of machine code | | | |------------|-------|------------------------------|-----------------------|------------------------------------------------|------|-----| | Mod | | (No. of cycles) machine code | HEX. | OCT. | DEC. | | | A I | MM | 2 | 2 | 81 | 201 | 129 | | A l | IDR [ | 3 | 2 | 91 | 221 | 145 | | A E | EXT | 4 | 3 | Bi | 261 | 177 | | A I | IND | 5 | 2 | Αī | 241 | 161 | | В | MM | 2 | 2 | C1 | 301 | 193 | | ВІ | DIR | 3 | 2 | DI | 321 | 209 | | ВЕ | EXT | 4 | 3 | F1 | 361 | 241 | | BI | ND | 5 | 2 | El | 341 | 225 | # COM Complement Operation: $ACCX \leftarrow \approx (ACCX) = FF - (ACCX)$ $M \leftarrow \approx (M) = FF - (M)$ Description: Replaces the contents of ACCX or M with its one's complement. (Each bit of the contents of ACCX or M is replaced with the complement of that bit.) Condition Codes: H: Not affected. I: Not affected. N: Set if most significant bit of the result is set; cleared Z: Set if all bits of the result are cleared; cleared otherwise. V: Cleared. C: Set. Boolean Formulae for Condition Codes: $N = R_7$ $Z = \overline{R}_7.\overline{R}_6.\overline{R}_5.\overline{R}_4.\overline{R}_3.\overline{R}_2.\overline{R}_1.\overline{R}_0$ V = 0 C = 1 Addressing Formats: See Table A-3. | A ddunasia a | Execution Time | Number of bytes of | Coding of First (<br>byte of machin | | | | |---------------------|-----------------|--------------------|-------------------------------------|------|------|--| | Addressing<br>Modes | (No. of cycles) | machine code | нех. ост. | OCT. | DEC. | | | A | 2 | 1 | 43 | 103 | 067 | | | В | 2 | 1 | 53 | 123 | 083 | | | ĘХТ | 6 | 3 | 73 | 163 | 115 | | | IND | 7 | 2 | 63 | 143 | 099 | | #### Compare Index Register **CPX** Operation: (IXL) (M+1) (IXH) · (M) Description: The more significant byte of the contents of the index register is compared with the contents of the byte of memory at the address specified by the program. The less significant byte of the contents of the index register is compared with the contents of the next byte of memory, at one plus the address specified by the program. The Z bit is set or reset according to the results of these comparisons, and may be used subsequently for conditional branching. The N and V bits, though determined by this operation, are not intended for conditional branching. The C bit is not affected by this operation. Condition Codes: H: Not affected. I: Not affected. N: Set if the most significant bit of the result of the subtraction from the more significant byte of the index register would be set; cleared otherwise. Z: Set if all bits of the results of both subtractions would be cleared; cleared otherwise. V: Set if the subtraction from the more significant byte of the index register would cause two's complement over- flow; cleared otherwise. C: Not affected. Boolean Formulae for Condition Codes: $N = RH_7$ $Z = (\overline{RH_7}.\overline{RH_6}.\overline{RH_5}.\overline{RH_4}.\overline{RH_3}.\overline{RH_2}.\overline{RH_1}.\overline{RH_6}),$ $(\overline{RL_7}.\overline{RL_6}.\overline{RL_5}.\overline{RL_4}.\overline{RL_3}.\overline{RL_2}.\overline{RL_1}.\overline{RL_0})$ $V = IXH_7.\overline{M}_7.\overline{RH}_7 + \overline{IXH}_7.M_7.RH_7$ Addressing Formats: See Table A-5. | ۸ باطامیونام د | Function Time | Number of | Coding of First (<br>byte of machine | | | | |---------------------|--------------------------------|--------------------------|--------------------------------------|------|------|--| | Addressing<br>Modes | Execution Time (No. of cycles) | bytes of<br>machine code | HEX. | ост. | DEC. | | | IMM | 3 | 3 | 8C | 214 | 140 | | | DIR | 4 | 2 | 9C | 234 | 156 | | | EXT | 5 | 3 | BC | 274 | 188 | | | IND | 6 | 2 | AC | 254 | 172 | | Operation: Adds hexadecimal numbers 00, 06, 60, or 66 to ACCA, and may also set the carry bit, as indicated in the following table: | State<br>C-bit<br>before<br>DAA<br>(Col. 1) | Upper<br>Half-byte<br>(bits 4-7)<br>(Col. 2) | Initial<br>Half-carry<br>H-bit<br>(Col. 3) | Lower<br>Haif-byte<br>(bits 0-3)<br>(Col. 4) | Number<br>Added<br>to ACCA<br>by DAA<br>(Col. 5) | State of<br>C-bit<br>after<br>DAA<br>(Col. 6) | |---------------------------------------------|----------------------------------------------|--------------------------------------------|----------------------------------------------|--------------------------------------------------|-----------------------------------------------| | 0 | 0-9 | 0 | 0-9 | 00 | 0 | | 0 | 0-8 | 0 | A-F | 06 | 0 | | 0 | 0-9 | 1 | 0-3 | 06 | 0 | | 0 | A-F | 0 | 0-9 | 60 | 1 | | 0 | 9-F | 0 | A-F | 66 | 1 | | 0 | A-F | 1 | 0-3 | 66 | 1 | | 1 | 0-2 | 0 | 0-9 | 60 | 1 | | 1 | 0-2 | 0 | A-F | 66 | 1 | | 1 | 0-3 | 1 | 0-3 | 66 | 1 | Note: Columns (1) to (4) of the above table represent all possible cases which can result from any of the operations ABA, ADD, or ADC, with initial carry either set or clear, applied to two binary-coded-decimal operands. The table shows hexadecimal values. Description: If the contents of ACCA and the state of the carry-borrow bit C and the half-carry bit H are all the result of applying any of the operations ABA, ADD, or ADC to binary-coded-decimal operands, with or without an initial carry, the DAA operation will function as follows. Subject to the above condition, the DAA operation will adjust the contents of ACCA and the C bit to represent the correct binary-coded-decimal sum and the correct state of the carry. Condition Codes: H: Not affected. - I: Not affected. - N: Set if most significant bit of the result is set; cleared otherwise. - Z: Set if all bits of the result are cleared; cleared otherwise. - V: Not defined. - C: Set or reset according to the same rule as if the DAA and an immediately preceding ABA, ADD, or ADC were replaced by a hypothetical binary-coded-decimal addition. Boolean Formulae for Condition Codes: $\overline{R}_7, \overline{R}_0, \overline{R}_5, \overline{R}_4, \overline{R}_3, \overline{R}_2, \overline{R}_1, \overline{R}_0$ C: See table above. | Addressing | Execution Time | Number of bytes of | Coding of byte of r | | | |------------|-----------------|--------------------|---------------------|------|------| | Modes | (No. of cycles) | machine code | HEX. | OCT. | DEC. | | INHERENT | 2 | 1 | 19 | 031 | 025 | #### Decrement **DEC** Operation: $ACCX \leftarrow (ACCX) - 01$ or: $M \leftarrow (M) - 01$ Description: Subtract one from the contents of ACCX or M. The N, Z, and V condition codes are set or reset according to the results of this operation. The C bit is not affected by the operation. Condition Codes: H: Not affected. I: Not affected. N: Set if most significant bit of the result is set; cleared otherwise. Z: Set if all bits of the result are cleared; cleared otherwise. V: Set if there was two's complement overflow as a result of the operation; cleared otherwise. Two's complement overflow occurs if and only if (ACCX) or (M) was 80 before the operation. C: Not affected. Boolean Formulae for Condition Codes: $\begin{array}{l} N = R_7 \\ Z = \overline{R}_7.\overline{R}_6.\overline{R}_5.\overline{R}_5.\overline{R}_4.\overline{R}_3.\overline{R}_2.\overline{R}_1.\overline{R}_6 \\ V = X_7.\overline{X}_6.\overline{X}_5.\overline{X}_4.\overline{X}_3.\overline{X}_2.\overline{X}_6 + \overline{R}_7.R_6.R_5R_4.R_3.R_2.R_1.R_0 \end{array}$ Addressing Formats: See Table A-3. | Addressing | Execution Time | Number of<br>bytes of | Coding of First<br>byte of mach | | | | |------------|-----------------|-----------------------|---------------------------------|------|------|--| | Modes | (No. of cycles) | machine code | HEX. | ост. | DEC. | | | Α | 2 | 1 | 4A | 112 | 074 | | | В | 2 | Ī | 5A | 132 | 090 | | | EXT | 6 | 3 | 7A | 172 | 122 | | | IND | 7 | 2 | 6A | 152 | 106 | | **DES** **Decrement Stack Point** Operation: $SP \leftarrow (SP) - 0001$ Description: Subtract one from the stack pointer. Condition Codes: Not affected. Addressing Modes, Execution Time, and Machine Code (hexadecimal/octal/ decimal); | Addressing | Execution Time | Number of bytes of | Coding of First (<br>byte of machin | | • 1 | |------------|-----------------|--------------------|-------------------------------------|------|------| | Modes | (No. of cycles) | machine code | HEX. | ост. | DEC. | | INHERENT | 4 | 1 | 34 | 064 | 052 | **DEX** **Decrement Index Register** Operation: $IX \leftarrow (IX) - 0001$ Description: Subtract one from the index register Only the Z bit is set or reset according to the result of this operation. Condition Codes: H: Not affected I: Not affected. N: Not affected. Z: Set if all bits of the result are cleared; cleared otherwise. V: Not affected. C: Not affected. Boolean Formulae for Condition Codes: $Z = (\overline{RH_7}.\overline{RH_6}.\overline{RH_5}.\overline{RH_4}.\overline{RH_8}.\overline{RH_2}.\overline{RH_1}.\overline{RH_0}).$ $(RL_7.RL_6.RL_5.RL_4.RL_3.RL_2.RL_1.RL_0)$ | Addressing | Execution Time | Number of bytes of bytes of | | | | |------------|-----------------|-----------------------------|------|------|------| | Modes | (No. of cycles) | machine code | HEX. | ост. | DEC. | | INHERENT | 4 | 1 | 09 | 011 | 009 | ### **Exclusive OR** **EOR** Operation: $ACCX \leftarrow (ACCX) \oplus (M)$ Description: Perform logical "EXCLUSIVE OR" between the contents of ACCX and the contents of M, and place the result in ACCX. (Each bit of ACCX after the operation will be the logical (EXCLUSIVE OR" of the corresponding bits of M and ACCX before the operation.) Condition Codes: H: Not affected. I: Not affected. N: Set if most significant bit of the result is set; cleared otherwise. Z: Set if all bits of the result are cleared; cleared otherwise. V: Cleared C: Not affected. Boolean Formulae for Condition Codes: $N\,=\,R\tau$ $Z = \overline{R}_7.\overline{R}_6.\overline{R}_5.\overline{R}_4.\overline{R}_3.\overline{R}_2.\overline{R}_1.\overline{R}_0$ V = 0 Addressing Formats: See Table A-1. | | | Number of | | Coding of First (or only)<br>byte of machine code | | | |---|-------------------|--------------------------------|-----------------------|---------------------------------------------------|------|------| | | lressing<br>Iodes | Execution Time (No. of cycles) | bytes of machine code | HEX. | ост. | DEC. | | Α | IMM | 2 | 2 | 88 | 210 | 136 | | Α | DIR | 3 | 2 | 98 | 230 | 152 | | Α | EXT | 4 | 3 | B8 | 270 | 184 | | Α | IND | 5 | 2 | A8 | 250 | 168 | | В | IMM | 2 | 2 | C8 | 310 | 200 | | В | DIR | 3 | 2 | D8 | 330 | 216 | | В | EXT | 4 i | 3 | F8 | 370 | 248 | | В | IND | 5 | 2 | E8 | 350 | 232 | INC Increment Operation: $ACCX \leftarrow (ACCX) + 01$ $M \leftarrow (M) + 01$ Description: Add one to the contents of ACCX or M. The N, Z, and V condition codes are set or reset according to the results of this operation. The C bit is not affected by the operation. Condition Codes: H: Not affected. I: Not affected. N: Set if most significant bit of the result is set; cleared otherwise. Z: Set if all bits of the result are cleared; cleared otherwise. V: Set if there was two's complement overflow as a result of the operation; cleared otherwise. Two's complement overflow will occur if and only if (ACCX) or (M) was 7F before the operation. C: Not affected. Boolean Formulae for Condition Codes: $N = R_7$ $Z = \overline{R}_7.\overline{R}_6.\overline{R}_5.\overline{R}_4.\overline{R}_3.\overline{R}_2.\overline{R}_1.\overline{R}_0$ $V = \overline{X}_{7}.X_{6}.X_{5}.X_{4}.X_{3}.X_{2}.X_{1}.X_{0}$ = $\overline{R}_{7}.\overline{R}_{6}.\overline{R}_{5}.\overline{R}_{4}.\overline{R}_{3}.\overline{R}_{2}.\overline{R}_{1}.\overline{R}_{0}$ Addressing Formats: See Table A-3. | Addressing | Execution Time | Number of<br>bytes of | Coding of First (<br>byte of machin | | | | |------------|-----------------|-----------------------|-------------------------------------|------|------|--| | Modes | (No. of cycles) | machine code | HEX. | ост. | DEC. | | | A | 2 | 1 | 4C | 114 | 076 | | | В | 2 | 1 | 5C | 134 | 092 | | | EXT | 6 | 3 | 7C | 174 | 124 | | | IND | 7 | 2 | 6C | 154 | 108 | | # **Increment Stack Pointer** INS Operation: $SP \leftarrow (SP) + 0001$ Description: Add one to the stack pointer. Condition Codes: Not affected. Addressing Modes, Execution Time, and Machine Code (hexadecimal/octal/decimal): | Addressing | Execution Time | Number of bytes of | Coding of First (or only)<br>byte of machine code | | | |------------|-----------------|--------------------|---------------------------------------------------|-----|------| | Modes | (No. of cycles) | machine code | HEX. OCT. DEC | | DEC. | | INHERENT | 4 | 1 | 31 | 061 | 049 | ### Increment Index Register **INX** Operation: $1X \leftarrow (IX) + 0001$ Description: Add one to the index register. Only the Z bit is set or reset according to the result of this operation. Condition Codes: H: Not affected. I: Not affected. N: Not affected. Z: Set if all 16 bits of the result are cleared; cleared other- wise. V: Not affected. C: Not affected. Boolean Formulae for Condition Codes: $Z = (\overline{RH}_7.\overline{RH}_6.\overline{RH}_5.\overline{RH}_4.\overline{RH}_3.\overline{RH}_2.\overline{RH}_1.\overline{RH}_0).$ $(\overline{RL}_7.\overline{RL}_6.\overline{RL}_5.\overline{RL}_4.\overline{RL}_3.\overline{RL}_2.\overline{RL}_1.\overline{RL}_0)$ | Addressing | Execution Time | Number of<br>bytes of | Coding of First (or only)<br>byte of machine code | | | | |------------|-----------------|-----------------------|---------------------------------------------------|------|------|--| | Modes | (No. of cycles) | machine code | HEX. | ост. | DEC. | | | INHERENT | 4 | l l | 08 | 010 | 008 | | **JMP** Jump Operation: PC ← numerical address Description: A jump occurs to the instruction stored at the numerical address. The numerical address is obtained according to the rules for EXTended or INDexed addressing. Condition Codes: Not affected. Addressing Formats: See Table A-7. | Addressing | Execution Time | Number of bytes of | | of First (<br>f machin | (or only)<br>ie code | |------------|-----------------|--------------------|------|------------------------|----------------------| | Modes | (No. of cycles) | machine code | HEX. | OCT. | DEC. | | EXT | 3 | 3 | 7E | 176 | 126 | | IND | 4 | 2 | 6E | 156 | 110 | # Jump to Subroutine **JSR** Operation: Either: PC ← (PC) + 0003 (for EXTended addressing) PC ← (PC) + 0002 (for INDexed addressing) or: Then: ↓ (PCL) $SP \leftarrow (SP) - 0001$ ↓ (PCH) SP ← (SP) − 0001 PC ← numerical address Condition Codes: Not affected. Description: The program counter is incremented by 3 or by 2, depending on the addressing mode, and is then pushed onto the stack, eight bits at a time. The stack pointer points to the next empty location in the stack. A jump occurs to the instruction stored at the numerical address. The numerical address is obtained according to the rules for EXTended or INDexed addressing. Addressing Formats: See Table A-7. | Addressing | Number of byte of n | | | of First (<br>of machin | | |------------|---------------------|--------------|------|-------------------------|------| | Modes | (No. of cycles) | machine code | HEX. | OCT. | DEC. | | EXT | 9 | 3 | BD | 275 | 189 | | IND | 8 | 2 | AD | 255 | 173 | # Jump to Subroutine # EXAMPLE (extended mode) | | | | Memory | Machine | Ass | embler Lange | uage | |----|-------|---------------|----------|------------|--------|--------------|---------| | | | | Location | Code (Hex) | Label | Operator | Operand | | Α. | Befor | re: | | | | | | | | PĊ | $\rightarrow$ | \$0FFF | BD | | JSR | CHARLI | | | | | \$1000 | 20 | | | | | | | | \$1001 | 77 | | | | | | SP | ← | \$EFFF | | | | | | В. | After | : | | | | | | | | PC | $\rightarrow$ | \$2077 | ** | CHARLI | *** | **** | | | SP | $\rightarrow$ | \$EFFD | | | | • | | | | | \$EFFE | 10 | | | | | | | | \$EFFF | 02 | | | | # Load Accumulator LDA Operation: $ACCX \leftarrow (M)$ Description: Loads the contents of memory into the accumulator. The condition codes are set according to the data. Condition Codes: H: Not affected. l: Not affected. N: Set if most significant bit of the result is set; cleared Z: Set if all bits of the result are cleared; cleared otherwise. V: Cleared. C: Not affected. Boolean Formulae for Condition Codes: $N = R_7$ $Z = \overline{R}_7 \cdot \overline{R}_6 \cdot \overline{R}_5 \cdot \overline{R}_4 \cdot \overline{R}_3 \cdot \overline{R}_2 \cdot \overline{R}_1 \cdot \overline{R}_0$ V = 0 Addressing Formats: See Table A-1. Addressing Modes, Execution Time, and Machine Code (hexadecimal/octal/ decimal): (DUAL OPERAND) | Addressing | | Execution Time | Number of bytes of | | | | |------------|-----|-----------------|--------------------|------|------|------| | N | - | (No. of cycles) | machine code | HEX. | ост. | DEC. | | Α | IMM | 2 | 2 | 86 | 206 | 134 | | Α | DIR | 3 | 2 | 96 | 226 | 150 | | Α | EXT | 4 | 3 | B6 | 266 | 182 | | Α | IND | 5 | 2 | A6 | 246 | 166 | | В | IMM | 2 | 2 | C6 | 306 | 198 | | В | DIR | 3 | 2 | D6 | 326 | 214 | | В | EXT | 4 | 3 | F6 | 366 | 246 | | В | IND | 5 | 2 | E6 | 346 | 230 | # LDS #### **Load Stack Pointer** Operation: $SPH \leftarrow (M)$ $\mathsf{SPL} \leftarrow (\mathsf{M}\!+\!1)$ Description: Loads the more significant byte of the stack pointer from byte of memory at the address specified by the program, and loads the less significant byte of the stack pointer from the next byte of memory, at one plus the address specified by the program. Condition Codes: H: Not affected. I: Not affected. N: Set if the most significant bit of the stack pointer is set by the operation; cleared otherwise. Z: Set if all bits of the stack pointer are cleared by the operation; cleared otherwise. V: Cleared. C: Not affected. Boolean Formulae for Condition Codes: $N = RH_7$ $Z = (\overline{RH}_{7}, \overline{RH}_{6}, \overline{RH}_{5}, \overline{RH}_{4}, \overline{RH}_{3}, \overline{RH}_{2}, \overline{RH}_{1}, \overline{RH}_{0}), \\ (\overline{RL}_{7}, \overline{RL}_{6}, \overline{RL}_{5}, \overline{RL}_{4}, \overline{RL}_{3}, \overline{RL}_{2}, \overline{RL}_{1}, \overline{RL}_{0})$ V = 0 Addressing Formats: See Table A-5. | Addressing | Execution Time | Number of<br>bytes of | Coding of First (or<br>byte of machine c | | | |------------|-----------------|-----------------------|------------------------------------------|------|------| | Modes | (No. of cycles) | machine code | HEX. | OCT. | DEC. | | IMM | 3 | 3 | 8E | 216 | 142 | | DIR | 4 | .2 | 9E | 236 | 158 | | EXT | 5 | 3 | BE | 276 | 190 | | IND | 6 | 2 | AE | 256 | 174 | ### Load Index Register LDX Operation: $\mathsf{IXH} \leftarrow (\mathsf{M})$ $\mathsf{IXL} \longleftarrow (\mathsf{M}+\mathsf{I})$ Description: Loads the more significant byte of the index register from byte of memory at the address specified by the program, and loads the less significant byte of the index register from the next byte of memory, at one plus the address specified by the program. Condition Codes: N: Not affected. I: Not affected. N: Set if the most significant bit of the index register is set by the operation; cleared otherwise. Z: Set if all bits of the index register are cleared by the operation; cleared otherwise. V. Cleared. C: Not affected. Boolean Formulae for Condition Codes: $N = RH_7$ $Z = (\overrightarrow{RH_1}, \overrightarrow{RH_6}, \overrightarrow{RH_5}, \overrightarrow{RH_4}, \overrightarrow{RH_3}, \overrightarrow{RH_2}, \overrightarrow{RH_1}, \overrightarrow{RH_0}), (\overrightarrow{RL_7}, \overrightarrow{RL_6}, \overrightarrow{RL_5}, \overrightarrow{RL_4}, \overrightarrow{RL_3}, \overrightarrow{RL_2}, \overrightarrow{RL_1}, \overrightarrow{RL_0})$ Addressing Formats: See Table A-5. | Addussina | Execution Time | Number of | | of First (<br>f machin | | |---------------------|-----------------|--------------------------|------|------------------------|------| | Addressing<br>Modes | (No. of cycles) | bytes of<br>machine code | HEX. | OCT. | DEC. | | IMM | 3 | 3 | CE | 316 | 206 | | DIR | 4 | 2 | DE | 336 | 222 | | EXT | 5 | 3 | FE | 376 | 254 | | IND | 6 | 2 | EE | 356 | 238 | # LSR ### Logical Shift Right Operation: Description: Shifts all bits of ACCX or M one place to the right. Bit 7 is loaded with a zero. The C bit is loaded from the least significant bit of ACCX or M. Condition Codes: H: Not affected. I: Not affected. N: Cleared. Z: Set if all bits of the result are cleared; cleared otherwise. V: Set if, after the completion of the shift operation, EITHER (N is set and C is cleared) OR (N is cleared and C is set); cleared otherwise. C: Set if, before the operation, the least significant bit of the ACCX or M was set; cleared otherwise. Boolean Formulae for Condition Codes: N = 0 $Z = \overline{R}_{7}.\overline{R}_{6}.\overline{R}_{5}.\overline{R}_{4}.\overline{R}_{3}.\overline{R}_{2}.\overline{R}_{1}.\overline{R}_{0}$ $V = N \oplus C = [N.\overline{C}] \oplus [\overline{N}.C]$ (the foregoing formula assumes values of N and C after the shift operation). $C\,=\,M_0$ Addressing Formats: See Table A-3. | Addressing<br>Modes | Execution Time<br>(No. of cycles) | Number of | Coding of First (<br>byte of machin | | | |---------------------|-----------------------------------|-----------------------|-------------------------------------|------|------| | | | bytes of machine code | HEX. | ост. | DEC. | | A | 2 | 1 | 44 | 104 | 068 | | В | 2 | 1 | 54 | 124 | 084 | | EXT | 6 | 3 | 74 | 164 | 116 | | IND | 7 | 2 | 64 | 144 | 100 | Negate NEG ì Operation: $ACCX \leftarrow - (ACCX) = 00 - (ACCX)$ or: $M \leftarrow - (M) = 00 - (M)$ Description: Replaces the contents of ACCX or M with its two's comple- ment. Note that 80 is left unchanged. Condition Codes: H: Not affected. I: Not affected. N: Set if most significant bit of the result is set; cleared otherwise. Z: Set if all bits of the result are cleared; cleared otherwise. V: Set if there would be two's complement overflow as a result of the implied subtraction from zero; this will occur if and only if the contents of ACCX or M is 80. C: Set if there would be a borrow in the implied subtraction from zero; the C bit will be set in all cases except when the contents of ACCX or M is 00. Boolean Formulae for Condition Codes: $\begin{array}{l} N \ = R_7 \\ Z \ = \ \overline{R}_7.\overline{R}_6.\overline{R}_5.\overline{R}_4.\overline{R}_3.\overline{R}_2.\overline{R}_1.\overline{R}_0 \end{array}$ $V=R_7.\overline{R}_6.\overline{R}_5.\overline{R}_4.\overline{R}_3.\overline{R}_2.\overline{R}_1.\overline{R}_6$ $C = R_7 + R_6 + R_5 + R_4 + R_3 + R_2 + R_1 + R_0$ Addressing Formats: See Table A-3. | Addressing | Execution Time | Number of bytes of | Coding of First (or onl byte of machine code | | | |------------|-----------------|--------------------|----------------------------------------------|------|------| | Modes | (No. of cycles) | machine code | нех. | OCT. | DEC. | | Α | 2 | 1 | 40 | 100 | 064 | | В | 2 | 1 | 50 | 120 | 080 | | EXT | 6 | 3 | 70 | 160 | 112 | | IND | 7 | 2 | 60 | 140 | 096 | # NOP # No Operation Description: This is a single-word instruction which causes only the program counter to be incremented. No other registers are af- fected. Condition Codes: Not affected. Addressing Modes, Execution Time, and Machine Code (hexadecimal/octal/ decimal): | Addressing | Execution Time | Number of bytes of | Coding of First (or only)<br>byte of machine code | | | | |------------|-----------------|--------------------|---------------------------------------------------|------|------|--| | Modes | (No. of cycles) | machine code | HEX. | OCT. | DEC. | | | INHERENT | 2 | 1 | 01 | 001 | 001 | | #### **Inclusive OR** **ORA** Operation: $\mathsf{ACCX} \leftarrow (\mathsf{ACCX})_{\bigodot}(\mathsf{M})$ Description: Perform logical "OR" between the contents of ACCX and the contents of M and places the result in ACCX. (Each bit of ACCX after the operation will be the logical "OR" of the corresponding bits of M and of ACCX before the operation). Condition Codes: H: Not affected. I: Not affected. N: Set if most significant bit of the result is set; cleared otherwise. Z: Set if all bits of the result are cleared; cleared otherwise. V: Cleared. C: Not affected. Boolean Formulae for Condition Codes: $$\begin{split} N &= \underline{R}_7 \\ Z &= \overline{R}_7.\overline{R}_6.\overline{R}_5.\overline{R}_4.\overline{R}_3.\overline{R}_2.\overline{R}_1.\overline{R}_6 \end{split}$$ Addressing Formats: See Table A-1. Addressing Modes, Execution Time, and Machine Code (hexadecimal/octal/ decimal): ### (DUAL OPERAND) | Add | Iressing | Execution Time | Number of | | | Number of bytes of Coding of First (or bytes of bytes of bytes of Coding of First (or bytes of o | | | |-----|----------|-----------------|--------------|------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | | lodes | (No. of cycles) | machine code | HEX. | ост. | DEC. | | | | Α | IMM | 2 | 2 | 8A | 212 | 138 | | | | A | DIR | 3 | 2 | 9A | 232 | 154 | | | | A | EXT | 4 | 3 | BA | 272 | 186 | | | | A | IND | 5 | 2 | AA | 252 | 170 | | | | В | IMM | 2 | 2 | ÇA | 312 | 202 | | | | В | DIR | 3 | 2 | DA | 332 | 218 | | | | В | EXT | 4 | 3 | FA | 372 | 250 | | | | В | IND | 5 | 2 | EA | 352 | 234 | | | **PSH** Push Data Onto Stack Operation: ↓ (ACCX) $SP \leftarrow (SP) - 0001$ Description: The contents of ACCX is stored in the stack at the address contained in the stack pointer. The stack pointer is then decremented. Condition Codes: Not affected. Addressing Formats: See Table A-4. Addressing Modes, Execution Time, and Machine Code (hexadecimal/octal/ decimal): | Addressing | Execution Time | Number of | | Coding of First<br>byte of machin | | |------------|-----------------|-----------|----------|-----------------------------------|------------| | Modes | (No. of cycles) | | HEX. | ост. | DEC. | | A<br>B | 4<br>4 | 1<br>1 | 36<br>37 | 066<br>067 | 054<br>055 | **PUL** /Pull Data from Stack Operation: $SP \leftarrow (SP) + 0001$ $\uparrow ACCX$ Description: The stack pointer is incremented. The ACCX is then loaded from the stack, from the address which is contained in the stack pointer. Condition Codes: Not affected. Addressing Formats: See Table A-4. | Addressing | Execution Time | me Number of byte bytes of | | of First<br>f machin | | |------------|-----------------|----------------------------|----------|----------------------|------------| | Modes | (No. of cycles) | | HEX. | OCT. | DEC. | | A<br>B | 4 | 1<br>1 | 32<br>33 | 062<br>063 | 050<br>051 | #### Rotate Left ROL Operation: Description: Shifts all bits of ACCX or M one place to the left. Bit 0 is loaded from the C bit. The C bit is loaded from the most significant bit of ACCX or M. Condition Codes: H: Not affected. I: Not affected. N: Set if most significant bit of the result is set; cleared otherwise. Z: Set if all bits of the result are cleared; cleared otherwise. V: Set if, after the completion of the operation, EITHER (N is set and C is cleared) OR (N is cleared and C is set); cleared otherwise. C: Set if, before the operation, the most significant bit of the ACCX or M was set; cleared otherwise. Boolean Formulae for Condition Codes: $N = R_7$ $Z = \overline{R}_7, \overline{R}_6, \overline{R}_5, \overline{R}_4, \overline{R}_3, \overline{R}_2, \overline{R}_1, \overline{R}_6$ $V = N \bigoplus C = [N.\overline{C}] \bigcirc [\overline{N}.C]$ (the foregoing formula assumes values of N and C after the rotation) $C = M_7$ Addressing Formats: See Table A-3 | A dd-oodsa | Execution Time | Number of | Coding of First (or or<br>byte of machine cod | | | |---------------------|--------------------------------|--------------------------|-----------------------------------------------|------|------| | Addressing<br>Modes | Execution Time (No. of cycles) | bytes of<br>machine code | HEX. | ост. | DEC. | | Α | 2 | 1 | 49 | 111 | 073 | | В | 2 | 1 | 59 | 131 | 089 | | EXT | 6 | 3 | 79 | 171 | 121 | | IND | 7 | 2 | 69 | 151 | 105 | ROR Rotate Right Operation: Shifts all bits of ACCX or M one place to the right. Bit 7 is Description: loaded from the C bit. The C bit is loaded from the least significant bit of ACCX or M. Condition Codes: H: Not affected. I: Not affected. N: Set if most significant bit of the result is set; cleared otherwise. Z: Set if all bits of the result are cleared; cleared otherwise. V: Set if, after the completion of the operation, EITHER (N is set and C is cleared) OR (N is cleared and C is set); cleared otherwise. C: Set if, before the operation, the least significant bit of the ACCX or M was set; cleared otherwise. Boolean Formulae for Condition Codes: $N = R_7$ $Z = \overline{R}_7.\overline{R}_6.\overline{R}_5.\overline{R}_4.\overline{R}_3.\overline{R}_2.\overline{R}_1.\overline{R}_0$ $V = N \bigoplus C = [N.\overline{C}.] \bigcirc [\overline{N}.C]$ (the foregoing formula assumes values of N and C after the rotation) $C = M_0$ Addressing Formats: See Table A-3 $\label{lem:decimal} \mbox{Addressing Modes, Execution Time, and Machine Code (hexadecimal/octal/decimal):}$ | Addressing<br>Modes | Execution Time<br>(No. of cycles) | Number of<br>bytes of<br>machine code | | oding of First (or only<br>byte of machine code<br>IEX. OCT. DEC | | |---------------------|-----------------------------------|---------------------------------------|----|------------------------------------------------------------------|-----| | A | 2 | 1 | 46 | 106 | 070 | | В | 2 | 1 | 56 | 126 | 086 | | EXT | 6 | 3 | 76 | 166 | 118 | | IND | 7 | 2 | 66 | 146 | 102 | # RTI ### Return from Interrupt Operation: $SP \leftarrow (SP) + 0001$ , $\uparrow CC$ $SP \leftarrow (SP) + 0001$ , $\uparrow ACCB$ $SP \leftarrow (SP) + 0001$ , $\uparrow ACCB$ $SP \leftarrow (SP) + 0001$ , $\uparrow ACCA$ $SP \leftarrow (SP) + 0001$ , $\uparrow IXH$ $SP \leftarrow (SP) + 0001$ , $\uparrow IXL$ $SP \leftarrow (SP) + 0001$ , $\uparrow PCH$ $SP \leftarrow (SP) + 0001$ , $\uparrow PCL$ Description: The condition codes, accumulators B and A, the index regis- ter, and the program counter, will be restored to a state pulled from the stack. Note that the interrupt mask bit will be reset if and only if the corresponding bit stored in the stack is zero. Condition Codes: Restored to the states pulled from the stack. | Addressing | Execution Time | Number of bytes of | Coding of First byte of machin HEX. OCT. | | | |------------|-----------------|--------------------|------------------------------------------|------|-----| | Modes | (No. of cycles) | machine code | HEX. | DEC. | | | INHERENT | 10 | 1 | 3B | 073 | 059 | # **Return from Interrupt** Example | | • | | Memory<br>Location | Machine<br>Code (Hex) | Ass<br>Label | embler Langi<br>Operator | iage<br>Operand | |----|-------|---------------|--------------------|-----------------------|--------------|--------------------------|-----------------| | Α. | Befor | e | | | | | | | | РČ | $\rightarrow$ | \$D066 | 3B | | RTI | | | | SP | $\rightarrow$ | \$EFF8 | | | | | | | | | \$EFF9 | 11HINZVC | (binary) | | | | | | | \$EFFA | 12 | | | | | | | | \$EFFB | 34 | | | | | | | | \$EFFC | 56 | | | | | | | | \$EFFD | 78 | | | | | | | | \$EFFE | 55 | | | | | | | | \$EFFF | 67 | | | | | B. | After | | | | | | | | | PC | $\rightarrow$ | \$5567 | ** | | *** | **** | | | | | \$EFF8 | | | | | | | | | \$EFF9 | 11HINZVC | (binary) | | | | | | | \$EFFA | 12 | (, | | | | | | | \$EFFB | 34 | | | | | | | | \$EFFC | 56 | | | | | | | | \$EFFD | 78 | | | | | | | | \$EFFE | 55 | | | | | | SP | $\rightarrow$ | \$EFFF | 67 | | | | | CC | = HI | NZV | C (binary) | | | | | | AC | CB = | 12 ( | Hex) | IXH = 50 | 6 (Hex) | | | | AC | CA = | 34 ( | Hex) | IXL = 78 | 3 (Hex) | | | # **RTS** #### Return from Subroutine Operation: $SP \leftarrow (SP) + 0001$ ↑ PCH $\dot{SP} \leftarrow (SP) + 0001$ ↑ PCL Description: The stack pointer is incremented (by 1). The contents of the byte of memory, at the address now contained in the stack pointer, is loaded into the 8 bits of highest significance in the program counter. The stack pointer is again incremental (by 1). The contents of the byte of memory, at the address now contained in the stack pointer, is loaded into the 8 bits of lowest significance in the program counter. Condition Codes: Not affected. Addressing Modes, Execution Time, and Machine Code (hexadecimal/octal/ decimal): | Addressing | Execution Time | System of the contract | | • • • • • • • • • • • • • • • • • • • • | | |------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|-----------------------------------------|------| | Modes | (No. of cycles) | machine code | HEX. OCT. D | | DEC. | | INHERENT | 5 | 1 | 39 | 071 | 057 | # Return from Subroutine #### **EXAMPLE** Example: | =manapac. | | | | | | |-----------|--------------------|-----------------------|--------------|--------------------------|-----------------| | | Memory<br>Location | Machine<br>Code (Hex) | Ass<br>Label | sembler Lang<br>Operator | uage<br>Operand | | A. Before | | | | <del></del> | | | PC | \$30A2 | 39 | | RTS | | | SP | \$EFFD | | | | | | | \$EFFE | 10 | | | | | | \$EFFF | 02 | | | | | B. After | | | | | | | PC | \$1002 | ** | | *** | **** | | | \$EFFD | | | | | | | \$EFFE | 10 | | | | | SP | \$EFFF | 02 | | | | ### **Subtract Accumulators** SBA Operation: $ACCA \leftarrow (ACCA) - (ACCB)$ Description: Subtracts the contents of ACCB from the contents of ACCA and places the result in ACCA. The contents of ACCB are not affected. Condition Codes: H: Not affected. I: Not affected. N: Set if most significant bit of the result is set; cleared otherwise. Z: Set if all bits of the result are cleared; cleared otherwise. V: Set if there was two's complement overflow as a result of the operation. C: Carry is set if the absolute value of accumulator B plus previous carry is larger than the absolute value of ac- cumulator A; reset otherwise. Boolean Formulae for Condition Codes: $N = R_7$ $\begin{array}{l} N = \underline{K_7} \\ Z = \overline{K_7}.\overline{K_6}.\overline{K_5}.\overline{K_4}.\overline{K_3}.\overline{K_2}.\overline{K_1}.\overline{K_0} \\ V = \underline{A_7}.\overline{B_7}.\overline{K_7} + \overline{A_7}.B_7.R_7 \\ C = \overline{A_7}.B_7 + B_7.R_7 + R_7.\overline{A_7} \end{array}$ | Addressing | Execution Time | Number of<br>bytes of | Coding<br>byte o | of First (<br>f machin | | |------------|-----------------|-----------------------|------------------|------------------------|-----| | Modes | (No. of cycles) | machine code | HEX. OCT. DEC. | | | | INHERENT | 2 | l | 10 | 020 | 016 | # **SBC** # Subtract with Carry Operation: $ACCX \leftarrow (ACCX) - (M) - (C)$ Description: Subtracts the contents of M and C from the contents of ACCX and places the result in ACCX. Condition Codes: H: Not affected. I: Not affected. N: Set if most significant bit of the result is set; cleared otherwise. Z: Set if all bits of the result are cleared; cleared otherwise. V: Set if there was two's complement overflow as a result of the operation; cleared otherwise. C: Carry is set if the absolute value of the contents of memory plus previous carry is larger than the absolute value of the accumulator; reset otherwise. Boolean Formulae for Condition Codes: $\begin{array}{l} N = \underline{R_7} \\ Z = \overline{R_7}.\underline{R_6}.\underline{R_5}.\overline{R_4}.\overline{R_8}.\overline{R_2}.\overline{R_1}.\overline{R_0} \\ V = \underline{X_7}.\overline{M_7}.\overline{R_7} + \overline{X_7}.\overline{M_7}.\underline{R_7} \end{array}$ $C = \overline{X}_7.M_7 + M_7.R_7 + R_7.\overline{X}_7$ Addressing Formats: See Table A-1. Addressing Modes, Execution Time, and Machine Code (hexadecimal/octal/ decimal): (DUAL OPERAND) | Add | ressing | • ; | Number of<br>bytes of | Coding of First (or only) byte of machine code | | | |-----|---------|-----------------|-----------------------|------------------------------------------------|------|------| | M | lodes | (No. of cycles) | machine code | HEX. | OCT. | DEC. | | Α | IMM | 2 | 2 | 82 | 202 | 130 | | A | DIR | 3 | 2 | 92 | 222 | 146 | | Α | EXT | 4 | 3 | B2 | 262 | 178 | | A | IND | 5 | 2 | A2 | 242 | 162 | | В | IMM | 2 | 2 | C2 | 302 | 194 | | В | DIR | 3 | 2 | D2 | 322 | 210 | | В | EXT | 4 | 3 | F2 | 362 | 242 | | В | IND | 5 | 2 | E2 | 342 | 226 | #### Set Carry **SEC** Operation: C bit $\leftarrow 1$ Description; Sets the carry bit in the processor condition codes register. Condition Codes: H: Not affected. 1: Not affected. N: Not affected. Z: Not affected. V: Not affected. C: Set. Boolean Formulae for Condition Codes: C = I Addressing Modes, Execution Time, and Machine Code (hexadecimal/octal/ decimal): | Addressing | Execution Time | Number of<br>bytes of | Coding of First (or on byte of machine cod | | | |------------|-----------------|-----------------------|--------------------------------------------|-----|-----| | Modes | (No. of cycles) | machine code | HEX. OCT. DEC. | | | | INHERENT | 2 | 1 | 0D | 015 | 013 | ### Set Interrupt Mask SEI Operation: I bit ← 1 Description: Sets the interrupt mask bit in the processor condition codes register. The microprocessor is inhibited from servicing an interrupt from a peripheral device, and will continue with execution of the instructions of the program, until the inter- rupt mask bit has been cleared. Condition Codes: H: Not affected. I: Set. N: Not affected. Z: Not affected. V: Not affected. C: Not affected. Boolean Formulae for Condition Codes: I = 1 | Addressing | Execution Time | Number of bytes of | Coding of First (or only byte of machine code | | | |------------|-----------------|--------------------|-----------------------------------------------|-----|-----| | Modes | (No. of cycles) | machine code | HEX. OCT. DEC. | | | | INHERENT | 2 | 1 | 0F | 017 | 015 | # **SEV** ### Set Two's Complement Overflow Bit Operation: V bit ← 1 Description: Sets the two's complement overflow bit in the processor condition codes register. Condition Codes: H: Not affected.I: Not affected. N: Not affected. Z: Not affected. V: Set. C: Not affected. Boolean Formulae for Condition Codes: V = 1 | Addressing | Execution Time | Number of<br>bytes of | Coding of First (or only)<br>byte of machine code | | | |------------|-----------------|-----------------------|---------------------------------------------------|------|------| | Modes | (No. of cycles) | machine code | HEX. | OCT. | DEC. | | INHERENT | 2 | 1 | 0B | 013 | 011 | ### Store Accumulator **STA** Operation: $M \leftarrow (ACCX)$ Description: Stores the contents of ACCX in memory. The contents of ACCX remains unchanged. Condition Codes: H: Not affected. I: Not affected. N: Set if the most significant bit of the contents of ACCX is set; cleared otherwise. Z: Set if all bits of the contents of ACCX are cleared; cleared otherwise. V: Cleared. C: Not affected. Boolean Formulae for Condition Codes: $\begin{array}{ll} N &= X_7 \\ Z &= \overline{X}_7.\overline{X}_6.\overline{X}_5.\overline{X}_4.\overline{X}_3.\overline{X}_2.\overline{X}_1.\overline{X}_0 \end{array}$ V = 0 Addressing Formats: See Table A-2. | | ressing<br>lodes | Execution Time<br>(No. of cycles) | Number of<br>bytes of<br>machine code | Coding of First (or only) byte of machine code HEX. OCT. DEC. | | | |---|------------------|-----------------------------------|---------------------------------------|---------------------------------------------------------------|-----|-----| | Α | DIR | 4 | 2 | 97 | 227 | 151 | | A | EXT | 5 | 3 | B7 | 267 | 183 | | Α | IND | 6 | 2 | A7 | 247 | 167 | | В | DIR | 4 | 2 | <b>D</b> 7 | 327 | 215 | | В | EXT | 5 | 3 | F7 | 367 | 247 | | В | IND | 6 | 2 | E7 | 347 | 231 | # STS ### Store Stack Pointer Operation: $M \leftarrow (SPH)$ $M + 1 \leftarrow (SPL)$ Description: Stores the more significant byte of the stack pointer in memory at the address specified by the program, and stores the less significant byte of the stack pointer at the next location in memory, at one plus the address specified by the program. Condition Codes: H: Not affected. I: Not affected. N: Set if the most significant bit of the stack pointer is set; cleared otherwise. Z: Set if all bits of the stack pointer are cleared; cleared otherwise. V: Cleared. C: Not affected. Boolean Formulae for Condition Codes: $N = SPH_7$ $Z = \underbrace{(SPH_7.SPH_6.SPH_5.SPH_4.SPH_3.SPH_2.SPH_1.SPH_0)}_{(SPL_7.SPL_6.SPL_5.SPL_4.SPL_3.SPL_2.SPL_1.SPL_0)}$ V = 0 Addressing Formats: See Table A-6. | Addressing | Execution Time | bytes of | Coding of First (or only)<br>byte of machine code | | | |------------|-----------------|--------------|---------------------------------------------------|------|------| | Modes | (No. of cycles) | machine code | HEX. | OCT. | DEC. | | DIR | 5 | 2 | 9F | 237 | 159 | | EXT | 6 | 3 | BF | 277 | 191 | | IND | 7 | 2 | AF | 257 | 175 | #### Store Index Register STX Operation: $M \leftarrow (IXH)$ $M + 1 \leftarrow (IXL)$ Description: Stores the more significant byte of the index register in memory at the address specified by the program, and stores the less significant byte of the index register at the next location in memory, at one plus the address specified by the program. Condition Codes: H: Not affected. I: Not affected. N: Set if the most significant bite of the index register is set; cleared otherwise. Z: Set if all bits of the index register are cleared; cleared otherwise. V: Cleared. C: Not affected. Boolean Formulae for Condition Codes: $N = IXH_{7}$ $Z = (IXH_{7}.IXH_{6}.IXH_{5}.IXH_{4}.IXH_{3}.IXH_{2}.IXH_{1}.IXH_{0})$ $(IXL_{7}.IXL_{6}.IXL_{5}.IXL_{4}.IXL_{3}.IXL_{2}.IXL_{1}.IXL_{0})$ Addressing Formats: See Table A-6. | Addressing<br>Modes | Execution Time (No. of cycles) | Number of<br>bytes of<br>machine code | Coding of First (or only) byte of machine code HEX. OCT. DEC. | | | |---------------------|--------------------------------|---------------------------------------|-------------------------------------------------------------------|------|------| | Middles | (No. of cycles) | macinne code | пел. | UCI. | DEC. | | DIR | 5 | 2 | DF | 337 | 223 | | EXT | 6 | 3 | FF | 377 | 255 | | IND | 7 | 2 | EF | 357 | 239 | # **SUB** Subtract Operation: $ACCX \leftarrow (ACCX) - (M)$ Description: Subtracts the contents of M from the contents of ACCX and places the result in ACCX. Condition Codes: H: Not affected. I: Not affected. - N: Set if most significant bit of the result is set; cleared otherwise. - Z: Set if all bits of the result are cleared; cleared otherwise. - V: Set if there was two's complement overflow as a result of the operation; cleared otherwise. - C: Carry is set if the absolute value of the contents of memory is larger than the absolute value of the accumulator; reset otherwise. Boolean Formulae for Condition Codes: $N = \frac{R_7}{Z} = \overline{R_7}.\overline{R_6}.\overline{R_5}.\overline{R_4}.\overline{R_3}.\overline{R_2}.\overline{R_1}.\overline{R_6}$ $V = X_7.\overline{M_7}.\overline{R_7}+\overline{X_7}.M_7.R_7$ $C = \overline{X_7}.M_7+M_7.R_7+R_7.\overline{X_7}$ ### Addressing Formats: See Table A-1. Addressing Modes, Execution Time, and Machine Code (hexadecimal/octal/ decimal): (DUAL OPERAND) | Addressing<br>Modes | | Execution Time (No. of cycles) | Number of<br>bytes of<br>machine code | Coding of First (or only)<br>byte of machine code | | | |---------------------|-----|--------------------------------|---------------------------------------|---------------------------------------------------|------|------| | | | | | HEX. | OCT. | DEC. | | A | IMM | 2 | 2 | 80 | 200 | 128 | | Α | DIR | 3 | 2 | 90 | 220 | 144 | | Α | EXT | 4 | 3 | В0 | 260 | 176 | | Α | IND | 5 | 2 | A0 | 240 | 160 | | В | IMM | 2 | 2 | C0 | 300 | 192 | | В | DIR | 3 | 2 | D0 | 320 | 208 | | В | EXT | 4 | 3 | F0 | 360 | 240 | | В | IND | 5 | 2 | E0 | 340 | 224 | ## Software Interrupt SWI Operation: PC ← (PC) + 0001 ↓ (PCL) , SP ← (SP)-0001 ↓ (PCH) , SP ← (SP)-0001 ↓ (IXL) , SP ← (SP)-0001 ↓ (IXH) , SP ← (SP)-0001 ↓ (ACCA) , SP ← (SP)-0001 ↓ (ACCB) , SP ← (SP)-0001 ↓ (CC) , SP ← (SP)-0001 ↓ (CC) , SP ← (SP)-0001 PCH ← (n-0005) PCL ← (n-0004) Description: The program counter is incremented (by 1). The program counter, index register, and accumulator A and B, are pushed into the stack. The condition codes register is then pushed into the stack, with condition codes H, I, N, Z, V, C going respectively into bit positions 5 thru 0, and the top two bits (in bit positions 7 and 6) are set (to the 1 state). The stack pointer is decremented (by 1) after each byte of data is stored in the stack. The interrupt mask bit is then set. The program counter is then loaded with the address stored in the software interrupt pointer at memory locations (n-5) and (n-4), where n is the address corresponding to a high state on all lines of the address bus. Condition Codes: H: Not affected. I: Set.N: Not affected.Z: Not affected. V: Not affected. C: Not affected. Boolean Formula for Condition Codes: I = 1 | Addressing | Execution Time | Number of<br>bytes of | Coding of First (or on byte of machine code | | | |------------|-----------------|-----------------------|---------------------------------------------|------|------| | Modes | (No. of cycles) | machine code | HEX. | ост. | DEC. | | INHERENT | 12 | 1 | 3F | 077 | 063 | #### Software Interrupt #### **EXAMPLE** A. Before: CC = HINZVC (binary) ACCB = 12 (Hex) IXH = 56 (Hex)ACCA = 34 (Hex)IXL = 78 (Hex)Machine Assembler Language Memory Location Code (Hex) Label Operator Operand SWI 3F PC \$5566 SP \$EFFF $\mathbf{D}\mathbf{0}$ \$FFFA \$FFFB 55 B. After: PC → \$D055 SP \$EFF8 \$EFF9 11HINZVC (binary) \$EFFA 12 \$EFFB 34 \$EFFC 56 \$EFFD **78** \$EFFE 55 \$EFFF 67 Note: This example assumes that FFFF is the memory location addressed when all lines of the address bus go to the high state. # Transfer from Accumulator A to Accumulator B **TAB** Operation: ACCB ← (ACCA) Description: Moves the contents of ACCA to ACCB. The former contents of ACCB are lost. The contents of ACCA are not affected. Condition Codes: H: Not affected. I: Not affected. N: Set if the most significant bit of the contents of the accumulator is set; cleared otherwise. Z: Set if all bits of the contents of the accumulator are cleared; cleared otherwise. V: Cleared. C: Not affected. Boolean Formulae for Condition Codes: $N = R_7$ $Z = \overline{R}_7.\overline{R}_6.\overline{R}_5.\overline{R}_4.\overline{R}_3.\overline{R}_2.\overline{R}_1.\overline{R}_0$ V = 0 | Addressing | Execution Time | Number of<br>bytes of | Coding of First (or only)<br>byte of machine code | | | |------------|-----------------|-----------------------|---------------------------------------------------|------|------| | Modes | (No. of cycles) | machine code | HEX. | ост. | DEC. | | INHERENT | 2 | 1 | 16 | 026 | 022 | # **TAP** Transfer from Accumulator A to Processor Condition Codes Register Operation: CC ← (ACCA) **Bit Positions** Description: Transfers the contents of bit positions 0 thru 5 of accumulator A to the corresponding bit positions of the processor condition codes register. The contents of accumulator A remain unchanged. Condition Codes: Set or reset according to the contents of the respective bits $\boldsymbol{0}$ thru 5 of accumulator A. | Addressing | Execution Time | Number of<br>bytes of | | ling of First (or only)<br>yte of machine code | | | |------------|-----------------|-----------------------|------|------------------------------------------------|------|--| | Modes | (No. of cycles) | machine code | HEX. | OCT. | DEC. | | | INHERENT | 2 | 1 | 06 | 006 | 006 | | # Transfer from Accumulator B to Accumulator A **TBA** Operation: ACCA ← (ACCB) Description: Moves the contents of ACCB to ACCA. The former contents of ACCA are lost. The contents of ACCB are not affected. Condition Codes: H: Not affected. I: Not affected. N: Set if the most significant bit of the contents of the accumulator is set; cleared otherwise. Z. Set if all bits of the contents of the accumulator are cleared; cleared otherwise. V: Cleared, C: Not affected. Boolean Formulae for Condition Codes: $N = R_7$ $Z = \overline{R}_7.\overline{R}_6.\overline{R}_5.\overline{R}_4.\overline{R}_3.\overline{R}_2.\overline{R}_1.\overline{R}_0$ V = 0 | Addressing Execution Time | Number of<br>bytes of | Coding of First (or onl byte of machine code | | | | |---------------------------|-----------------------|----------------------------------------------|------|------|------| | Modes | (No. of cycles) | machine code | HEX. | OCT. | DEC. | | INHERENT | 2 | 1 | 17 | 027 | 023 | ## **TPA** #### Transfer from Processor Condition Codes Register to Accumulator A Operation: $ACCA \leftarrow (CC)$ Description: Transfers the contents of the processor condition codes register to corresponding bit positions 0 thru 5 of accumulator A. Bit positions 6 and 7 of accumulator A are set (i.e. go to the "1" state). The processor condition codes register remains unchanged. Condition Codes: Not affected. | Addressing | Execution Time | Number of bytes of | | oding of First (or only)<br>byte of machine code | | | | |------------|-----------------|--------------------|------|--------------------------------------------------|------|--|--| | Modes | (No. of cycles) | machine code | HEX. | OCT. | DEC. | | | | INHERENT | 2 | 1 | 07 | 007 | 007 | | | Test **TST** Operation: (ACCX) - 00 (M) - 00 Description: Set condition codes N and Z according to the contents of ACCX or M. Condition Codes: H: Not affected. I: Not affected. N: Set if most significant bit of the contents of ACCX or M is set; cleared otherwise. Z: Set if all bits of the contents of ACCX or M are cleared; cleared otherwise. V: Cleared. C: Cleared. Boolean Formulae for Condition Codes: N = $M_7$ $Z = \overline{M}_7.\overline{M}_6.\overline{M}_5.\overline{M}_4.\overline{M}_3.\overline{M}_2.\overline{M}_1.\overline{M}_6$ V = 0 C = 0 Addressing Formats: See Table A-3. | Addressing | Execution Time | Number of bytes of | | of First (<br>f machin | (or only)<br>e code | |------------|-----------------|--------------------|------|------------------------|---------------------| | Modes | (No. of cycles) | machine code | HEX. | OCT. | DEC. | | Α | 2 | 1 | 4D | 115 | 077 | | В | 2 | 1 | 5D | 135 | 093 | | EXT | 6 | 3 | 7D | 175 | 125 | | IND | 7 | 2 | 6D | 155 | 109 | **TSX** Transfer from Stack Pointer to Index Register Operation: $IX \leftarrow (SP) + 0001$ Description: Loads the index register with one plus the contents of the stack pointer. The contents of the stack pointer remains unchanged. Condition Codes: Not affected. Addressing Modes, Execution Time, and Machine Code (hexadecimal/octal/decimal): | Addressing | Execution Time | Number of<br>bytes of | | of First (<br>f machin | (or only)<br>e code | |------------|-----------------|-----------------------|------|------------------------|---------------------| | Modes | (No. of cycles) | machine code | HEX. | OCT. | DEC. | | INHERENT | 4 | 1 | 30 | 060 | 048 | **TXS** Transfer From Index Register to Stack Pointer Operation: $SP \leftarrow (IX) - 0001$ Description: Loads the stack pointer with the contents of the index regis- ter, minus one. The contents of the index register remains unchanged. Condition Codes: Not affected. | Addressing | Execution Time | Number of<br>bytes of | , . | of First (<br>f machin | (or only)<br>e code | |------------|-----------------|-----------------------|------|------------------------|---------------------| | Modes | (No. of cycles) | machine code | HEX. | OCT. | DEC. | | INHERENT | 4 | 1 | 35 | 065 | 053 | #### Wait for Interrupt WAI Operation: PC ← (PC) + 0001 ↓ (PCL) , SP ← (SP)-0001 ↓ (PCH) , SP ← (SP)-0001 ↓ (IXL) , SP ← (SP)-0001 ↓ (IXH) , SP ← (SP)-0001 ↓ (ACCA) , SP ← (SP)-0001 ↓ (ACCB) , SP ← (SP)-0001 ↓ (CC) , SP ← (SP)-0001 Condition Codes: Not affected. Description: The program counter is incremented (by 1). The program counter, index register, and accumulators A and B, are pushed into the stack. The condition codes register is then pushed into the stack, with condition codes H, 1, N, Z, V, C going respectively into bit positions 5 thru 0, and the top two bits (in bit positions 7 and 6) are set (to the 1 state). The stack pointer is decremented (by 1) after each byte of data is stored in the stack. Execution of the program is then suspended until an interrupt from a peripheral device is signalled, by the interrupt request control input going to a low state. When an interrupt is signalled on the interrupt request line, and provided the I bit is clear, execution proceeds as follows. The interrupt mask bit is set. The program counter is then loaded with the address stored in the internal interrupt pointer at memory locations (n-7) and (n-6), where n is the address corresponding to a high state on all lines of the address bus. Condition Codes: - H: Not affected. - I: Not affected until an interrupt request signal is detected on the interrupt request control line. When the interrupt request is received the I bit is set and further execution takes place, provided the I bit was initially clear. - N: Not affected. - Z: Not affected. - V: Not affected. - C: Not affected. | Addressing | Execution Time | Number of<br>bytes of | Coding of First (or only)<br>byte of machine code | | | |------------|-----------------|-----------------------|---------------------------------------------------|------|------| | Modes | (No. of cycles) | machine code | HEX. | OCT. | DEC. | | INHERENT | 9 | 1 | 3E | 076 | 062 | | Addressing Mode of | First ( | First Operand | | | | |--------------------|-------------------------------------------------------------------|-------------------------------------------------------------------|--|--|--| | Second Operand | Accumulator A | Accumulator B | | | | | IMMediate | CCC A #Number<br>CCC A #symbol<br>CCC A #expression<br>CCC A #'C | CCC B #Number<br>CCC B #symbol<br>CCC B #expression<br>CCC B #'C | | | | | DIRect or EXTended | CCC A Number<br>CCC A symbol<br>CCC A expression | CCC B Number<br>CCC B symbol<br>CCC B expression | | | | | INDexed | CCC A X CCC Z ,X CCC A Number,X CCC A symbol,X CCC A expression,X | CCC B X CCC B ,X CCC B Number,X CCC B symbol,X CCC B expression,X | | | | Notes: 1. CCC = Mnemonic operator of source instruction 2. "symbol" may be the special symbol "\*" 3. "expression" may contain the special symbol "\*" 4. space may be omitted before A or B ## Applicable to the Following Source Instructions: ADC ADD AND BIT CMP EOR LDA ORA SBC SUB TABLE A-1. Addressing Formats (1) <sup>\*</sup>Special symbol indicating program-counter | Addressing Mode of | First Operand | | | | |--------------------|--------------------|--------------------|--|--| | Second Operand | Accumulator A | Accumulator B | | | | DIRect or EXTended | STA A Number | STA B Number | | | | | STA A symbol | STA B symbol | | | | | STA A expression | STA B expression | | | | INDexed | STA A X | STA B X | | | | | STA A ,X | STA B ,X | | | | | STA A Number,X | STA B Number,X | | | | | STA A symbol,X | STA B symbol,X | | | | | STA A expression,X | STA B expression,X | | | Notes: 1. "symbol" may be the special symbol "\*". 2. "expression" may contain the special symbol "\*". 3. space may be omitted before A or B. ## Applicable to the Source Instruction: STA TABLE A-2. Addressing Formats (2) <sup>\*</sup>Special symbol indicating program-counter | Operand or<br>Addressing Mode | Formats | |-------------------------------|---------------------------------------------------------| | Accumulator A | CCC A | | Accumulator B | ССС В | | EXTended | CCC Number<br>CCC symbol<br>CCC expression | | INDexed | CCC X CCC ,X CCC Number,X CCC symbol,X CCC expression,X | Notes: 1. CCC + Mnemonic operator of source instruction. - 2. "symbol" may be the special symbol "\*".3. "expression" may contain the special symbol "\*". - 4. space may be omitted before A or B ## Applicable to the Following Source Instructions: ASL ASR CLR COM DEC INC LSR NEG ROL ROR TST TABLE A-3. Addressing Formats (3) | Operand | Formats | |---------------|---------| | Accumulator A | CCC A | | Accumulator B | ССС В | Notes: 1. CCC = Mnemonic operator of source instruction 2. space may be omitted before A or B # Applicable to the Following Source Instructions: PSH PUL TABLE A-4. Addressing Formats (4) A-72 <sup>\*</sup>Special symbol indicating program-counter | Addressing Mode | Formats | | | |--------------------|----------------------------------------------------------|--|--| | IMMediate | CCC #number<br>CCC #symbol<br>CCC #expression<br>CCC #'C | | | | DIRect or EXTended | CCC Number<br>CCC symbol<br>CCC expression | | | | INDexed | CCC X CCC ,X CCCNumber,X CCC symbol,X CCC expression,X | | | Notes: 1. CCC = Mnemonic operator of source instruction 2. "symbol" may be the special symbol "\*" 3. "expression" may contain the special symbol "\*" ## Applicable to the Following Source Instructions: CPX LDS LDX \*Special symbol indicating program-counter TABLE A-5. Addressing Formats (5) | Addressing Mode | Formats | | | |--------------------|---------------------------------------------------------|--|--| | DIRect or EXTended | CCC N<br>CCC symbol<br>CCC expression | | | | INDexed | CCC X CCC ,X CCC Number,X CCC symbol,X CCC expression,X | | | Notes: 1. CCC = Mnemonic operator of source instruction 2. "symbol" may be the special symbol "\*" 3. "expression" may contain the special symbol "\*" ## Applicable to the Following Source Instructions: STS STX TABLE A-6. Addressing Formats (6) | Addressing Mode | Formats | | | |-----------------|------------------|--|--| | EXTended | CCC Number | | | | | CCC symbol | | | | | CCC expression | | | | INDexed | CCC X | | | | | CCC ,X | | | | | CCC Number,X | | | | | CCC symbol,X | | | | | CCC expression,X | | | Notes: 1. CCC = Mnemonic operator of source instruction - "symbol" may be the special symbol "\*" "expression" may contain the special symbol "\*" ## Applicable to the Following Source Instructions: ### TABLE A-7. Addressing Formats (7) <sup>\*</sup>Special symbol indicating program-counter <sup>\*</sup>Special symbol indicating program-counter | Addressing Mode | Formats | |-----------------|--------------------------------------------| | RELative | CCC Number<br>CCC symbol<br>CCC expression | Notes: 1. CCC = Mnemonic operator of source instruction 2. "symbol" may be the special symbol "\*" 3. "expression" may contain the special symbol "\*" # Applicable to the Following Source Instructions: BCC BCS BEQ BGE BGT BHI BLE BLS BLT BMI BNE BPL BRA BSR BVC BVS TABLE A-8. Addressing Formats (8) <sup>\*</sup>Special symbol indicating program-counter # appendix B **Assembler Directives** lacksquare #### APPENDIX B # Definition of the Assembler Directives ## Alphabetic List of Assembler Directives | END | End of program | |------|--------------------------------| | EQU | Equate symbol | | FCB | Form Constant byte | | FCC | Form Constant Characters | | FDB | Form Double Constant Byte | | MON | Return to Monitor | | NAM | Name program | | 0PT | Option | | ORG | Origin | | PAGE | Advance Listing to top of page | | RMB | Reserve Memory Bytes | | SPC | Space n lines | #### END - End of Program When the assembler directive "END", is used, it marks the end of a source program and can be followed only by a statement containing the assembler directive "MON" or another program. The operator in the last statement of a source program must be either "END" or "MON". If the program ends with a "MON" directive, the use of "END" is optional. The "END" directive must not be written with a label, and it does not have an operand. The "END" directive is not translated into object code. ## EQU - Equate Symbol The "EQU" directive is used to assign a value to a symbol. The "EQU" statement must contain a label which is identical with the symbol being defined. The operand field may contain the numerical value of the symbol (decimal, hexadecimal, octal, or binary). Alternatively, the operand field may be another symbol or an expression which can be evaluated by the assembler. The EQU statement is not translated into object code. The following are examples of valid "EQU" statements: | Location | Data | Label | Operator | Operand | |----------|----------------------|-----------------|-------------------|--------------| | | 0A01<br>0003 | SUN<br>Ab | EQU<br>EQU | \$A01<br>3 | | | 0A01<br>0A04<br>0FC1 | AA<br>AC<br>ABC | EQU<br>EQU<br>EQU | SUN<br>AB+AA | | | orei | ADC | EQU<br>B | \$FC1 | Relating to the use of a symbol or an expression in the operand field, only one level of forward referencing will assemble correctly. This reflects a two-pass characteristic of the assembly process. An (illegal) example of two levels of forward referencing would be: | Ε | EQU | Y | |---|-----|---| | Y | ΕQU | C | | C | EQU | 5 | This will not assemble correctly because E will not be assigned a numerical value at the end of pass 2. E and Y are both undefined throughout pass 1. E is undefined throughout pass 2 and will cause an error message. #### FCB - Form Constant Byte The "FCB" directive may have one or more operands, separated by commas. An 8-bit unsigned binary number, corresponding to the value of each operand is stored in a byte of the object program. If there is more than one operand, they are stored in successive bytes. The operand field may contain the actual value (decimal, hexadecimal, octal, or binary). Alternatively, the operand may be a symbol or an expression which can be assigned a numerical value by the assembler. An "FCB" directive followed by one or more void operands separated by commas will store zeros for the void operands. An "FCB" directive may be written with a label. Examples of valid "FCB" directives follow: | Location | Data | Label | Operator | Operand | |----------|------|-------|----------|---------| | 0000 | FF | TOP | FCB | \$FF | | 0001 | 00 | TAB | FCB | \$F,23. | | 0002 | 0F | | | ., | | 0003 | 17 | | | | | 0004 | 00 | | | | | 0005 | E5 | | FCB | *+\$E0 | #### FCC - Form Constant Characters The "FCC" directive translates strings of characters into their 7-bit ASCII codes. Any of the characters which correspond to ASCII hexadecimal codes 20 (SP) thru 5F $(\_)$ can be processed by this directive. - Count, comma, text. Where the count specifies how many ASCII characters to generate and the text begins following the first comma of the operand. Should the count be longer than the text, spaces will be inserted to fill the count. Maximum count is 255. - Text enclosed between identical delimiters, each being any single character. (If the delimiters are numbers, the text must not begin with a comma.) If the string in the operand comprises more than one character, the ASCII codes corresponding to the successive characters are entered into successive bytes of memory. An "FCC" directive may be written with a label. The following are examples of valid "FCC" directives: | Location | Data | Labe1 | Operator | Operand | |---------------|------|-------|----------|---------| | 0A00 | 54 | MSG1 | FCC | /TEXT/ | | 0 <b>A</b> 01 | 45 | | | 7 . =, | | 0A02 | 58 | | | | | 0A03 | 54 | | | | | 0 <b>A</b> 04 | 54 | MSG2 | FCC | 9,TEXT | | 0A05 | 45 | | | -, | | 0A06 | 58 | | | | | 0A07 | 54 | | | | | 80A0 | 20 | | | | | 0A09 | 20 | | | | | OAOA | 20 | | | | | OAOB | 20 | | | | | 0A0C | 20 | | | | FDB - Form Double Constant Byte The "FDB" directive may have one or more operands separated by commas. The 16-bit unsigned binary number, corresponding to the value of each operand is stored in two bytes of the object program. If there is more than one operand, they are stored in successive bytes. The operand field may contain the actual value (decimal, hexadecimal, octal, or binary). Alternatively, the operand may be a symbol or an expression which can be assigned a numerical value by the assembler. An "FDB" directive followed by one or more void operands separated by commas will store zeros for the void operands. An "FDB" directive may be written with a label. Examples of valid "FDB" directives follow: | Location | Data | Label | Operator | Operand | |----------------------------------------------|----------------------------------------------|-------------|------------|-----------------------| | 0010<br>0012<br>0014<br>0016<br>0018<br>001A | 0002<br>0000<br>000F<br>00EF<br>0000<br>0AFF | TWO<br>Mask | FDB<br>FDB | 2<br>,\$F,\$EF,,\$AFF | MON - Return to Monitor The assembler directive "MON", if used, must be in the last statement of a source program. (See assembler directive "END" above.) The "MON" directive instructs the assembler that the source program just completed is the last to be assembled, and it returns control to the 680b PROM Monitor. The last statement of a source program must contain either "END" or "MON". The assembler directive "MON" must not be written with a label, and no operand is used. The "MON" directive is not translated into object code. NAM - Name The "NAM" (or NAME) directive names the program, or provides the top of page heading text meaningful to users of the assembly. The "NAM" directive must not be written with a label. The "NAM" directive cannot distinguish the operand field from the comment field. Both the operand field and the comment field are treated as continuous text. No object code results from the "NAM" directive. OPT - Option The "OPT" directive is used to give the programmer optional control of the format of assembler output. The details of the "OPT" directive depend on the version of the 680b Resident Assembler being used. When the Assembler becomes available, details of the "OPT" directive will be included in the documentation. ORG - Origin The assembler directive "ORG" defines the numerical address of the first byte of machine code which results from the assembly of the immediately subsequent section of a source program. There may be any number of "ORG" statements in a program. The "ORG" directive sets the program counter to the value expressed in the operand field. The operand field may contain the actual value (decimal, hexadecimal, octal, or binary) to which the program counter is to be set. Alternatively, the operand field may contain a symbol or an expression which can be assigned a numerical value by the assembler. The location counter is initialized before each assembly. If no "ORG" statement appears at the beginning of the program, the location counter will begin as if an "ORG" zero had been entered. An "ORG" directive must not be written with a label. The ORG statement does not translate into object code. The following are examples of valid ORG statements: | Location | Data | Label | Operator | Operand | |----------|------|------------------|------------|-----------------| | 0064 | | (blank) | ORG | 100 | | AF23 | 1100 | (blank) | ORG | \$AF23 | | 1100 | 1100 | BEGIN<br>(blank) | EQU<br>ORG | \$1100<br>BEGIN | PAGE - Advance Paper to Top of Next Page The "PAGE" directive causes the Assembler to advance the paper to the top of the next page. The PAGE directive does not appear on the program listing. No label or operand is used, and no machine code results. ## RMB - Reserve Memory Bytes The "RMB" directive causes the location counter to be increased by the value of the operand field. This reserves a block of memory whose length is equal to the value of the operand field. The operand field may contain the actual number (decimal, hexadecimal, octal or binary) equal to the number of bytes to be reserved. Alternatively, the operand may be a symbol or an expression which can be assigned a numerical value by the assembler. The block of memory which is reserved by the "RMB" directive is unchanged by that directive. The "RMB" directive may be written with a label. Examples of valid "RMB" directives follow (the data column indicates the number of bytes being reserved): | Location | Data | Label | Operator | Operand | |----------|------|---------|----------|---------| | 0100 | 0004 | TABLE 1 | RMB | 4 | | 0104 | 0014 | | RMB | 20 | | 0118 | 0014 | | RMB | 20 | #### SPC - Space N Lines The "SPC" directive provides n vertical spaces for formatting the program listing. It does not itself appear in the listing. The number of lines to be left blank is stated by an operand in the operand field. The operand would normally contain the actual number (decimal, hexadecimal, octal, or binary) equal to the number of lines to be left blank. A symbol or an expression is also allowed. The "SPC" directive must not be written with a label. When the "SPC" directive causes the listing to cross page boundries only those blank lines required to get to the top of the next page will be generated. # appendix C Input/Output Information ## APPENDIX C, INPUT/OUTPUT INFORMATION ACIA The 680b is supplied with an Asynchronous Communications Interface Adapter (ACIA) for the purpose of handling serial input and output operations. Initialization and control of this I/O port is usually handled by system software such as the PROM Monitor. The following information concerning the ACIA registers is included for those who wish to do their own initialization and I/O handling. #### ACIA Registers Transmit Data Register (TDR) Writing data into the Transmit Data Register causes the Transmit Data Register Empty bit in the Status Register to go low. Data can then be transmitted. If the transmitter is idling and no character is being transmitted, then the transfer will take place within one bit time of the trailing edge of the Write command. If a character is being transmitted, the new data character will commence as soon as the previous character is complete. The transfer of data causes the Transmit Data Register Empty (TDRE) bit to indicate empty. Receive Data Register (RDR) Data is automatically transferred to the empty Receive Data Register (RDR) from the receiver descrializer (a shift register) upon receiving a complete character. This event causes the Receive Data Register Full bit (RDRF) in the status buffer to go high (full). Data may then be read through the bus by addressing the ACIA and selecting the Receive Data Register with RS and R/W high when the ACIA is enabled. The non-destructive read cycle causes the RDRF bit to be cleared to empty although the data is retained in the RDR. The status is maintained by RDRF as to whether or not the data is current. When the Receive Data Register is full, the automatic transfer of data from the Receiver Shift Register to the Data Register is inhibited and the RDR contents remain valid with its current status stored in the Status Register. Control Register The ACIA Control Register consists of eight bits of write-only buffer that are selected when RS and R/W are low. This register controls the function of the receiver, transmitter, interrupt enables, and the Request-to-Send peripheral/modem control output. Counter Divide Select Bits (CRO and CRI) - The Counter Divide Select Bits (CRO and CRI) determine the divide ratios utilized in both the transmitter and receiver sections of the ACIA. Additionally, these bits are used to provide a master reset for the ACIA which clears the Status Register (except for external conditions on $\overline{\text{CTS}}$ and $\overline{\text{DCD}}$ ) and initializes both the receiver and transmitter. Master reset does not affect other Control Register bits. Note that after power-on or a power fail/restart, these bits must be set high to reset the ACIA. After resetting, the clock divide ratio may be selected. These counter select bits provide for the following clock divide ratios: | CRT | CRO | Function | | |-----|----------|--------------|--| | 0 | 0 | ÷1 | | | 0 | 1 | ÷16 | | | ı | 0 | ÷64 | | | ] | <u> </u> | Master Reset | | Word Select Bits (CR2, C3, and CR4) - The Word Select bits are used to select word length, parity, and the number of stop bits. The encoding format is as follows: | CR4 | CR3 | CR2 | Function | | | |-----|-----|-----|------------------------------------|--|--| | 0 | 0 | 0 | 7 Bits + Even Parity + 2 Stop Bits | | | | 0 | 0 | ī | 7 Bits + Odd Parity + 2 Stop Bits | | | | 0 | 1 | 0 | 7 Bits + Even Parity + 1 Stop Bit | | | | 0 | 1 | 1 | 7 Bits + Odd Parity + 1 Stop Bit | | | | 1 | 0 | 0 | 8 Bits + 2 Stop Bits | | | | ı | 0 | 1 | 8 Bits + I Stop Bit | | | | 1 | 1 | 0 | 8 Bits + Even Parity + 1 Stop Bit | | | | 1 | ı | 1 | 8 Bits + Odd Parity + 1 Stop Bit | | | Word length, Parity Select, and Stop Bit changes are not buffered and, therefore, become effective immediately. Transmitter Control Bits (CR5 and CR6) - Two Transmitter Control bits provide for the control of the interrupt from the Transmit Data Register Empty condition, the Request-to-Send output, and the transmission of a Break level (space). The following encoding format is used: | CR6 | CR5 | Function | | | |-----|-----|--------------------------------------------------------------------------------------------------------|--|--| | 0 | 0 | $\overline{\text{RTS}}$ = low, Transmitting Interrupt Disabled. | | | | 0 | 1 | RTS = low, Transmitting Interrupt Enabled. | | | | 1 | 0 | RTS = high, Transmitting Interrupt Disabled. | | | | 1 | 1 | RTS = low, Transmits a Break level on the<br>Transmit Data Output, Transmitting<br>Interrupt Disabled. | | | Receive Interrupt Enable Bit (CR7) - Interrupts will be enabled by a high level in bit position 7 of the Control Register (CR7). Interrupts from the receiver section, Receive Data Register Full being high or by a low to high transition on the Data Carrier Detect signal line, are enabled or disabled by the Receive Interrupt Enable Bit. #### Status Register Information on the status of the ACIA is available to the MPU by reading the ACIA Status Register. This read-only register is selected when RS is low and R/W is high. Information stored in this register indicates the status of the Transmit Data Register, the Receive Data Register and error logic, and the peripheral/modem status inputs of the ACIA. Receive Data Register Full (RDRF), Bit O - Receive Data Register Full indicates that received data has been transferred to the Receive Data Register. RDRF is cleared after an MPU read of the Receive Data Register or by a master reset. The cleared or empty state indicates that the contents of the Receive Data Register are not current. Data Carrier Detect being high also causes RDRF to indicate empty. Transmit Data Register Empty (TDRE), Bit 1 - The Transmit Data Register Empty bit being set high indicates that the Transmit Data Register contents have been transferred and that new data may be entered. The low state indicates that the register is full and that transmission of a new character has not begun since the last write data command. Data Carrier Detect (DCD), Bit 2 - The Data Carrier Detect bit will be high when the $\overline{DCD}$ input from a modem has gone high to indicate that a carrier is not present. This bit going high causes an Interrupt Request to be generated when the Receive Interrupt Enable is set. It remains high after the $\overline{DCD}$ input is returned low until cleared by first reading the Status Register and then the Data Register or until a master reset occurs. If the $\overline{DCD}$ input remains high after read status and read data or master reset have occurred, the $\overline{DCD}$ status bit remains high and will follow the $\overline{DCD}$ input. Clear-to-Send (CTS), Bit 3 - The Clear-to-Send bit indicates the state of the Clear-to-Send input from a modem. A low CTS indicates that there is a Clear-to-Send from the modem. In the high state, the Transmit Data Register Empty bit is inhibited and the Clear-to-Send status bit will be high. Master reset does not affect the Clear-to-Send Status bit. Framing Error (FE), Bit 4 - Framing error indicates that the received character is improperly framed by a start and a stop bit and is detected by the absence of the 1st stop bit. This error indicates a synchronization error, faulty transmission, or a break condition. The framing error flag is set or reset during the receive data transfer time. Therefore, this error indicator is present throughout the time that the associated character is available. Receiver Overrun (OVRN), Bit 5 - Overrun is an error flag that indicates that one or more characters in the data stream were lost. That is, a character or a number of characters were received but not read from the Receive Data Register (RDR) prior to subsequent characters being received. The overrun condition begins at the midpoint of the last bit of the second character received in succession without a read of the RDR having occurred. The Overrun does not occur in the Status Register until the valid character prior to Overrun has been read. The RDRF bit remains set until the Overrun is reset. Character synchronization is maintained during the Overrun condition. The Overrun indication is reset after the reading of data from the Receive Data Register. Overrun is also reset by the Master Reset. Parity Error (PE), Bit 6 - The parity error flag indicates that the number of highs (ones) in the character does not agree with the preselected odd or even parity. Odd parity is defined to be when the total number of ones is odd. The parity error indication will be present as long as the data character is in the RDR. If no parity is selected, then both the transmitter parity generator output and the receiver parity check results are inhibited. Interrupt Request (IRQ), Bit 7 - The IRQ bit indicates the state of the $\overline{IRQ}$ output. Any interrupt condition with its applicable enable will be indicated in this status bit. Anytime the $\overline{IRQ}$ output is low, the IRQ bit will be high to indicate the interrupt or service request status. Paper Tape Reader Control When the paper tape reader control circuit is used, the $\overline{\text{RTS}}$ output of the ACIA turns the reader on and off. When $\overline{\text{RTS}}$ is high, the reader will be on. When $\overline{\text{RTS}}$ is low, the reader will be off. Therefore, the reader is turned on when CR6 is 1 and CR5 is 0. This also turns off input interrupts. (See ACIA Control Register above.) The reader is off for the three other possible combinations of CR6 and CR5. Interrupt Vectors The processor interrupt vectors are located in locations FFF8 through FFFF within the 680b PROM Monitor. The contents of the interrupt vectors depends on the version of the Monitor being used. Refer to Section VI of the System Monitor Manual for further information. 9 2450 Alamo SE Albuquerque, NM 87106