# MC146805G2 # Advance Information ### 8-BIT MICROCOMPUTER UNIT The MC146805G2 Microcomputer Unit (MCU) belongs to the M146805 CMOS Family of Microcomputers. This 8-bit MCU contains on-chip oscillator, CPU, RAM, ROM, I/O, and TIMER. The fully static design allows operation at frequencies down to dc, further reducing its already low-power consumption. It is a low-power processor designed for low-end to mid-range applications in the consumer, automotive, industrial, and communications markets where very low power consumption constitutes an important factor. The following are the major features of the MC146805G2 MCU ### HARDWARE FEATURES - Typical Full Speed Operating Power of 12 mW at 5 V - Typical WAIT Mode Power of 4 mW - Typical STOP Mode Power of 5 µW - Fully Static Operation - 112 Bytes of On-Chip RAM - 2106 Bytes of On-Chip ROM - 32 Bidirectional I/O Lines - High Current Drive - Internal 8-Bit Timer with Software Programmable 7-Bit Prescaler - External Timer Input - External and Timer Interrupts - Self-Check Mode - Master Reset and Power-On Reset - Single 3 to 6 Volt Supply - On-Chip Oscillator with RC or Crystal Mask Options - 40-Pin Dual-In-Line Package - Chip Carrier Also Available ### SOFTWARE FEATURES - Similar to the MC6800 - Efficient Use of Program Space - Versatile Interrupt Handling - True Bit Manipulation - Addressing Modes with Indexed Addressing for Tables - Efficient Instruction Set - Memory Mapped I/O - Most Self-Check Routines User Callable - Two Power Saving Standby Modes | GENERIC INFORMATION | | | | | |--------------------------------------|-----------------|-------------------------------|------------------------------|--| | Package Type | Frequency (MHz) | Temperature | Generic Number | | | Ceramic | 1.0 | 0°C to 70°C | MC146905G2L | | | L Suffix | 1.0 | -40°C to 85°C | MC146805G2CL | | | Cerdip | 1.0 | 0°C to 70°C | MC146805G2S | | | S Suffix | 1.0 | - 40°C to 85°C | MC146805G2CS | | | Plastic | 1.0 | 0°C to 70°C | MC146805G2P | | | P Suffix | 1.0 | 40°C to 85°C | MC146805G2CP | | | Leadless Chip<br>Carrier<br>Z Suffix | 1.0<br>1.0 | 0°C to 70°C<br>- 40°C to 85°C | MC 146805G2Z<br>MC146805G2CZ | | This document contains information on a new product. Specifications and information herein are subject to change without notice. # **CMOS** (HIGH-PERFORMANCE SILICON-GATE) 8-BIT **MICROCOMPUTER** | PIN ASSIGNMENT | | | | | | | |----------------|---------|---------------------------------|--|--|--|--| | RESET ! | 1 (2) | (1) 40 <b>1</b> V <sub>DD</sub> | | | | | | ĪRQ [ | 2 (3) | (40) 39 OSC1 | | | | | | NUM | 3 (4) | (39) 38 🛭 OSC2 | | | | | | PA7 | 4 (5) | (38) 37 <b>1</b> TIMER | | | | | | PA6 | 5 (6) | (37) 36 <b>1</b> PD7 | | | | | | PA5 | 6 (7) | (36) 35 <b>7</b> PD6 | | | | | | PA4 | 7 (8) | (35) 34 D PD5 | | | | | | PA3 | 8 (9) | (34) 33 🗖 PD4 | | | | | | PA2 | 9 (10) | (33) 32 🗖 PD3 | | | | | | PA1 | 10 (11) | (32) 31 🗖 PD2 | | | | | | PA0 🕻 | 11 (12) | (31) 30 <b>1</b> PD1 | | | | | | PB0 <b>[</b> | 12 (13) | (30) 29 🗖 PD0 | | | | | | PB1 🕻 | 13 (14) | (29) 28 🛮 PC0 | | | | | | PB2 🕻 | 14 (15) | (28) 27 🗖 PC1 | | | | | | РВЗ [ | 15 (16) | (27) 26 PC2 | | | | | | PB4 <b>[</b> | 16 (17) | (26) 25 🗖 PC3 | | | | | | PB5 <b>[</b> | 17 (18) | (25) 24 🗖 PC4 | | | | | | ٦ | 18 (19) | (24) 23 PC5 | | | | | | РВ7 🕻 | 19 (20) | (23) 22 <b>D</b> PC6 | | | | | | vss <b>t</b> | 20 (21) | (22) 21 PC7 | | | | | Pin numbers in parentheses represent equivalent Z suffix chip carrier pins ### MAXIMUM RATINGS (Voltages Referenced to VSS) | Ratings | Symbol | Value | Unit | | |---------------------------------------------|------------------|-----------------------------------------------------------|------|--| | | | -0.3 to +8.0 | V | | | Supply Voltage | V <sub>ID</sub> | V <sub>SS</sub> = 0.5 to V <sub>DD</sub> + 0.5 | V | | | All Input Voltages Except OSC1 | | 10 | mA | | | Current Drain Per Pin Excluding VDD and VSS | | | | | | Operating Temperature Range<br>MC146805G2 | TA | T <sub>L</sub> to T <sub>H</sub><br>0 to 70<br>- 40 to 85 | °C | | | MC146805G2C | T <sub>stq</sub> | - 55 to + 150 | °C | | | Storage Temperature Range | loh | 40 | mA | | | Current Drain Total (PD4-PD7 only) | -011 | | | | THERMAL CHARACTERISTICS | Characteristics | Symbol | Value | Unit | |--------------------------------------------------------|------------------|------------------------|------| | Thermal Resistance Plastic Cerdip Ceramic Chip Carrier | $\theta_{ m JA}$ | 100<br>60<br>50<br>100 | °C/W | This device contains circuitry to protect the inputs against damage due to high static voltages of electric fields, however, it is advised that normal precautions be taken to avoid application of any voltage higher than maximum rated voltages to this high impedance circuit. For proper operation it is recommended that $V_{ID}$ and $V_{OU}$ be constrained to the range $VSS \leq (V_{ID} \text{ or } V_{OU}) \leq V_{OD}$ . Reliability of operation is enhanced if unused inputs except OSC2 and NUM are tied to an appropriate logic voltage level (e.g., either VSS or $V_{OD}$ ). FIGURE 1 -- MC146805G2 CMOS MICROCOMPUTER DC ELECTRICAL CHARACTERISTICS (VDD = 5.0 Vdc $\pm$ 10%, $V_{SS}$ = 0 Vdc, $T_{A}$ = 0° to 70°C unless otherwise noted) | Characteristics Characteristics | Symbol | Min | Max | r | |----------------------------------------------------------------------------------|------------------|-----------------------|-----------------|----------| | Output Voltage I <sub>Load</sub> ≤ 10.0 µA | VOL | 1 | | Unit | | | | V 0 • | 0.1 | V | | Output High Voltage | Voн | $V_{DD} = 0.1$ | _ | | | (ILoad = - 100 µA) PB0-PB7, PC0-PC7 | V | | | | | (I <sub>Load</sub> = - 2 mA) PA0-PA7, PD0 PD3 | VOH | 2.4 | · | V | | (I <sub>Load</sub> = -8 mA) PD4-PD7 | Voн | 2 4 | _ | V | | Output Low Voltage | VOH | 2.4 | | V | | (ILoad = 800 µA) All Ports | | | | | | PAO-PA7, PBO-PB7, PCO-PC7, PDO-PD7 | VOL | - 1 | 0.4 | V | | nput High Voltage | | | | | | Ports PA0-PA7, PB0-PB7, PC0 PC7, PD0 PD7 | 1 | | | | | TIMER, IRQ, RESET, OSC1 | V <sub>IH</sub> | V <sub>DD</sub> = 2.0 | VDD | V | | nput Low Voltage All Inputs | VIH | V <sub>DD</sub> = 0.8 | V <sub>DD</sub> | V | | otal Supply Current ( $C_L = 50$ pF on Ports, no dc Loads, $t_{Cyc} = 1 \mu s$ ) | VIL | VSS | 0.8 | V | | RUN ( $V_{IL} = 0.2 \text{ V}$ , $V_{IH} = V_{DD} - 0.2 \text{ V}$ ) | | | | | | WAIT (See Note) | lDD | - | 4 | mA | | STOP (See Note) | IDD | | 1.5 | mA | | O Ports Input Leakage | DD | _ | 150 | μΑ | | PA0-PA7, PB0-PB7, PC0-PC7, PD0-PD7 | | | | | | nput Current | ήL | - 1 | ± 10 | μΑ | | RESET, IRQ, TIMER, OSC1 | | | | μπ | | apacitance | lin | _ | ± 1 | μΑ | | Ports | | | | - μΑ | | | C <sub>out</sub> | _ 1 | 12 | ρF | | RESET, IRQ, TIMER, OSC1 | Cin | | 8 | pF<br>pF | DC ELECTRICAL CHARACTERISTICS ( $V_{DD} = 3.0 \ \underline{Vdc}$ , $\underline{V_{SS} = 0 \ Vdc}$ , $\underline{T_A} = 0^{\circ}$ to $70^{\circ}$ C unless otherwise noted to the following of the transfer t | Characteristics | Symbol | Min | Max | T | |---------------------------------------------------------------------------|-----------------|--------------------------------------------------|------------------|------| | Output Voltage I <sub>Load</sub> ≤1 0 μA | | IVIIII | | Unit | | | VOL | | 0.1 | V | | Output High Voltage | VOH | V <sub>DD</sub> -01 | | V | | (ILoad = -50 µA) PBO-PB7, PCO-PC7 | l ., | 1 ] | | | | (I <sub>Load</sub> = -0.5 mA) PA0-PA7, PD0-PD3 | Voн | 1.4 | | V | | (I <sub>Load</sub> = -2 mA) PD4-PD7 | Voн | 1.4 | - | V | | Output Low Voltage | ∨он | 1.4 | | V | | (I <sub>Load</sub> = 300 µA) All Ports PA0-PA7, PB0-PB7, PC0-PC7, PD0-PD7 | VOL | | | | | Input High Voltage | - VOL | <del> </del> | 0.3 | V | | Ports PA0-PA7, PB0-PB7, PC0-PC7, PD0-PD7 | VIH | 2.7 | | i | | TIMER, IRO, RESET, OSC1 | | 2.7 | VDD | V | | nput Low Voltage All Inputs | ViH | 2.7 | V <sub>D</sub> D | V | | fotal Supply Current (no dc Loads, t <sub>Cyc</sub> = 5 μs) | V <sub>IL</sub> | VSS | 0.3 | V | | RUN $(V_{IL} = 0.1 \text{ V}, V_{JH} = V_{DD} - 0.1 \text{ V})$ | | 1 | | | | WAIT (See Note) | IDD | | 0.5 | mA | | STOP (See Note) | DD | | 200 | μA | | O Ports Input Leakage | DD | | 100 | μΑ | | PA0-PA7, PB0-PB7, PC0-PC7, PD0-PD7 | | | | | | nput Current | իլ | - | ±5 | μΑ | | RESET, IRQ, TIMER, OSC1 | 1 1 | | | | | apacitance | in | | ± 1 | μΑ | | Ports | 1 . T | | | | | RESET, IRQ, TIMER, OSC1 | Cout | - | 12 | pF | | | C <sub>in</sub> | - 1 | 8 | pF | NOTE Test conditions for I<sub>DD</sub> are as follows All ports programmed as inputs V<sub>IL</sub> = 0.2 V (PA0-PA7, PB0-PB7, PC0-PC7, PD0-PD7) V<sub>IH</sub> = V<sub>DD</sub> = 0.2 V for RESET, IRQ, TIMER OSC1 input is a squarewave from 0.2 V to V<sub>DD</sub> = 0.2 V OSC2 output load = 20 pF (wait I<sub>DD</sub> is affected linearly by the OSC2 capacitance) TABLE 1 - CONTROL TIMING (VDD = 5.0 Vdc $\pm$ 10%. VSS = 0, TA = 0° to 70°C. forc = 4 MHz) | Characteristics | Symbol | Min | Max | Unit | |-------------------------------------------------------------|------------------|------|-----|------------------| | Crystal Oscillator Startup Time (Figure 11) | VOXO | _ | 100 | ms | | Stop Recovery Startup Time (Crystal Oscillator) (Figure 12) | TILCH | - | 100 | ms | | Timer Pulse Width (Figure 10) | tTH, tTL | 0.5 | | tcyc | | Reset Pulse Width (Figure 11) | tRL | 1.5 | _ | tcyc | | Timer Period (Figure 10) | †TLTL | 10 | | toyc | | Interrupt Pulse Width Low (Figure 21) | tiLiH | 10 | - | tcyc | | Interrupt Pulse Period (Figure 21) | tilil | * | _ | t <sub>cyc</sub> | | OSC1 Pulse Width | toH, tOL | 100 | _ | ns | | Cycle Time | t <sub>cyc</sub> | 1000 | _ | ns | | Frequency of Operation Crystal | fosc | | 4 0 | MHz | | External Clock | f <sub>osc</sub> | DC | 4.0 | MHz | <sup>\*</sup>The minimum period t<sub>ILIL</sub> should not be less than the number of t<sub>CVC</sub> cycles it takes to execute the interrupt service routines plus 20 t<sub>CVC</sub> cycles FIGURE 2 -- EQUIVALENT TEST LOAD | Port | Rf | R <sub>2</sub> | |------------|---------|-----------------| | B and C | 24.3 kΩ | 4.32 kΩ | | A, PD0-PD3 | 1.21 kΩ | 3.1 kΩ | | PD4-PD7 | 300 Ω | 1.64 k <b>Ω</b> | FIGURE 3 - TYPICAL OPERATING CURRENT vs INTERNAL FREQUENCY FIGURE 4 - MAXIMUM IDD vs FREQUENCY FIGURE 5 — MAXIMUM IDD vs FREQUENCY FIGURE 6 - MINIMUM IOH, PORT D PINS 33-36 FIGURE 7 - MINIMUM IOH, PORT C FIGURE 8 - MINIMUM IOH, PORT A AND 8 FIGURE 9 - MINIMUM IOL, ALL PORTS \*Internal timing signal and bus information not available externally. \* $\sim 0.0\%$ line is not meant to represent frequency. It is only used to represent time. # FIGURE 12 — STOP RECOVERY AND POWER-ON RESET - \*Internal timing signals not available externally - \*\*Represents the internal gating of the OSC1 input pin # **FUNCTIONAL PIN DESCRIPTION** # V<sub>DD</sub> and V<sub>SS</sub> Power is supplied to the MCU using these two pins. $V_{\mbox{DD}}$ is power and $V_{\mbox{SS}}$ is ground. # IRQ (MASKABLE INTERRUPT REQUEST) $\overline{\text{IRQ}}$ is mask option selectable with the choice of interrupt sensitivity being both level-sensitive, and negative edge-sensitive or negative edge-sensitive only. The MCU completes the current instruction before it responds to the request If $\overline{\text{IRQ}}$ is low and the interrupt mask bit (I bit) in the condition code register is clear, the MCU begins an interrupt sequence at the end of the current instruction. If the mask option is selected to include level sensitivity, then the $\overline{\text{IRO}}$ input requires an external resistor to VDD for "wire-OR" operation. See INTERRUPTS for more detail. ### RESET The RESET input is not required for start-up but can be used to reset the MCU's internal state and provide an orderly software start-up procedure. Refer to RESETS for a detailed description. ### TIMER The TIMER input may be used as an external clock for the on-chip timer. Refer to TIMER for additional information about the timer circuitry. ### NUM - NON-USER MODE This pin is intended for use in self-check only. In user applications, connect this pin to ground through a 10 $\text{k}\Omega$ resistor. ### OSC1, OSC2 The MC146805G2 can be configured to accept either a crystal input or an RC network to control the internal oscillator. Additionally, the internal clocks can be derived by either a divide-by-two or divide-by-four of the internal oscillator output frequency (f<sub>osc</sub>). Both of these options are mask selectable. RC- If the RC oscillator option is selected, then a resistor is connected to the oscillator pins as shown in Figure 13(d). The relationship between R and $f_{\rm OSC}$ is shown in Figure 14. CRYSTAL — The circuit shown in Figure 13(b) is recommended when using a crystal. The internal oscillator is designed to interface with an AT-cut parallel resonant quartz crystal resonator in the frequency range specified for fosc in the electrical characteristics table. Using an external CMOS oscillator is suggested when crystals outside the specified ranges are to be used. The crystal and components should be mounted as close as possible to the input pins to minimize output distortion and start-up stabilization time. Crystal frequency limits are also affected by VDD. Refer to Control Timing Characteristics for limits. See Table 1. **EXTERNAL CLOCK** — An external clock should be applied to the OSC1 input with the OSC2 input not connected, as shown in Figure 13(c). An external clock should be used with the crystal oscillator mask option only. The toxov or tILCH specifications do not apply when using an external clock input. ### PA0-PA7 These eight I/O lines comprise Port A. The state of any pin is software programmable. Refer to INPUT/OUTPUT PROGRAMMING for a description of I/O programming. FIGURE 13 - OSCILLATOR CONNECTIONS | | 1 MHz | 4 MHz | Units | |-------------------|-------|-------|-------| | RSMAX | 400 | 75 | Ω | | Co | 5 | 7 | рF | | C <sub>1</sub> | 0.008 | 0.012 | μĥ | | C <sub>OSC1</sub> | 15-40 | 15-30 | pF | | Cosc2 _ | 15-30 | 15 25 | pF | | Rp | 10 | 10 | МΩ | | 0 | 30 | 40 | K | (a) Crystal Parameters (b) Crystal Oscillator Connections (d) RC Oscillator Connection 3-975 ### PB0-PB7 These eight lines comprise Port B. The state of any pin is software programmable. Refer to INPUT/CUTPUT PROGRAMMING for a description of I/O programming. ### PC0-PC7 These eight lines comprise Port C. The state of any pin is software programmable. Refer to INPUT/OUTPUT PROGRAMMING for a description of I/O programming. #### PD0-PD7 These eight lines comprise Port D. PD4-PD7 also are capable of driving LEDs directly. The state of any pin is soft- ware programmable. Refer to INPUT/OUTPUT PROGRAM-MING for a description of I/O programming. # INPUT/OUTPUT PROGRAMMING Any port pin may be software programmed as an input or output by the state of the corresponding bit in the port data direction register (DDR). A pin is configured as an output if its corresponding DDR bit is set to a logic 1. A pin is configured as an input if its corresponding DDR bit is cleared to a logic 0. At reset, all DDRs are cleared, which configures all port pins as inputs. A port pin configured as an output will output the data in the corresponding bit of its port data latch. Refer to Figure 15 and Table 2. # FIGURE 15 - TYPICAL PORT I/O CIRCUITRY TABLE 2 - I/O PIN FUNCTIONS | R/₩* | DDR | I/O Pin Function | |------|-----|---------------------------------------------------------------------------| | 0 | 0 | The I/O pin is in input mode. Data is written into the output data latch. | | 0 | 1 | Data is written into the output data latch and output to the I/O pin. | | 1 | 0 | The state of the I/O pin is read. | | 11 | 1 | The I/O pin is in an output mode. The output data latch is read. | <sup>\*</sup> R/W is an internal signal ### SELF-CHECK The MC146805G2 self-check is performed using the circuit in Figure 16. Self-check is initiated by connecting NUM and TIMER pins to a logic 1 then executing a reset. After reset, five subroutines are called that execute the following tests: I/O - Functionally exercise ports A, B, C, D RAM - Walking bit test ROM - Exclusive OR with odd 1s parity result Timer - Functionally exercise timer Interrupts - Functionally exercise external and timer interrupts Self-check results are shown in Table 3. The following subroutines are available to user programs and do not require any external hardware. ### **RAM SELF-CHECK SUBROUTINES** Returns with the Z bit clear if any error is detected; otherwise the Z bit is set. The RAM test must be called with the stack pointer at \$007F. When run, the test checks every RAM cell except for \$007F and \$007E which are assumed to contain the return address. A and X are modified. All RAM locations except the top 2 are modified. (Enter at location \$1F80.) ### ROM CHECKSUM SUBROUTINE Returns with Z bit cleared if any error was found, otherwise Z = 1. X = 0 on return, and A is zero if the test passed RAM locations 0040-0043 are overwritten. (Enter at location 1598) #### TIMER TEST SUBROUTINE Return with Z bit cleared if any error was found; otherwise Z = 1 This routine runs a simple test on the timer. In order to work correctly as a user subroutine, the internal clock must be the clocking source and interrupts must be disabled. Also, on exit, the clock will be running and the interrupt mask not set so the caller must protect himself from interrupts if necessary. TABLE 3 - SELF-CHECK RESULTS | PD3 | PD2 | PD1 | PD0 | Remarks | |------------|-----|-----|-----------|-------------------------------| | 1 | 0 | 1 | 0 | Bad I/O | | 1 | 0 | 1 | 1 | Bad Timer | | 1 | 1 | 0 | 0 | Bad RAM | | 1 | 1 | 0 | 1 | Bad ROM | | 1 | 1 | 1 | 0 | Bad Interrupt or Request Flag | | Cycling | | | Good Part | | | All Others | | | Bad Part | | FIGURE 17 - ADDRESS MAP <sup>\*</sup> Reads of unused locations undefined # MC146805G2 A and X register contents are lost; this routine counts how many times the clock counts in 128 cycles. The number of counts should be a power of two since the prescaler is a power of two. If not, the timer probably is not counting correctly. The routine also detects if the timer is running at all. (Enter at location \$1FB5.) ### MEMORY The MC146805G2 has a total address space of 8192 bytes of memory and I/O registers. The address space is shown in Figure 17. The first 128 bytes of memory (first half of page zero) are comprised of the I/O port locations, timer locations, and 112 bytes of RAM. The next 2096 bytes (including the 128 bytes of the second half of page zero) comprise the user ROM. The 10 highest address bytes contain the reset and the interrupt vectors. The stack pointer is used to address data stored on the stack. Data is stored on the stack during interrupts and subroutine calls. At power-up, the stack pointer is set to \$007F and it is decremented as data is pushed on the stack. When data is removed from the stack, the stack pointer is incremented. A maximum of 64 bytes of RAM is available for stack usage. Since most programs use only a small part of the allocated stack locations for interrupts and/or subroutine stacking purposes, the unused bytes are usable for program data storage. #### REGISTERS The MC146805G2 contains five registers, as shown in the programming model in Figure 18. The interrupt stacking order is shown in Figure 19. ### FIGURE 18 - PROGRAMMING MODEL # FIGURE 19 - STACKING ORDER NOTE - Since the Stack Pointer decrements during pushes, the PCL is stacked first, followed by PCH, etc. Pulling from the stack is in the reverse order. ### ACCUMULATOR (A) This accumulator is an 8-bit general purpose register used to hold operands, results of the arithmetic calculations, and data manipulations. ### INDEX REGISTER (X) The X register is an 8-bit register which is used during the indexed modes of addressing. It provides an 8-bit value which is used to create an effective address. The index register is also used for data manipulations with the readmodify-write type of instructions and as a temporary storage register when not performing addressing operations. ### PROGRAM COUNTER (PC) The program counter is a 13-bit register that contains the address of the next instruction to be executed by the processor. ### STACK POINTER (SP) The stack pointer is a 13-bit register containing the address of the next free location on the stack. When accessing memory, the seven most significant bits are permanently configured to 0000001. These seven bits are appended to the six least significant register bits to produce an address within the range of \$007F to \$0040. The stack area of RAM is used to store the return address on subroutine calls and the machine state during interrupts. During external or power-on reset, and during a reset stack pointer (RSP) instruction, the stack pointer is set to its upper limit (\$007F). Nested interrupts and/or subroutines may use up to 64 (decimal) locations, beyond which the stack pointer wraps around and points to its upper limit thereby losing the previously stored information. A subroutine call occupies two RAM bytes on the stack, while an interrupt uses five RAM bytes. # CONDITION CODE REGISTER (CC) The condition code register is a 5-bit register which indicates the results of the instruction just executed. These bits can be individually tested by a program and specific action taken as a result of their state. Each bit is explained in the following paragraphs. HALF CARRY BITS (H) - The H bit is set to a one when a carry occurs between bits 3 and 4 of the ALU during an ADD or ADC instruction. The H bit is useful in binary coded decimal subroutines. **INTERRUPT MASK BIT (I)** — When the I bit is set, both the external interrupt and the timer interrupt are disabled. Clearing this bit enables the above interrupts. If an interrupt occurs while the I bit is set, the interrupt is latched and is processed when the I bit is next cleared. **NEGATIVE (N)** — When set, this bit indicates that the result of the last arithmetic, logical, or data manipulation is negative (bit 7 in the result is a logical 1). **ZERO (Z)** — When set, this bit indicates that the result of the last arithmetic, logical, or data manipulations is 0. **CARRY/BORROW (C)** — When set, this bit indicates that a carry or borrow out of the arithmetic logic unit (ALU) occurred during the last arithmetic operation. This bit is also affected during bit test and branch instructions, shifts, and rotates. ### RESETS The MC146805G2 has two reset modes: an active low external reset pin ( $\overline{RESET}$ ) and a power-on reset function; refer to Figure 11. ### RESET The RESET input pin is used to reset the MCU to provide an orderly software start-up procedure. When using the external reset mode, the RESET pin must stay low for a minimum of one t<sub>CyC</sub>. The RESET pin is provided with a Schmitt Trigger input (internally) to improve its noise immunity. #### POWER-ON RESET The power-on reset occurs when a positive transition is detected on VDD. The power-on reset is used strictly for power turn-on conditions and should not be used to detect any drops in the power supply voltage. There is no provision for a power-down reset. The power-on circuitry provides for a 1920 toyc delay from the time that the oscillator becomes active. If the external RESET pin is low at the end of the 1920 toyc time out, the processor remains in the reset condition. Either of the two types of reset conditions causes the following to occur: - Timer control register interrupt request bit TCR7 is cleared to a "0". - Timer control register interrupt mask bit TCR6 is set to a "1". - All data direction register bits are cleared to logical zeros. All ports are defined as inputs. - Stack pointer is preset to \$007F. - The internal address bus is forced to the reset vector (\$1FFE, \$1FFF). - Condition code register interrupt mask bit (I) is set to a "1". - STOP and WAIT latches are cleared. - External interrupt latch is cleared All other functions, such as other registers (including output ports), the timer, etc. are not cleared by the reset conditions. ### **INTERRUPTS** The MC146805G2 may be interrupted by one of three different methods: either one of two maskable hardware interrupts (external input or timer) or a nonmaskable software interrupt (SWI). Systems often require that normal processing be interrupted so that some external event may be serviced. Interrupts cause the processor registers to be saved on the stack and the interrupt mask (I bit) set to prevent additional interrupts. The RTI instruction causes the register contents to be recovered from the stack followed by a return to normal processing. The stack order is shown in Figure 19. Unlike RESET, hardware interrupts do not cause the current instruction execution to be halted, but are considered pending until the current instruction execution is complete. ### NOTE The current instruction is considered to be the one already fetched and being operated on. When the current instruction is complete, the processor checks all pending hardware interrupts and if unmasked (I bit # MC146805G2 clear), proceeds with interrupt processing; otherwise, the next instruction is fetched and executed. Note that masked interrupts are latched for later interrupt service. If both an external interrupt and a timer interrupt are pending at the end of an instruction execution, the external interrupt is serviced first. The SWI is executed the same as any other instruction and as such takes precedence over hardware interrupts only if the I bit is set (hardware interrupts masked). Refer to Figure 20 for the interrupt and instruction processing sequence. Table 4 shows the execution priority of the RESET, IRO and timer interrupts, and the software interrupt, SWI. Two conditions are shown, one with the I bit set and the other with I bit clear, however, in either case RESET has the highest priority of execution. If the I bit is set as per Table 4(a), the second highest priority is assigned to SWI. This is illustrated in Figure 20 which shows that the IRQ or Timer interrupts are not executed when the I bit is set and the next instruction (including SWI) is fetched. If the I bit is cleared as per Table 4(b), the priorities change in that the next instruction (including SWI) is not fetched until after the IRQ and Timer interrupts have been recognized (and serviced). Also, when the I bit is clear, if both IRQ and Timer interrupts are pending, the IRQ interrupt is always serviced before the Timer interrupt. FIGURE 20 - RESET AND INTERRUPT PROCESSING FLOWCHART # TABLE 4 — INTERRUPT/INSTRUCTION EXECUTION PRIORITY AND VECTOR ADDRESS (a) I Bit Set | Interrupt/Instruction | Priority | Vector<br>Address | |-----------------------|----------|-------------------| | RESET | 1 | \$1FFE-\$1FFF | | SWI | 2 | \$1FFC-\$1FFD | NOTE IRQ and Timer Interrupts are not executed when the I bit is set, therefore, they are not shown ### (b) I Bit Clear | Interrupt/Instruction | Priority | Vector<br>Address | |-----------------------|----------|-------------------| | RESET | 1 | \$1FFE \$1FFF | | ĪRQ | 2 | \$1FFA-\$1FFB | | Timer | 3 | \$1FF8-\$1FF9 | | | | \$1FF6-\$1FF7* | | SWI | 4 | \$1FFC-\$1FFD | <sup>\*</sup> The Timer vector address from the WAIT mode is \$1FF6-\$1FF7 #### NOTE Processing is such that at the end of the current instruction execution, the I bit is tested and if set the next instruction (including SWI) is fetched. If the I bit is cleared, the hardware interrupt latches are tested, and if no hardware interrupt is pending, the program falls through and the next instruction is fetched. ### TIMER INTERRUPT If the timer interrupt mask bit (TCR6) is cleared, then each time the timer decrements to zero (transitions from \$01 to \$00) an interrupt request is generated. The actual processor interrupt is generated only if the interrupt mask bit of the condition code register is also cleared. When the interrupt is recognized, the current state of the machine is pushed onto the stack and the interrupt mask bit in the condition code register is set. This masks further interrupts until the present one is serviced. The processor now vectors to the timer interrupt service routine. The address for this service routine is specified by the contents of \$1FF8 and \$1FF9 unless the processor is in a WAIT mode in which case the contents of \$1FF6 and \$1FF7 specify the timer service routine address. Software must be used to clear the timer interrupt request bit (TCR7). At the end of the timer interrupt service routine, the software normally executes an RTI instruction which restores the machine state and starts executing the inter rupted program. ### EXTERNAL INTERRUPT If the interrupt mask bit of the condition code register is cleared and the external interrupt pin ( $\overline{IRO}$ ) is low, then the external interrupt occurs. The action of the external interrupt is identical to the timer interrupt with the exception that the service routine address is specified by the contents of \$1FFA and \$1FFB Either a level- and edge-sensitive trigger (or edge-sensitive only) are available as mask options. Figure 21 shows both a functional diagram and timing for the interrupt line. The timing diagram shows two different treatments of the interrupt line (IRQ) to the processor. The first method is single pulses on the interrupt line spaced far enough apart to be serviced. The minimum time between pulses is a function of the length of the interrupt service routine. Once a pulse occurs, the next pulse should not occur until the MPU software has exited the routine (an RTI occurs). This time ( $t_{\rm H\,II}$ ) is obtained by adding 20 instruction cycles ( $t_{\rm CVC}$ ) to the total number of cycles it takes to complete the service routine in cluding the RTI instruction; refer to Figure 21. The second configuration shows many interrupt lines "wire-ORed" to form the interrupts at the processor. Thus, if after servicing an interrupt the $\overline{\text{IRO}}$ remains low, then the next interrupt is recognized ### SOFTWARE INTERRUPT (SWI) The software interrupt is an executable instruction. The action of the SWI instruction is similar to the hardware interrupts. The SWI is executed regardless of the state of the interrupt mask in the condition code register. The service routine address is specified by the contents of memory locations \$1FFC and \$1FFD. See Figure 20 for interrupt and instruction processing flowchart. Interrupt Request (MPU) # FIGURE 21 — EXTERNAL INTERRUPT # (a) Interrupt Functional Diagram ### Edge-Sensitive Trigger Condition The minimum pulse width (t<sub>ILIH</sub>) is one ĪRQ -tiLiH t<sub>CVC</sub> The period t<sub>LLIL</sub> should not be less than the number of t<sub>CVC</sub> cycles it takes to execute the interrupt service routine - ULIL plus 20 t<sub>cyc</sub> cycles Level-Sensitive Trigger Condition If after servicing an interrupt the IRO remains low, then the next interrupt is IRQ (MPU) recognized Normally used with Wire-ORed Connection IRQ1 -tilih- (b) Interrupt Mode Diagram ### LOW-POWER MODES ### STOP The STOP instruction places the MC146805G2 in its lowest power consumption mode. In the STOP mode the internal oscillator is turned off, causing all internal processing and the timer to be halted; refer to Figure 22. During the STOP mode, timer control register (TCR) bits 6 and 7 are altered to remove any pending timer interrupt requests and to disable any further timer interrupts. The timer prescaler is cleared. External interrupts are enabled in the condition code register. All other registers and memory remain unaltered. All I/O lines remain unchanged. FIGURE 22 - STOP FUNCTION FLOWCHART ### WAIT The WAIT instruction places the MC146805G2 in a low power consumption mode, but the WAIT mode consumes somewhat more power than the STOP mode. In the WAIT mode, the internal clock is disabled from all internal circuitry except the timer circuit; refer to Figure 23. Thus, all internal processing is halted; however, the timer continues to count normally During the WAIT mode, the I bit in the condition code register is cleared to enable interrupts. All other registers, memory, and I/O lines remain in their previous state. The timer may be enabled to allow a periodic exit from the WAIT mode. If an external and a timer interrupt occur at the same time, the external interrupt is serviced first; then, if the timer interrupt request is not cleared in the external interrupt routine, the normal timer interrupt (not the timer wait interrupt) is serviced since the MCU is no longer in the WAIT mode. ### TIMER The MCU timer contains an 8-bit software programmable counter (timer data register) with a 7-bit software selectable prescaler. Figure 24 contains a block diagram of the timer. The counter may be loaded under program control and is decremented towards zero by the clock input (prescaler output). When the counter decrements to zero, the timer interrupt request bit (i.e., bit 7 of the timer control register TCR) is set. Then, if the timer interrupt is not masked (i.e., bit 6 of the TCR and the 1 bit in the condition code register are both cleared) the processor receives an interrupt. After completion of the current instruction, the processor proceeds to store the appropriate registers on the stack, and then fetches the timer vector address from locations \$1FF8 and \$1FF9 (or \$1FF6 and \$1FF7 if in the WAIT mode) in order to begin servicing. The counter continues to count after it reaches zero, allowing the software to determine the number of internal or external input clocks since the timer interrupt request bit was set. The counter may be read at any time by the processor without disturbing the count. The contents of the counter become stable prior to the read portion of a cycle, and do not change during the read. The timer interrupt request bit (TCR7) remains set until cleared by the software. If the timer interrupt request bit (TCR7) is cleared before the timer interrupt is serviced, the interrupt is lost. TCR7 may also be used as a scanned status bit in a non-interrupt mode of operation (TCR6=1) The prescaler is a 7-bit divider which is used to extend the maximum length of the timer. Bit 0, bit 1, and bit 2 of the TCR are programmed to choose the appropriate prescaler output which is used as the counter input. The processor cannot write into or read from the prescaler; however, its contents are cleared to all zeros by the write operation into TCR when bit 3 of the written data equals a logic one. This allows for truncation-free counting. The timer input can be configured for three different operating modes plus a disable mode, depending on the value written to the TCR4 and TCR5 control register bits. Refer to TIMER CONTROL REGISTER. Wait Oscillator Active Clear I Bit Timer Clock Active All Other Processor Clocks Stop No Reset? Yes No External Interrupt? Yes Timer No Interrupt? (TCR Bit 7 = 1Yes No TCR Restart Bit 6 = 0? Processor Clocks Yes Fetch External Interrupt, Reset, or Timer Interrupt Vector (from WAIT Mode Only) FIGURE 23 — WAIT FUNCTION FLOWCHART # TIMER INPUT MODE 1 If TCR4 and TCR5 are both programmed to a zero, the input to the timer is from an internal clock and the TIMER input pin is disabled. The internal clock mode can be used for periodic interrupt generation, as well as a reference in frequency and event measurement. The internal clock is the instruction cycle clock. During a WAIT instruction, the internal clock to the timer continues to run at its normal rate. # **TIMER INPUT MODE 2** With TCR4=1 and TCR5=0, the internal clock and the TIMER input pin are ANDed to form the timer input signal. This mode can be used to measure external pulse widths. The external timer input pulse simply turns on the internal clock for the duration of the pulse. The resolution of the count in this mode is $\pm 1$ clock; therefore, accuracy im- proves with longer input pulse widths. # TIMER INPUT MODE 3 If TCR4=0 and TCR5=1, then all inputs to the timer are disabled. # TIMER INPUT MODE 4 If TCR4=1 and TCR5=1, the internal clock input to the timer is disabled and the TIMER input pin becomes the input to the timer. The timer can, in this mode, be used to count external events as well as external frequencies for generating periodic interrupts. The counter is clocked on the falling edge of the external signal. Figure 24 shows a block diagram of the timer subsystem. Power-on Reset and the STOP instruction cause the counter to be set to \$FO. # FIGURE 24 -- TIMER BLOCK DIAGRAM ### NOTES - 1. Prescaler and timer data register (8-bit counter) are clocked on the falling edge of the internal clock or external input - 2. The timer data register counts down continuously. # TIMER CONTROL REGISTER (TCR) | 7 | 6 5 | 44 | 3 | _ 2 | 1 | 0 | |---------|---------|--------|------|------|------|------| | TCR7 TC | CR6 TCR | 5 TCR4 | TCR3 | TCR2 | TCR1 | TCRO | All bits in this register except bit 3 are Read/Write bits TCR7 - Timer interrupt request bit: bit used to indicate the timer interrupt when it is logic one. - 1 Set whenever the counter decrements to zero, or under program control. - 0 Cleared on external reset, power-on reset, STOP instruction, or program control. TCR6 - Timer interrupt mask bit: when this bit is a logic one it inhibits the timer interrupt to the processor. - 1 Set on external reset, power-on reset, STOP instruction, or program control. - 0 Cleared under program control. TCR5 ~ External or internal bit: selects the input clock source to be either the external TIMER pin or the internal clock. (Unaffected by reset.) - 1 Select external clock source. - 0 Select internal clock source (period = $t_{CVC}$ ). TCR4 — External enable bit: control bit used to enable the external TIMER pin. (Unaffected by reset.) - 1 Enable external TIMER pin. - 0 Disable external TIMER pin. | TCR5 | _TCR4 | | |--------|-------|----------------------------------------------| | 0 | 0 | Internal clock to timer | | 0 | 1 | AND of internal clock and TIMER pin to timer | | _ 1_ ] | 0 | Inputs to timer disabled | | 1 | 1 | TIMER pin to timer | TCR3 — Timer prescaler reset bit: writing a "1" to this bit resets the prescaler to zero. A read of this location always indicates a "0". (Unaffected by reset.) TCR2, TCR1, TCR0 - Prescaler select bits: decoded to select one of eight outputs of the prescaler. (Unaffected by reset.) | | Pre | scaler | | |------|------|--------|--------| | TCR2 | TCR1 | TCRO | Result | | 0 | 0 | 0 | ÷ 1 | | 0 | 0 | 1 | ÷ 2 | | 0 | 1 | 0 | - 4 | | 0 | 1 | 1 | +8 | | 1 | 0 | 0 | + 16 | | 1 | 0 | 1 | ÷ 32 | | 1 | 1 | 0 | + 64 | | 1 | 1 | 1 | + 128 | ### INSTRUCTION SET The MCU has a set of 61 basic instructions. They can be divided into five different types: register/memory, read-modify-write, branch, bit manipulation, and control. The following paragraphs briefly explain each type. All the instructions within a given type are presented in individual tables. ### REGISTER/MEMORY INSTRUCTIONS Most of these instructions use two operands. One operand is either the accumulator or the index register. The other operand is obtained from memory using one of the addressing modes. The operand for the jump unconditional (JMP) and jump to subroutine (JSR) instructions is the program counter. Refer to Table 5. ### READ-MODIFY-WRITE INSTRUCTIONS These instructions read a memory location or a register, modify or test its contents, and write the modified value back to memory or to the register. The test for negative or zero (TST) instruction is an exception to the read-modify-write sequence since it does not modify the value. Refer to Table 6 ### **BRANCH INSTRUCTIONS** Most branch instructions test the state of the condition code register and if certain criteria are met, a branch is executed. This adds an offset between -127 and +128 to the current program counter. Refer to Table 7. # BIT MANIPULATION INSTRUCTIONS The MCU is capable of setting or clearing any bit which resides in the first 128 bytes of the memory space where all port registers, port DDRs, timer, timer control, and on-chip RAM reside. An additional feature allows the software to test and branch on the state of any bit within the first 256 locations. The bit set, bit clear, and bit test and branch functions are all implemented with a single instruction. For the test and branch instructions, the value of the bit tested is also placed in the carry bit of the condition code register. Refer to Table 8 ### NOTE The MCU is actually capable of operating on the bit set and bit clear instructions anywhere in the first 256 bytes; however, since only ROM resides in the upper 128 bytes the bit set/clear instructions have no effect on the upper 128 bytes. ### CONTROL INSTRUCTIONS These instructions are register reference instructions and are used to control processor operation during program execution. Refer to Table 9. ### OPCODE MAP Table 10 is an opcode map for the instructions used on the MCU. ### ALPHABETICAL LISTING The complete instruction set is given in alphabetical order in Table 11. ### ADDRESSING MODES The MCU uses ten different addressing modes to provide the programmer with an opportunity to optimize the code to all situations. The various indexed addressing modes make it possible to locate data tables, code conversion tables, and scaling tables anywhere in the memory space. Short indexed accesses are single byte instructions, while the longest instructions (three bytes) permit tables throughout memory. Short absolute (direct) and long absolute addressing are also included. Table 11 shows the addressing modes for each instruction, with the effects each instruction has on the condition code register. An opcode map is shown in Table 10. The term "Effective Address" (EA) is used in describing the various addressing modes, and is defined as the byte address to or from which the argument for an instruction is fetched or stored. The ten addressing modes of the processor are described below. Parentheses are used to indicate "contents of" the location or register referred to, e.g., (PC) indicates the contents of the location pointed to by the PC. An arrow indicates "is replaced by", and a colon indicates concatenation of two bytes. For additional details and graphical illustrations, refer to the M6805 Family User's Manual #### INHERENT In inherent instructions, all the information necessary to execute the instruction is contained in the opcode. Operations specifying only the index register or accumulator, and no other arguments, are included in this mode. ### IMMEDIATE In immediate addressing, the operand is contained in the byte immediately following the opcode. Immediate addressing is used to access constants which do not change during program execution (e.g., a constant used to initialize a loop counter). ### DIRECT In the direct addressing mode, the effective address of the argument is contained in a single byte following the opcode byte. Direct addressing allows the user to directly address the lowest 256 bytes in memory with a single two byte in struction. This includes all on-chip RAM and I/O registers and 128 bytes of on-chip ROM. Direct addressing is efficient in both memory and time. $$\label{eq:energy} \begin{split} \mathsf{EA} = & (\mathsf{PC} + 1); \; \mathsf{PC} + \mathsf{PC} + 2 \\ \mathsf{Address} \; \mathsf{Bus} \; \mathsf{High} + 0; \; \mathsf{Address} \; \mathsf{Bus} \; \mathsf{Low} + (\mathsf{PC} + 1) \end{split}$$ ### **EXTENDED** In the extended addressing mode, the effective address of the argument is contained in the two bytes following the opcode. Instructions with extended addressing modes are capable of referencing arguments anywhere in memory with a single three-byte instruction. When using the Motorola assembler, the user need not specify whether an instruction uses direct or extended addressing. The assembler automatically selects the most efficient address mode. $$EA = (PC + 1):(PC + 2), PC \leftarrow PC + 3$$ Address Bus High $\leftarrow (PC + 1), Address Bus Low \leftarrow (PC + 2)$ ### INDEXED, NO OFFSET In the indexed, no offset addressing mode, the effective address of the argument is contained in the 8-bit index register. Thus, this addressing mode can access the first 256 memory locations. These instructions are only one byte long. This mode is used to move a pointer through a table or to address a frequently referenced RAM or I/O location. EA = X; PC $$\leftarrow$$ PC + 1 Address Bus High $\leftarrow$ 0; Address Bus Low $\leftarrow$ X ### INDEXED, 8-BIT OFFSET Here, the EA is obtained by adding the contents of the byte following the opcode to that of the index register; therefore, the operand is located anywhere within the lowest 511 memory locations. For example, this mode of addressing is useful for selecting the m-th element in an n element table. All instructions are two bytes. The contents of the index register (X) is not changed. The contents of (PC+1) is an unsigned 8-bit integer. One byte offset indexing permits look-up tables to be easily accessed in either RAM or ROM. EA = $$X + \{PC + 1\}$$ ; $PC \leftarrow PC + 2\}$ Address Bus High $\leftarrow$ K; Address Bus Low $\leftarrow$ X + $\{PC + 1\}$ Where: K = The carry from the addition of X + $\{PC + 1\}$ # INDEXED, 16-BIT OFFSET In the indexed, 16-bit offset addressing mode, the effective address is the sum of the contents of the unsigned 8-bit index register and the two unsigned bytes following the opcode. This addressing mode can be used in a manner similar to indexed 8-bit offset, except that this three byte instruction allows tables to be anywhere in memory (e.g., jump tables in ROM). As with direct and extended, the M6805 assembler determines the most efficient form of indexed offset; 8 or 16-bit. The content of the index register is not changed. Where: K = The carry from the addition of X + (PC + 2) ### RELATIVE Relative addressing is only used in branch instructions. In relative addressing, the contents of the 8-bit signed byte following the opcode (the offset) is added to the PC if and only if the branch condition is true. Otherwise, control proceeds to the next instruction. The span of relative addressing is limited to the range of $-126\ {\rm to}+129\ {\rm bytes}$ from the branch instruction opcode location. The Motorola assembler calculates the proper offset and checks to see if it is within the span of the branch. EA = PC + 2 + (PC + 1); PC $$\leftarrow$$ EA if branch taken; otherwise, EA = PC $\leftarrow$ PC + 2 ### BIT SET/CLEAR Direct addressing and bit addressing are combined in instructions which set and clear individual memory and I/O bits. In the bit set and clear instructions, the byte is specified as a direct address in the location following the opcode. The first 256 addressable locations are thus accessed. The bit to be modified within that byte is specified within the first three bits of the opcode. The bit set and clear instructions occupy two bytes, one for the opcode (including the bit number) and the other to address the byte which contains the bit of interest. EA = (PC + 1); PC $$\leftarrow$$ PC + 2 Address Bus High $\leftarrow$ 0; Address Bus Low $\leftarrow$ (PC + 1) # BIT TEST AND BRANCH Bit test and branch is a combination of direct addressing, bit set or bit clear addressing, and relative addressing. The actual bit to be tested, within the byte, is specified within the low order nibble of the opcode. The address of the data byte to be tested is located via a direct address in the location immediately following the opcode byte (EA1). The signed relative 8-bit offset is in the third byte (EA2) and is added to the PC if the specified bit is set or clear in the specified memory location. This single three byte instruction allows the program to branch based on the condition of any bit in the first 256 locations of memory. EA1 = $$(PC + 1)$$ Address Bus High $\leftarrow$ 0; Address Bus Low $\leftarrow$ $(PC + 1)$ EA2 = $PC + 3 + (PC + 2)$ ; $PC \leftarrow$ EA2 if branch taken; otherwise, $PC \leftarrow$ $PC + 3$ | Function Mineral Line | | | | | | | | | | ٩ | Addressing Modes | g Modes | ţo. | | | | | | | | |-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------|----------|----------|----------|--------|-----------------|--------|--------|-----|----------|------------------|----------|----------------------|--------|-----|---------------------|---------|------|---------------------|--------| | Myennonic Code Hyen Hyen Code Hyen | | | | mmediate | | | Direct | | | Extended | | ٤ | Indexed<br>to Offset | - | | ndexed<br>3it Offse | £ | - 91 | ndexed<br>Bit Offse | ĵ. | | NAME Code Bytes Cycles | | | o | | * | රි | *** | ** | g ( | | ** | o d | • | • 0 | a 8 | * 6 | Cycles | o o | Bytes | Cvcles | | IVA A6 2 3 C6 3 4 F6 1 3 EB 2 3 C6 3 4 F6 1 3 EB 2 4 DE 3 IVA LDX AE 2 2 2 8F 2 4 CF 3 6 FF 1 4 FF 1 4 FF 2 4 DE 3 6 7 4 DE 3 CF 6 7 4 FF 1 4 FF 2 4 DE 3 6 7 4 FF 1 | Function | Mnemonic | | _ | Cycles | <del>စ</del> ီဝ | Bytes | Cycles | 98 | Bytes | Cycles | 200 | DYIGS | cycles | 3 | 3 | 3 | 3 | , | 4 | | V 10 10 10 10 10 10 10 | Load A from Memory | PA | | 2 | 2 | 98 | 2 | 3 | 99 | က | 4 | 9 | - | m | 9 | 7 | 4 | 8 | 7 | 0 | | STA | Load & from Momon | × | ΔF | ^ | 2 | BE | 2 | 3 | GE | Э | 4 | 丑 | - | 3 | 끒 | 2 | 4 | 30 | 8 | ۵ | | STX — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — | Code A Hollin Welliony | VI.S | ! | | | 87 | 2 | 4 | 5 | 9 | 2 | F7 | - | 4 | £7 | 2 | ည | 07 | е | و | | ADC AB 2 2 6 3 CB 3 4 FB 1 3 EB 2 4 DB 3 CB 3 CB 1 3 EB 2 4 DB 3 CB 3 4 FB 1 3 EB 2 4 DB 3 CB 3 CB 1 3 EB 2 4 DB 3 CB 3 CB 1 3 EB 2 4 DB 3 CB 3 CB 1 3 EB 2 4 DB 3 CB 3 CB 4 FB 1 3 EB 2 4 DB 3 CB 3 CB 4 FB 1 3 EB 2 4 DB 3 3 A FB 1 3 EB 2 4 DB 3 A EB 2 | Store A III INIBITION | × 10 | | | | B | 2 | 4 | ä | 3 | 2 | H | - | 4 | 43 | 2 | ري<br>م | DF | 3 | 9 | | ADC ABC <td>Store A in Memory</td> <td>× 0</td> <td>av</td> <td>,</td> <td>0</td> <td>B.B</td> <td>2</td> <td>m</td> <td>CB</td> <td>6</td> <td>4</td> <td>F8</td> <td>_</td> <td>8</td> <td>EB</td> <td>2</td> <td>4</td> <td>DB</td> <td>3</td> <td>ای</td> | Store A in Memory | × 0 | av | , | 0 | B.B | 2 | m | CB | 6 | 4 | F8 | _ | 8 | EB | 2 | 4 | DB | 3 | ای | | Sus Ao 2 2 8 2 3 60 3 4 FO 1 3 EO 2 4 FO 1 3 EO 2 4 FO 1 3 EO 4 FO 1 3 EO 4 DO 3 EO 4 FO 1 3 EO 2 4 FO 1 3 EO 2 4 FO 1 3 EO 2 4 FO 1 3 EO 4 FO 1 3 EO 4 FO 1 3 EO 4 FO 1 3 EO 4 FO 1 3 EO 4 FO 1 3 EO 4 DO 3 3 4 FO 1 3 EO 4 DO 3 3 4 FO 1 3 EO 4 DO 4 FO | Add Memory to A | ADC | 0 4<br>4 | , ~ | 2 2 | 68 | 2 | m | ව | 3 | 4 | 92 | _ | 8 | 63 | 2 | 4 | 60 | 3 | 5 | | Sec A2 2 2 3 4 F2 1 3 E4 2 4 02 3 AND AA 2 2 8 2 3 CA 3 4 FA 1 3 E4 2 4 0A 3 VA ORA AA 2 3 CA 3 4 FA 1 3 EA 2 4 0A 3 6 A 6 A 6 A 6 A 6 A 6 A 6 A 6 A 6 A 6 A 6 A 6 A 6 A 6 A 6 A 6 A A 6 A A A A A A A A A A A A A A A A A A A A A A | Subtract Memory | SUB | 9 O | 2 | 2 | 88 | 2 | 3 | 8 | 3 | 4 | 50 | _ | e | 60 | 2 | 4 | 0G | 3 | 2 | | AND A4 2 8 C4 3 4 F4 1 3 E4 2 4 D4 3 VA AND AA 2 2 8 2 3 CA 3 4 FA 1 3 EA 2 4 DA 3 A A FA 1 3 EA 2 4 DA 3 A A FA 1 3 EA 2 4 DA 3 A A FA 1 3 EA 2 4 DA 3 A A FA 1 3 EA 2 4 DA 3 A A FA FA FA FA FA FA A B A A FA FA FA A B B A A FA FA FA FA B B B B B B | Subtract Memory from | SBC | A2 | 2 | 2 | B2 | 2 | 3 | C2 | 8 | 4 | F2 | - | 3 | E2 | 2 | 4 | D2 | ω . | വ | | ANU AA AA CA A F F I B CA A A F A F A F A F A F A F A F A F A F A F A F B A F A F B A F B A F B B A B B B C B A F B B B C B A F B B B B C B B B B B C B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B B </td <td>A with Borrow</td> <td></td> <td>3</td> <td>,</td> <td>,</td> <td>P.4</td> <td>2</td> <td>m</td> <td>2</td> <td>m</td> <td>4</td> <td>F4</td> <td>-</td> <td>ю</td> <td>E4</td> <td>2</td> <td>4</td> <td>70</td> <td>ю</td> <td>ď</td> | A with Borrow | | 3 | , | , | P.4 | 2 | m | 2 | m | 4 | F4 | - | ю | E4 | 2 | 4 | 70 | ю | ď | | VMA AR 2 2 8 2 3 6 3 4 F8 1 3 E8 2 4 D8 3 A CMP AB 2 2 8 2 3 C1 3 4 F1 1 3 E8 2 4 D1 3 X Cpx A3 2 2 3 C3 3 4 F3 1 3 E3 2 4 D1 3 BIT A5 2 2 85 2 3 C5 3 4 F5 1 3 E5 4 D5 3 and BIT A5 2 2 3 C5 3 4 F5 1 3 E5 4 D6 3 A8 - - - - - - - - - - - - | AND Memory to A | AND | { { | 1 0 | 2 0 | A B | 2 | 8 | CA | 3 | 4 | FΑ | - | m | EA | 2 | 4 | DA | 3 | 2 | | EOR A8 2 3 CB 3 4 F3 1 3 E1 2 4 D1 3 B1 2 3 C1 3 4 F1 1 3 E1 2 4 D1 3 CPX A3 C2 3 C3 3 4 F3 1 3 E3 4 D3 3 3 3 4 F5 1 3 E6 2 4 D5 3 3 4 F6 1 3 E6 2 4 D5 3 3 4 F6 1 3 E6 2 4 D5 3 3 4 F6 1 3 E6 2 4 D5 3 3 4 F6 1 2 EC 3 5 C7 3 5 C7 3 5 C7 3 6 FD 1 5 | OR Memory with A | A 40 | { | , | • | | | | 1 | , | | 8 | <br> - | , | ď | 0 | 4 | 8 | 8 | ഹ | | CMP A1 2 2 2 81 2 3 C1 3 4 F1 1 3 E1 2 4 D1 3 CPX A3 2 2 8 83 2 3 C3 3 4 F5 1 3 E3 2 4 D3 3 3 BIT A5 2 2 86 2 3 C5 3 4 F5 1 3 E5 2 4 D3 3 JMP 8C 2 2 CC 3 3 FC 1 5 ED 2 6 DD 3 | Exclusive OR Memory with A | EOR | A8 | 2 | 2 | 88 | 2 | m | 3 | n | 4 | 2 | - | , | 3 | · [ | | | . . | . . | | X CPX A3 2 2 83 2 3 4 F3 1 3 E3 2 4 D3 3 e1 BIT A5 2 2 2 3 C5 3 4 F5 1 3 F6 2 4 D5 3 IMP - - - BC 2 C 3 FC 1 2 EC 2 4 D5 3 ISR - - BD 2 C C 3 FC 1 5 ED 2 6 DD 3 | Anthmetic Compare A with Memory | CMP | ٤ | 2 | 2 | 18 | 2 | 9 | 5 | ო | 4 | <u>.</u> | - | m | ā | 2 | 4 | 5 | e | D. | | e) BIT A5 2 2 86 2 3 C5 3 4 F5 1 3 E6 2 4 D5 3<br>JMP BC 2 2 CC 3 3 FC 1 5 EC 2 3 DC 3<br>JSR BD 2 6 CD 3 6 FD 1 5 ED 2 6 DD 3 | Anthmetic Compare X with Memory | CPX | A3 | 2 | 2 | B3 | 2 | т | 8 | 3 | 4 | £3 | - | 6 | E3 | 2 | 4 | 8 | m | C) | | JMP _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ | Bit Test Memory with | | A5 | 2 | 2 | 92 | 2 | ю | S | 8 | 4 | F5 | - | 6 | 83 | 2 | 4 | 25 | e | 2 | | See | Condition is a control of | | | L | | 90 | 2 | 2 | 20 | m | ю | 5 | - | 2 | EC | 2 | 9 | 20 | m | 4 | | | Jump Uncoriginal | S S | | L | , | QB | 2 | 2 | CD | 3 | 9 | FD | _ | 5 | 69 | 2 | 9 | 8 | m | | | | - | | - | Addressin | 5 | | | | ddressin | Addressing Modes | | | | | | | |------------------------|------------|------------|--------------|-----------|----------|--------------|--------|----------|----------|------------------|------|------------------------|--------|----------|---------------------------|--------| | | | = | Inherent (A) | ā | = | Inherent (X) | Q | | Direct | | | Indexed<br>(No Offset) | = | <u>ø</u> | Indexed<br>(8-Bit Offset) | ē | | | | | | | , | 1. | | č | | 40 | ć | 31 | ** | ď | ** | ** | | | Moomoon | <u>ة</u> 6 | Bytes | Cvcles | ရှိ<br>၁ | #<br>Bytes | Cycles | g g | Bytes | Cycles | Code | Bytes | Cycles | Code | Bytes | Cycles | | runction | | AC. | - | | 5 | - | 6 | 30 | 2 | 5 | 2C | - | 5 | 90 | 2 | 9 | | ncrement | IN C | ? . | - | , , | 2 | - | ~ | J.A. | 2 | 2 | 7.4 | - | 5 | 6A | 2 | 9 | | Decrement | DEC | 1 1 | - | 2 | 1 0 | . - | , , | 12. | 0 | ď | 77 | - | S | 9F | 2 | 9 | | Clear | CLB<br>CLB | 44 | _ | າ | b | - | , | 5 | , | , | | | | 00 | 1 | ď | | Complement | COM | 43 | - | 0 | 53 | - | т | 33 | 2 | ۵ | 73 | - | n | 3 | 7 | | | Negate | NEG | 64 | _ | e<br> | 28 | - | т | 8 | 2 | <u>م</u> | 92 | | 2 | 8 | 2 | 9 | | (2's Complement) | 2 | , | | | | Ì | | | | | , | | | 00 | , | u | | Rotate Left Thru Carry | ROL | 49 | - | 8 | 59 | - | m | ee | 2 | ۵ | 5) | - | 0 | 66 | ٦ | | | Rotate Right Thru | ROR | 46 | - | ~<br>— | 38 | - | ж | 98 | 2 | £. | 9/ | - | ഹ | 99 | 2 | 9 | | Cally . | | | | | 3 | - | - | æ | 2 | 2 | 78 | - | 5 | 88 | 7 | 9 | | Logical Shift Left | 127 | 6 | - | 2 | 8 | - | , | 3 3 | , | , | 14 | - | ď | 3 | C | ی | | Logical Shift Right | LSR | 4 | | e<br>- | Z. | | ~ | a' | 7 | 0 | , | - | , | 5 5 | 1 | | | Anthmetic Shift Right | ASR | 47 | L | (*) | 57 | - | 3 | 3, | 2 | 2 | 12 | -!<br>-! | 2 | اُه | 7 | | | Test for Negative | 151 | 04 | _ | 9 | 25 | _ | (M) | <u>e</u> | 2 | 4 | 70 | - | 4 | 09 | 2 | S | TABLE 7 - BRANCH INSTRUCTIONS | | | Relativ | e Address | ing Mode | |----------------------------------------|----------|------------|------------|----------------| | Function | Mnemonic | Op<br>Code | #<br>Bytes | #<br>Cycles | | Branch Always | BRA | 20 | 1 2 | 3 | | Branch Never | BRN | 21 | 2 | 3 | | Branch IFF Higher | ВНІ | 22 | 2 | 3 | | Branch IFF Lower or Same | BLS | 23 | 2 | 3 | | Branch IFF Carry Clear | BCC | 24 | 2 | 3 | | (Branch IFF Higher or Same) | (BHS) | 24 | 2 | 3 | | Branch IFF Carry Set | BCS | 25 | 2 | 3 | | (Branch IFF Lower) | (BLO) | 25 | 2 | 3 | | Branch IFF Not Equal | BNE | 26 | 2 | 3 | | Branch IFF Equal | BEQ | 27 | 2 | 3 | | Branch IFF Half Carry Clear | внсс | 28 | 2 | 3 | | Branch IFF Half Carry Set | BHCS | 29 | 2 | 3 | | Branch IFF Plus | BPL | 2A | | $-\frac{3}{3}$ | | Branch IFF Minus | ВМІ | 2B | 2 | 3 | | Branch IFF Interrupt Mask Bit is Clear | ВМС | 2C | 2 | 3 | | Branch IFF Interrupt Mask Bit is Set | BMS | 2D | 2 | $\frac{3}{3}$ | | Branch (FF Interrupt Line is Low | BIL | 2E | 2 | 3 | | Branch IFF Interrupt Line is High | ВІН | 2F | 2 | $\frac{3}{3}$ | | Branch to Subroutine | BSR | AD | 2 | 6 | TABLE 8 - BIT MANIPULATION INSTRUCTIONS | | <del></del> | | | Addr | essing Mod | es | | |---------------------------|--------------------|------------|------------|-------------|------------|-------------|-------------| | | | В | it Set/Cle | ar | Bit T | est and Bra | inch | | Function | Mnemonic | Op<br>Code | #<br>Bytes | #<br>Cycles | Op<br>Code | #<br>Bytes | #<br>Cycles | | Branch IFF Bit n is Set | BRSET n (n = 0. 7) | | | | 2•n | 3 | | | Branch IFF Bit n is Clear | BRCLR n (n = 07) | | _ | | 01 + 2•n | 3 | - 5 | | Set Bit n | BSET n (n = 07) | 10 + 2•n | 2 | 5 | | | | | Clear Bit n | BCLR n (n = 0 .7) | 11 + 2•n | 2 | 5 | | | | TABLE 9 — CONTROL INSTRUCTIONS | | | | Inherent | | |--------------------------|----------|------------|-------------|---------------| | Function | Mnemonic | Op<br>Code | #<br>Bytes | Cycles | | Transfer A to X | TAX | 97 | 1 | 2 | | Transfer X to A | TXA | 9F | 1 | 2 | | Set Carry Bit | SEC | 99 | 1 | 2 | | Clear Carry Bit | CLC | 98 | 1 | 2 | | Set Interrupt Mask Bit | SEI | 9B | 1 1 | 2 | | Clear Interrupt Mask Bit | CLI | 9A | 1 | 2 | | Software Interrupt | SWI | 83 | 1 | 10 | | Return from Subroutine | RTS | 81 | 1 | 6 | | Return from Interrupt | RTI | 80 | 1 | 9 | | Reset Stack Pointer | RSP | 9C | 1 | | | No-Operation | NOP | 9D . | <del></del> | $\frac{2}{2}$ | | Stop | STOP | 8E | 1 | 2 | | Wait | WAIT | 8F | | | TABLE 10 - M146805 CMOS FAMILY INSTRUCTION SET OPCODE MAP | Ī. | | | | | | | | | | č | | | | | | | | |--------|------------------|-----------------|---------------|--------|-------------|--------------------|------------|------------|-------|-------|--------------|--------------|--------------|--------------|---------------|------------|--------| | Ī | Brt Manipulation | TOTAL DI | Branch | | | Read/ Modry/ Write | 110 | | INI | IN | Z | BIO | EXT IX2 | ž | × | × | 1 | | Ē | 978 | BSC | HE. | AIG. | ΣV | Į.c | <u>×</u> ω | <u> </u> | 00 8 | က § | <b>∀</b> § | 9.5 | ပ <u>ဋ</u> | σē | 1110 | - [ | Š. | | 1 | , 00<br>, | - 58 | 000 | 2 | 0000 | 1010 | 0110 | 2 0 | 5 a | t | SUB 2 | SUB 3 | SUB 4 | SUB | SUB. | SUB . | 08 | | 0 | BRSETO | BSETO | BAA | NEG | NEG<br>P | ב<br>ה<br>ב | NEG<br>X | × 200 | Ž | 7 | IMM | Din 3 | EXT | 3 ×2 | X | S F S | | | ╁ | 50000 | BCI BO | N. N. W. | | | | | | BTS . | | CMP | CMP 2 | CMP EXT | CMP<br>ix2 | CMP<br>1×1 | Z. | -100 | | - 100 | 8 8 8 8 | 2 855 | 2 PEL | | | | | | | 1 | SBC | SBC | SBC | SBC | SBC 4 | SBC | 2 0010 | | 0 | BHSEIT | 85E 1 | 2 67 | -5 | | 6 | 9 | , | S LAN | 1 | CPX 2 | CPX 3 | CPX 4 | CPX | CPX | CPX 3 | e ( | | <br> | BRCLR1<br>3 BTB | BCLR1 | BLS<br>2 REL | COM | AMOO . | XX | ×. | × × | I. | | NWI 5 | 2 OIB | EXT | 3 172 | Z CNA | NO CNA | 4 | | | BRSETZ | BSETZ | 9CC 3 | LSR | LSRA | LSRX | LSR | LSR | | 1 | AND | 2 DIR | 3 AND | 3 AND | 2<br>1X1<br>4 | ×κ | 0010 | | Ť | BRCI B2 | BCLR2 | BCS 3 | - | İ | | | | _ | _ = | BIT 2 | BIT<br>2 DIR | BIT<br>3 EXT | BIT 3 | BIT X | BIT | 0101 | | 1 | 818 | 2 85C | 2 REL | ROR | RORA | RORX | ROR | ROR | | | LDA | LDA 3 | LDA 4 | LDA 3 | LDA 2 | , LDA | 900 | | 010 | 3 BTB | 2 855 | 2 PEL | ACB 5 | ASBA 3 | A SE SE | ASR | ASR 5 | | TAX 2 | | STA | STA | STA 6 | STA 5 | STA | 1110 | | 1210 | 3 81B | 2 85C | 2 BEL | 80 | I C | - N | . x 5 | Į. | † - | CLC 2 | £08 2 | EOR | EOR 4 | EOR 5 | EOR | EOH 3 | 8 20 | | <br>8⊛ | BRSET4<br>3 BTB | BSET4<br>2 BSC | BHCC<br>2 PEL | 2 DIR | TAN TAN | - LOCA | × | * | 1 | TV. | NWI 2 | 2 DIR | 3 57 | 3 VV 2 | ADC | ADC 3 | o | | | BRCLR4 | BCLR4 | BHCS | ROL | ROLA | ROLX | 10F | . AOL<br>* | | SEC | ADC<br>MM | 2 AUC | m | 3 x2 | 2 IX1 | ×m | 1001 | | ő | BTB 5 | 2 BSC<br>SCETES | BPI 3E | 2 OEC | DECA 3 | DECX | DEC | DEC | | CLI 2 | ORA | ORA 3 | ORA<br>3 EXT | ORA 3 | OBA<br>(X) | ORA | 1010 | | 00 | 3 BTB | 2 886 | 2 REL | SIC | <u>z</u> | 2 | × | * | | SEL | ADD | ADD | ~ | ADD 5 | ADD 1 | ADD . | 101 | | m [ | 3 878 | 2 BSC | Z PIE | N.F | 1 | | 140 | 5 | | N. C | 2 | , IMP | MP | ₽<br>MP | MP 3 | JMP 2 | J | | إن | BRSETG | BSET6 | BMC 3 | NC 2 | NCA<br>INCA | NCX<br>INCX | NC . | ž | | TN - | 9 | 2 018 | 3 EXT | 3 IX2 | 2 ix1 | × | 8 4 | | 3 6 | BRCI R6 | 1- | BMS | TST 4 | TSTA | 151) | TST | TST | | NOP . | BSR<br>2 REL | JSR<br>2 DIR | JSR<br>3 EXT | JSR<br>3 IX2 | JSR 5 | JSR<br>X | 201 | | , ë | 3 BTB | 2 850 | A 3 - | 0<br>0 | Ž | 1 | 1 | | STOP | | LDX 2 | LDX 3 | LDX L | 3 LDX 3 | LDX | י א<br>רםא | 1110 | | ر<br>ا | 3 818<br>3 818 | 3 | ~ - | 8 | CLRA 1 | T CLBX | CLR | CLR 5 | WAIT | TXA 2 | | STX 4 | STX<br>3 Ext | STX 6 | STX 5 | STX | ٣Ē | | - 5 | 3 878 | _~ | ~ | ~ | · | 1 | . * | * | Z | | | | | | | | | | Abbreviations for Address Modes | INH Inherent | A Accumulator | X Index Register | IMM Immediate | DIR Direct | EXT Extended | |---------------------------------|--------------|---------------|------------------|---------------|------------|--------------| | ₹ | Ž | ۷ | × | ž | ۵ | ũ | | Index Register | Immediate | Direct | Extended | Relative | Bit Set/Clear | Bit Test and Branch | Indexed (No Offset) | Indexed, 1 Byte (8-8it) Offset | Indexed, 2 Byte (16-Bit) Offset | |----------------|------------------|--------|----------|----------|---------------|---------------------|---------------------|--------------------------------|---------------------------------| | × | Σ | DIR | EXT | HEL | BSC | 818 | × | × | ix2 | | | X Index Register | | | | | | | | | | | | | | | | ISTRUCTION | SET | | | | | | | | | |-----------------|---------------------------------------|-----------------|---------------|-------------|----------------|------------------------|---------------------|----------------------|----------------------|-------------------------|-------|-----|-----|-----|---------------------| | | Addressing Modes | | | | | | | | Condition Cod | | | | | | | | Mnemonic<br>ADC | Inherent | Immediate | Direct | Extended | Relative | Indexed<br>(No Offset) | Indexed<br>(8 Bits) | Indexed<br>(16 Bits) | Bit<br>Set/<br>Clear | Bit<br>Test &<br>Branch | н | ı | N | z | 7 | | ADD | <del></del> | X | X | × | | × | X | X | - Ciour | Diditon | Λ | • | Λ | ╁ | +. | | AND - | ++ | - X | X | _ × | | X | X | X | | | A | • | A | Λ | 12 | | ASL. | +- <del>x</del> + | - <del></del> ^ | <u>x</u> | × | | X | X | X | - | | - | • | Λ | A | i a | | ASR | . 0 | | x | | | Χ | x | | | | • | • | Λ | A | Ā | | BCC | — ^— | | _ X | | | X | X | | - | | • | ě | A | Λ | Ä | | BCLR - | | | | | × | | | | | | • | • | • | • | 1: | | BCS | · + | | | | | | | | × | | • | • | • | • | • | | BEQ | | | | | X | | | | | | • | • | • | • | ۱÷ | | внсс | + | | | | X | | | | ( | | • | • | • | • | | | BHCS | | | | | x | | | | | | • | • | • | ٠ | • | | ВНІ | | | | | $-\hat{x}$ | | | | | | • | • | • | • | • | | BHS | · · · · · · · · · · · · · · · · · · · | + | | + | $-\hat{x}$ | | | | | | • | • | • | • | • | | ВІН | | | | | - ^- | | | | | | • | • | • | • | • | | BIL | | | + | | $-\hat{x}$ | | | | -1 | | • | • | • | • | • | | BIT | | X | $ \times$ $+$ | | | | | | | | • | • | • | • | • | | BLO | | | | ····· ^ | x | × | × | X | | | • | • | Λ | Λ | • | | BLS | | | | | - x | | | | | I | • | • | • | • | • | | вмс | + | | | | $-\frac{x}{x}$ | | | | | I | • | • | • | • | • | | ВМІ | | | + | + | x | + | | | | | • | • | • | • | • | | BMS | | | | | - x | | | | i | | • | • | • | • | • | | BNE | | | + | | - <del>`</del> | | | | | I | • | • | • | • | • | | BPL | | | + | ~ | $-\hat{x}+$ | | | | | | | | • | • | • | | BRA | | | | | $-\hat{x}$ | | | | | | | | • | • | • | | BRN | | | | | $-\hat{x}$ | | | | | | • | | | • | • | | BRCLR | | | | | <del></del> | | + | | | | | | • | • | • | | BRSET | | | | | + | | | | | X | | -+- | _ | • | ٨ | | BSET | | | | | | · | | | | Х | | | | • | Λ | | BSR | | | | | x | | <del> </del> - | | Х | | | | | • | • | | CLC ] | X | | | | <del></del> | | | | | | | | | • | • | | CLI | X | | | <del></del> | + | | + | | | | | | | • | 0 | | CLR | X | | X | | | × | X | | | $\rightarrow$ | | | | • | • | | CMP | | X | × | X | | × | $\hat{x}$ | | -+ | | | | | 1 | • | | сом | X | | X | | | - <del>x</del> | $\hat{x}$ | X | | | | | | Λ | Λ | | CPX | | X | X | X | | - <del>x</del> + | - x | $\overline{x}$ | | | | | | Δ | 1 | | DEC | X | | X | | | X | $\frac{\hat{x}}{x}$ | ^ | -+ | | | • . | ٨ | Ā | Λ | | EOR | | X | _ X | X | · | × | x | × | | | | | | Λ | • | | INC | X | | X | | | X | X | -^-+ | | | | | | Λ | • | | JMP | | | X | X | - | X | × | X | | -+ | | | | Λ | • | | JSR | | | _X | X | - | X | X | X | | | | | | - 1 | <del>:</del> - | | LDA | | X | X | × | | X | x | - x | | | | | | | ÷ | | LDX | | Х | X | X | | × | X | <del>x</del> | | | | | | | • | | LSL | X | | Х | | | X | X | | | | • | | | | _ | | LSR | X | | X | | | X | X | | | | • | | | | Λ_ | | NEG<br>NOP | X | | X | | | X | _x | | | | • | | | | <u>^</u> | | ORA | X | | | | | | | | | | • | | | | Ā | | ROL | | X | X | X | | × | X | $\overline{x}$ | | | • | | | | | | ROR | × | | _X | | | × | X | | -+ | | | | | | <del>,</del> | | RSP | X | | X | | | X | X | -+ | | | | | | | $\frac{1}{\lambda}$ | | RTI | X | | | | | | | | | | | | | | - | | RTS | X | | | | | | | | -+ | | 7 1 7 | | | | , | | SBC | Х | | | | | | | | _ +- | | • • | | | | $\vdash$ | | SEC | × | x | _ X | X | | X | X | x | -+- | | • | | | | | | SEI | | | | | | | | | - | | • | | | | $\vdash$ | | STA | X | | <del></del> | | | | | | _ | | 1 | | | | | | STOP | -x | | х | × | | X | x | X | $\overline{}$ | | • | | | | | | STX | _^ - | | -, | | | | | | | | 0 | | | | | | SUB | | × | X | X | | X | X | X | | | | | | | | | SWI | - x | _^ _ | X | × | | X | х | X | | | | | | | _ | | TAX | $\hat{\mathbf{x}}$ | | | | | | | | | | | | | | | | TST | x | | | | | | | | | -+i | | | 1 - | | | | TXA | <del>x</del> | | Х | | | Х | Х | | $\neg$ | | | | | | _ | | WAIT | $\frac{\cdot}{\mathbf{x}} + -$ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | # Condition Code Symbols - H Half Carry (From Bit 3) I Interrupt Mask N Negative (Sign Bit) Z Zero C Carry/Borrow - A Test and Set if True Cleared Otherwise Not Affected Load CC Register From Stack Cleared Set Set # ORDERING INFORMATION The following information is required when ordering a custom MCU. This information may be transmitted to Motorola in the following media: EPROM(s) MCM2716s or MCM2532s MDOS disk file To initiate a ROM pattern for the MCU, it is necessary to first contact your local field service office, local sales person, or your local Motorola representative. #### **EPROMs** The MCM2716 or MCM2532 type EPROMs, programmed with the customer program (positive logic sense for address and data), may be submitted for pattern generation. The EPROMs must be clearly marked to indicate which EPROM corresponds to which address space. Figure A-1 illustrates the recommended marking procedure for two MCM2716 EPROMs. After the EPROM(s) are marked, they should be placed in conductive IC carriers and securely packed. Do not use styrofoam. FIGURE A-1 - EPROM MARKING xxx = Customer ID ### VERIFICATION MEDIA All original pattern media (EPROMs or floppy disk) are filed for contractual purposes and are not returned. A computer listing of the ROM code will be generated and returned along with a listing verification form. The listing should be thoroughly checked and the verification form completed, signed, and returned to Motorola. The signed verification form constitutes the contractual agreement for creation of the customer mask. If desired, Motorola will program a blank 2716 EPROM (supplied by the customer) from the data file used to create the custom mask to aid in the verification program. # ROM VERIFICATION UNITS The MCUs containing the customer's ROM pattern will be sent for program verification. These units will have been made using the custom mask but are for the purpose of ROM verification only. For expediency they are usually unmarked, packaged in ceramic, and tested only at room temperature and 5 volts. These RVUs are included in the mask charge and are not production parts. These RVUs are not backed nor guaranteed by Motorola Quality Assurance. #### FLEXIBLE DISKS The disk media submitted must be single-sided, singledensity, 8-inch, MDOS compatible floppies. The customer must write the binary file name and company name on the disk with a felt-tip pen. The floppies are not to be returned by Motorola as they are used for archival storage. The minimum MDOS system files as well as the absolute binary object file (filename LO type of file) from the M6805 cross assembler must be on the disk. An object file made from a memory dump using the ROLLOUT command is also admissable. Consider submitting a source listing as well as the following files: filename.LX (EXORciser loadable format) and filename.SA (ASCII Source Code). These files will of course be kept confidential and are used 1) to speed up the process in house if any problems arise, and 2) to speed up our customer to factory interface if a user finds any software errors and needs assistance quickly from the factory representatives MDOS is Motorola's Disk Operating System available on development systems such as EXORciser, EXORset, etc. | | ١ | |--|---| | | ě | | | 1 | | | | | Option List Select the options one in each section. | for your MCU from the following list | . A manufacturing mask will be generated from th | nis information. Select | |-----------------------------------------------------|--------------------------------------|--------------------------------------------------|-------------------------| | Internal Oscillator Inp Crystal Resistor | out | | | | Internal Divide | | | | | nterrupt Trigger Edge-Sensitiv Level-Sensitiv | e Only<br>ve and Edge-Sensitive | | | | Customer Name | | | | | Address | | | | | City | | State | Z <sub>I</sub> n | | | | Extension | | | | | | | | | ber | _ | | | | | | | | Pattern Media | | | | | | 2708 EPROM | | | | | 2716 EPROM | | | | | MDOS Disk File | | | | | Silent 700 Cassette | | | | | Card Deck | | | | | Tape of Card Deck | | | | | (Note 2) | | | | | | | | | Notes: (2) Other med | dia require prior factory approval. | | | | Signature | | | | | | | | | | | | | | Silent 700 Cassette is a trademark of Texas Instruments Incorporated