# MC6805R2 # Technical Summary # 8-Bit Microcontroller Unit The MC6805R2 (HMOS) Microcontroller Unit (MCU) is a member of the MC6805 Family of microcontrollers. This low cost and high-speed MCU has parallel I O capability with pins programmable as input or output. This publication contains condensed information on the MCU; for detailed information, refer to M6805 HMOS, M146805 CMOS Family User's Manual (M6805UM(AD2)) or contact your local Motorola sales office. Refer to the block diagram for the hardware features and to the list below for additional features available on the MCU. - Internal 8-Bit Timer with 7-Bit Prescaler - On-chip Oscillator - Memory Mapped I O - Versatile Interrupt Handling - True Bit Manipulation - · Bit Test and Branch Instruction - Vectored Interrupts - Self-Check Mode - 2048 Bytes of ROM - 64 Bytes of RAM - 24 Bidirectional I/O Ports - A.D Converter #### **BLOCK DIAGRAM** This document contains information on a new product. Specifications and information herein are subject to change without notice. # MOTOROLA MICROPROCESSOR DATA 3-433 3 ## SIGNAL DESCRIPTION #### Vcc AND Vss Power is supplied to the microcomputer using these two pins. V<sub>CC</sub> is +5.25 volts ( $\pm0.5\Delta$ ) power, and V<sub>SS</sub> is ground. #### NUM This pin is not for user applications and must be connected to $V_{SS}$ . #### INT This pin provides the capability for asynchronously applying an external interrupt to the MCU. Refer to **INTER-RUPTS** for more detailed information. ## **EXTAL, XTAL** These pins provide control input for the on-chip clock oscillator circuit. A crystal, a resistor/capacitor combination, or an external signal (depending upon selected manufacturing mask option) is connected to these pins to provide a system clock. #### RC Oscillator With this option, a resistor is connected to the oscillator pins as shown in Figure 1. The relationship between R and $f_{OSC}$ is shown in Figure 2. Piezoelectric ceramic resonators which have the equivalent specifications may be used instead of crystal oscillators. Follow ceramic resonator manufacturer's suggestions for C<sub>0</sub>, C<sub>1</sub>, and R<sub>S</sub> values. Excludes Resistor Tolerance/ External Resistor NOTE: The recommended C<sub>L</sub> value with a 4.0 MHz crystal is 27 pF maximum, including system distributed capacitance. There is an internal capacitance of approximately 25 pF on the XTAL pin. For crystal frequencies other than 4 MHz, the total capacitance on each pin should be scaled as the inverse of the frequency ratio. For example, with a 2 MHz crystal, use approximately 50 pF on EXTAL and approximately 25 pF on XTAL. The exact value depends on the Motional-Arm parameters of the crystal used. Figure 2. Typical Frequency vs Resistance for RC Oscillator Option Only # Crystal The circuit shown in Figure 1 is recommended when using a crystal. Using an external CMOS oscillator is recommended 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 startup stabilization time. Refer to ELECTRICAL SPECIFICATIONS for VCC specifications. Figure 1. Oscillator Connections #### **External Clock** An external clock should be applied to the EXTAL input with the XTAL input connected to ground, as shown in Figure 1. This option may only be used with the crystal oscillator option selected in the mask option register. The tOXOV or tILCH specifications do not apply when using an external clock input. #### TIMER This pin is used as an external input to control the internal timer/counter circuitry. This pin also detects a higher voltage level used to initiate the self-test program. #### RESET This pin has a Schmitt trigger input and an on-chip pullup. The MCU can be reset by pulling RESET low. # INPUT/OUTPUT LINES (PA0-PA7, PB0-PB7, PC0-PC7, PD0-PD7) These 32 lines are arranged into four 8-bit ports (A, B, C, and D). Ports A, B, and C are programmable as either inputs or outputs under software control of the data direction registers. Port D is a fixed input port and not controlled by any data direction register. Port D has up to four analog inputs, plus two voltage reference inputs when the A/D converter is used (PD5/VRH, PD4/VRL) and an INT2 input. All Port D lines can be read directly and used as binary inputs. If any analog input is used, then PD5/VRH and PD4/VRL must be used in the analog mode. Refer to **PROGRAMMING** and **ANALOG-TO-DIGITAL CONVERTER** for additional information. ## **PROGRAMMING** # INPUT/OUTPUT PROGRAMMING Port A, B, and C pins are programmable as either input or output under software control of the corresponding data direction register (DDR). Port D lines are input only. The port I/O programming is accomplished by writing the corresponding bit in the port DDR to a logic one for output and a logic zero for input. On reset, all the DDRs are initialized to a logic zero state to put the ports in the input mode. The port output registers are not initialized on reset and should be written to before setting the DDR bits. When programmed as outputs, the latched output data is readable as input data regardless of the logic levels at the output pin due to output loading. The latched output data bit may always be written. Therefore, any write to a port writes all of its data bits, even though the port DDR is set to input. This port write may be used to initialize the data registers and avoid undefined outputs. Care must be exercised when using read-modify-write instructions since the data read corresponds to the pin level if the DDR is an input (zero) and also to the latched output when the DDR is an output (one). Refer to Table 1 for I/O functions and to Figure 3 for typical port circuitry. Port D provides reference voltage $(\overline{INT2})$ and multiplexed analog inputs. Port D can always be used as digital input and may be used for analog if VRH and VRL are connected to the appropriate reference voltage. The VRH (PD5) and VRL (PD4) are internally connected to the A/D resistor. Table 1. I/O Pin Functions | | Data<br>Direction<br>Register<br>Bit | Latched<br>Output<br>Data<br>Bit | Output<br>State | Input<br>To<br>MCU | |---|--------------------------------------|----------------------------------|-----------------|--------------------| | | 1 | 0 | 0 | 0 | | - | 1 | 1 | 1 | 1 | | | 0 | X | Hi-Z** | Pin | <sup>\*\*</sup>Ports B and C are three-state ports. Port A has optional internal pullup devices to provide CMOS data drive capability. #### **MEMORY** The MCU is capable of addressing 4096 bytes of memory and I/O registers. The memory map is shown in Figure 4. The locations consist of user ROM, self-check ROM, user RAM, A/D registers, a miscellaneous control register, Figure 3. Typical Port I/O Circuitry and Register Configuration # MOTOROLA MICROPROCESSOR DATA 3-435 <sup>\*</sup>Caution: Data direction registers (DDRs) are write-only; they read as \$FF Figure 4. Memory Map and I/O. The interrupt and reset vectors are located from \$FF8 to \$FFF. The stack area is used during processing of an interrupt or subroutine call to save the CPU state. The stack pointer decrements during pushes and increments during pulls. Refer to INTERRUPTS for additional information. ### NOTE Using the stack area for data storage or temporary work locations requires care to prevent it from being overwritten due to stacking from an interrupt or subroutine call. # REGISTERS The MCU contains the registers described in the following paragraphs. ### **ACCUMULATOR (A)** The accumulator is a general purpose 8-bit register used to hold operands and results of arithmetic calculations or data manipulations. # INDEX REGISTER (X) The index register is an 8-bit register used for the indexed addressing mode. It contains an 8-bit value that may be added to an 8- or 16-bit immediate value to create an effective address. The index register may also be used as a temporary storage area. ## **PROGRAM COUNTER (PC)** The program counter is an 12-bit register that contains the address of the next byte to be fetched. ## STACK POINTER (SP) The stack pointer is an 12-bit register that contains the address of the next free location on the stack. During an MCU reset or the reset stack pointer (RSP) instruction, the stack pointer is set at location \$07F. The stack pointer is then decremented as data is pushed onto the stack and incremented as data is pulled from the stack. The seven most-significant bits of the stack pointer are permanently set at 0000011. Subroutines and interrupts may be nested down to location \$061 (31 bytes maximum), which allows the programmer to use up to 15 levels of subroutine calls (less if interrupts are allowed). | 11 | | | | | | 5 | 4 | 0 | |----|---|---|---|---|---|---|----|---| | 0 | 0 | 0 | 0 | 0 | 1 | 1 | SP | | ### CONDITION CODE REGISTER (CC) The condition code register is a 5-bit register in which four bits are used to indicate the results of the instruction just executed. These bits can be individually tested by a program, and specific actions can be taken as a result of their state. Each bit is explained in the following paragraphs. | 4 | | | | 0 | |---|---|---|---|---| | Н | 1 | N | Z | С | #### Half Carry (H) This bit is set during ADD and ADC operations to indicate that a carry occurred between bits 3 and 4. #### Interrupt (I) When this bit is set, the timer and external interrupt is masked (disabled). If an external interrupt occurs while this bit is set, the interrupt is latched and is processed as soon as the interrupt bit is cleared. #### Negative (N) When set, this bit indicates that the result of the last arithmetic, logical, or data manipulation was negative (bit 7 in the result is a logic one). #### Zero (Z) When set, this bit indicates that the result of the last arithmetic, logical, or data manipulation was zero. ### Carry/Borrow (C) When set, this bit indicates that a carry or borrow out of the arithmetic logical unit (ALU) occurred during the last arithmetic operation. This bit is also affected during bit test and branch instructions, and during shifts and rotates. #### **SELF-CHECK** The self-check is initiated by connecting the MCU as shown in Figure 5 and then monitoring the output of port C (bit 3) for an oscillation of approximately 7 Hz. The following test are executed automatically: I/O - Functionally exercise I/O ports. RAM - Walking bit test. ROM -- Exclusive OR with ODD "1st" parity result. Timer — functionally exercise timer. Interrupts — Functionally exercise external and timer interrupts. A/D Converter — Functionally test the Analog-to-Digital Converter. The RAM, ROM, and the A/D test can be called by a user program. The timer test may be called if the timer input is the internal clock. Table 2 shows the status of the LEDs as a result of a failure. Port C is tested only once (just after reset). If port C fails, no lights will appear. Table 2. Self-Check Error Patterns | PC0 | PC1 | PC2 | РС3 | Remarks (1: LED ON; 0: LED OFF) | |-----|---------|-------|-----|---------------------------------| | 1 | 0 | 1 | 0 | Bad I/O | | 0 | -0 | 1 | 0 | Bad Timer | | 1 | 1 | 0 | 0 | Bad RAM | | 0 | 1 | 0 | 0 | Bad ROM | | 1 | 0 | 0 | 0 | Bad A/D | | 0 | 0 | 0 | 0 | Bad Interrupts or Request Flag | | | All Fla | shing | | Good Device | Anything else Bad Part, Bad Port C, etc. This connection depends on clock oscillator user selectable mask option. Use jumper if the RC mask option is selected. Figure 5. Self-Check Connections #### RESETS The MCU can be reset three ways: (1) by initial power-up, (2) by the external reset input (RESET), and (3) by an optional, internal, low-voltage detect circuit. The RESET input consists mainly of a Schmitt trigger that senses the RESET line logic level. #### POWER-ON-RESET (POR) An internal reset is generated on power-up that allows the internal clock generator to stabilize. The power-on reset is used strictly for power turn-on conditions and should not be used to detect any drop in the power supply voltage. A delay of t<sub>RHL</sub> milliseconds is required before allowing the RESET input to go high. Connecting a capacitor to the RESET input (Figure 6) typically provides sufficient delay. #### **EXTERNAL RESET INPUT** The MCU is reset when a logic zero is applied to the RESET input for a period longer than one machine cycle (tcyc). Under this type of reset, the Schmitt trigger switches off at VIRES – to provide an internal reset voltage. #### LOW-VOLTAGE INHIBIT (LVI) The optional low-voltage detection circuit causes a reset of the MCU if the power supply voltage falls below a certain level ( $V_L v_I$ ). The only requirement is that the $V_{CC}$ must remain at or below the $V_L v_I$ threshold for one $t_{CyC}$ minimum. In typical applications, the V<sub>CC</sub> bus filter capacitor will eliminate negative-going voltage glitches of less than one t<sub>CyC</sub>. The output from the low-voltage detector is connected directly to the internal reset circuitry. It also forces the RESET pin low via a strong discharge device through a resistor. The internal reset is removed once the power supply voltage rises above a recovery level (V<sub>LVR</sub>) at which time a normal power-on reset occurs. #### INTERRUPTS The MCU can be interrupted four different ways: (1) through the external interrupt $\overline{\text{INT}}$ input pin, (2) with the internal timer interrupt request, (3) using the software interrupt instruction (SWI) or (4) the external port D bit 6 ( $\overline{\text{INT2}}$ ) input pin. 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, and then normal processing resumes. The stacking order is shown in Figure 7. Unlike RESET, hardware interrupts do not cause the current instruction execution to be halted but are considered pending until the current instruction is complete. #### NOTE The current instruction is considered to be the one already fetched and being operated on. Figure 6. RESET Configuration <sup>\*</sup>For subroutine calls, only PCH and PCL are stacked Figure 7. Interrupt Stacking Order When the current instruction is complete, the processor checks all pending hardware interrupts and, if unmasked (I bit clear), proceeds with interrupt processing; otherwise, the next instruction is fetched and executed. Masked interrupts are latched for later interrupt service. If the timer interrupt status bit is cleared before unmasking the interrupt, then the interrupt is not latched. 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 regardless of the setting of the I bit. Refer to Figure 8 for the reset and interrupt instruction processing sequence. #### TIMER INTERRUPT If the timer 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 (CCR) is also cleared. When the interrupt is recognized, the current state of the machine is pushed onto the stack and the l bit in the CCR is set, masking further interrupts until the present one is serviced. The contents of the timer interrupt vector, containing the location of the timer interrupt service routine, is then loaded into the program counter. 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 interrupted program. ## **EXTERNAL INTERRUPT** The external interrupt is internally synchronized and then latched on the falling edge of INT and INT2. Clearing the I bit enables the external interrupt. The INT2 interrupt has an interrupt request bit (bit 7) and a mask bit (bit 6) in the miscellaneous register (MR). The $\overline{\text{INT2}}$ interrupt is inhibited when the mask bit is set. The $\overline{\text{INT2}}$ is always read as a digital input on port D. The $\overline{\text{INT2}}$ and timer interrupt request bits, if set, cause the MCU to process and interrupt when the condition code I bit is clear. The following paragraphs describe two typical external interrupt circuits. ## **Zero-Crossing Interrupt** A sinusoidal input signal (f<sub>INT</sub> maximum) can be used to generate an external interrupt (see Figure 9a) for use as a zero-crossing detector (for negative transitions of the ac sinusoid). This type of circuit allows applications Figure 8. Reset and Interrupt Processing Flowchart such as servicing time-of-day routines and engaging/disengaging ac power control devices. Off-chip, full-wave rectification provides an interrupt at every zero crossing of the ac signal and thereby provides a 2f clock. ### Digital-Signal Interrupt With this type of circuit (Figure 9b), the INT pin can be driven by a digital signal. The maximum frequency of a signal that can be recognized by the TIMER or INT pin logic is dependent on the parameter labeled tWL, tWH. Refer to TIMER for additional information. #### SOFTWARE INTERRUPT (SWI) The SWI is an executable instruction that is executed regardless of the state of the I bit in the CCR. If the I bit is zero, SWI executes after the other interrupts. The SWI execution is similar to the hardware interrupts. #### TIMER The MCU consists of an 8-bit software programmable counter driven by a 7-bit prescaler. The timer source is made during manufacturing as a mask option. The 8-bit counter may be loaded under program control and is decremented toward zero. When the timer reaches zero, the timer interrupt request bit (bit 7) in the timer control register (TCR) is set. Refer to Figure 10 for timer block diagram. The timer interrupt can be masked (disabled) by setting the timer interrupt mask bit (bit 6) in the TCR. When the I bit in the condition code register is cleared, the processor receives the interrupt. The MCU responds to this interrupt by 1) saving the present CPU state on the stack, 2) fetching the timer interrupt vector, and 3) executing the interrupt routine. The timer interrupt request bit must be cleared by software. The TIMER and INT2 share the same interrupt vector, therefore the interrupt routine must check the request bits to determine the source of the interrupt. Refer to **RESETS** and **INTERRUPTS** for additional information. The prescaler is a 7-bit divider which is used to extend the maximum length of the timer. To avoid truncation errors, the prescaler is cleared when TCR bit 3 is set to a logic one; however, the TCR bit 3 always reads as a logic zero to ensure proper operation with read-modifywrite instructions. The timer continues to count past zero, falling from \$00 through \$FF, and continues the countdown. The counter can be read at any time by reading the timer data register (TDR). This allows a program to determine the length of time since a timer interrupt has occurred without disturbing the counting process. Three machine cycles are required for a change in state of the TIMER pin to decrement the timer prescaler. Clock input to the timer can be from an external source or from the internal phase two signal. Clock source is one of the mask options. A prescaler mask option is available to select a divide option of a power of two up to 128. Figure 9. Typical Interrupt Circuits Figure 10: Timer Block Diagram ## MOTOROLA MICROPROCESSOR DATA 3-440 #### TIMER CONTROL REGISTER (TCR) (\$009) This 8-bit register controls various functions such as write timer interrupt request, timer interrupt inhibit, and prescaler clear. Bit 3 is write only. | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|--------|-----|---|----|-----|---|---|-----| | | TIR | TIM | 1 | 1 | PSC | 1 | 1 | 1 1 | | F | RESET: | 1 | Ш | 11 | | Ш | D | Ð | #### TIR - Timer Interrupt Request Used to indicate the timer interrupt when it is logic - T ≈ Set when the timer data register changes to all zeros. - 0 = Cleared by external reset, power-on reset, or under program control. TIM — Timer Interrupt Mask Used to inhibit the timer interrupt. - 1 = Interrupt inhibited. - 0 = Interrupt enabled. PSC — Prescaler Clear Write only bit. Writing a one to this bit resets the prescaler to zero. A read of this location always indicates a zero. Bits 5, 4, 2, 1, 0 - Not Used. #### ANALOG-TO-DIGITAL CONVERTER The chip resident 8-bit analog-to-digital (A/D) converter uses a successive approximation technique as shown in Figure 11. Four external analog inputs can be connected to the A/D through a multiplexer via Port D. Four internal analog channels (VRH-VRL, VRH-VRL/2, VRH-VRL/4, and VRL) may be selected for calibration. The accuracy of these internal channels may not meet the accuracy specifications of the external channels. Multiplexer selection is controlled by the A/D control register (ACR) bits 0, 1, and 2. Refer to Table 3 for multiplexer selection. The ACR is shown in Figure 11. The converter uses 30 machine cycles to complete a conversion of a sampled analog input. When the conversion is complete, the digital value is placed in the A/D result register (ARR), the conversion flag set, selected input is sampled again, and a new conversion starts. When ACR7 is cleared, the conversion in progress is aborted and the selected input is sampled for five machine cycles and held internally. Table 3. A/D Input MUX Selection | A/D Co | ontrol R | egister | Input | A/D | Output | (Hex) | |--------|----------|---------|--------------------------------------------|-----|--------|-------| | ACR2 | ACR1 | ACR0 | Selected | Min | Тур | Max | | 0 | 0 | 0 | AN0 | | | | | 0 | 0 | 1 1 | AN1 | | | | | 0 | 1 | 0 | AN2 | | | 1 | | 0 | 1 | 1 | AN3 | | ł | | | 1 | 0 | 0 | V <sub>RH</sub> * | FE | FF | FF | | 1 | 0 | 1 | V <sub>RL</sub> * | 00 | 00 | 01 | | 1 | 1 | 0 | | 3F | 40 | 41 | | 1 | 1 | 1 1 | V <sub>RH</sub> /4*<br>V <sub>RH</sub> /2* | 7F | 80 | 81 | <sup>\*</sup>Internal (Calibration) Levels The converter uses $V_{RH}$ and $V_{RL}$ as reference voltages. An input voltage equal to or greater than $V_{RH}$ converts to \$FF. An input voltage equal to or less than $V_{RL}$ , but greater than $V_{SS}$ , converts to \$00. Maximum and minimum ratings must not be exceeded. Each analog input source should use $V_{RH}$ as the supply voltage and be referenced to $V_{RL}$ for the ratiometric conversion. To maintain full accuracy of the A/D, three requirements should be followed: (1) $V_{RH}$ should be equal to or less than $V_{DD}$ , (2) $V_{RL}$ should be equal to or greater than $V_{SS}$ but less than maximum specifications, and (3) $V_{RH}$ – $V_{RL}$ should be equal to or greater than $V_{SS}$ The A/D has a built-in 1/2 LSB offset intended to reduce the magnitude of the quantizing error to $\pm$ 1/2 LSB, rather than +0, -1 LSB with no offset. This implies that, ignoring errors, the transition point from \$00 to \$01 occurs at 1/2 LSB above V<sub>RL</sub>. Similarly, the transition from \$FE to \$FF occurs 1-1/2 LSB below V<sub>RH</sub>, ideally. Figure 11. A/D Block Diagram #### **INSTRUCTION SET** The MCU has a set of 59 basic instructions which can be divided into five different types: register/memory, read-modify-write, branch, bit manipulation, and control. The following paragraphs briefly explain each type. ## 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 jump unconditional (JMP) and jump to subroutine (JSR) instructions have no register operand. Refer to the following list of instructions. | Function | Mnemonic | |------------------------------------------|----------| | Load A from Memory | LDA | | Load X from Memory | LDX | | Store A in Memory | STA | | Store X in Memory | STX | | Add Memory to A | ADD | | Add Memory and Carry to A | ADC | | Subtract Memory | SUB | | Subtract Memory from A with Borrow | SBC | | AND Memory to A | AND | | OR Memory with A | ORA | | Exclusive OR Memory with A | EOR | | Arithmetic Compare A with Memory | CMP | | Arithmetic Compare X with Memory | CPX | | Bit Test Memory with A (Logical Compare) | BIT | | Jump Unconditional | JMP | | Jump to Subroutine | JSR | # **BIT MANIPULATION INSTRUCTIONS** The MCU is capable of setting or clearing any bit which resides in the first 256 bytes of the memory space, where all port registers, port DDRs, timer, timer control, and onchip RAM reside. An additional feature allows the software to test and branch on the state of any bit within these 256 locations. The bit set, bit clear and bit test, and branch functions are all implemented with a single instruction. For test and branch instructions, the value of the bit tested is also placed in the carry bit of the condition code register. Refer to the following list for bit manipulation instructions. | Function | Mnemonic | |--------------------------|-------------------| | Branch if Bit n is Set | BRSET n (n = 0 7) | | Branch if Bit n is Clear | BRCLR n (n = 0 7) | | Set Bit n | BSET n (n = 0 7) | | Clear Bit n | BCLR n (n = 0 7) | #### **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 the following list of instructions. | Function | Mnemonic | |---------------------------|----------| | Increment | INC | | Decrement | DEC | | Clear | CLR | | Complement | COM | | Negate (2's Complement) | NEG | | Rotate Left Thru Carry | ROL | | Rotate Right Thru Carry | ROR | | Logical Shift Left | LSL | | Logical Shift Right | LSR | | Arithmetic Shift Right | ASR | | Test for Negative or Zero | TST | #### **BRANCH INSTRUCTIONS** This set of instructions branches if a particular condition is met; otherwise, no operation is performed. Branch instructions are two-byte instructions. Refer to the following list for branch instructions. | Function | Mnemonic | |---------------------------------------|----------| | Branch Always | BRA | | Branch Never | BRN | | Branch if Higher | ВНІ | | Branch if Lower or Same | BLS | | Branch if Carry Clear | ВСС | | (Branch if Higher or Same) | (BHS) | | Branch if Carry Set | BCS | | (Branch if Lower) | (BLO) | | Branch if Not Equal | BNE | | Branch if Equal | BEQ | | Branch if Half Carry Clear | BHCC | | Branch if Half Carry Set | BHCS | | Branch if Plus | BPL | | Branch if Minus | ВМІ | | Branch if Interrupt Mask Bit is Clear | вмс | | Branch if Interrupt Mask Bit is Set | BMS | | Branch if Interrupt Line is Low | BIL | | Branch if Interrupt Line is High | він | | Branch to Subroutine | BSR | #### CONTROL INSTRUCTIONS These instructions are register reference instructions and are used to control processor operation during program execution. Refer to the following list for control instructions. | Function | Mnemonic | |--------------------------|----------| | Transfer A to X | TAX | | Transfer X to A | TXA | | Set Carry Bit | SEC | | Clear Carry Bit | CLC | | Set Interrupt Mask Bit | SEI | | Clear Interrupt Mask Bit | CLI | | Software Interrupt | SWI | | Return from Subroutine | RTS | | Return from Interrupt | RTI | | Reset Stack Pointer | RSP | | No Operation | NOP | #### **OPCODE MAP SUMMARY** Table 4 is an opcode map for the instructions used on the MCU. #### ADDRESSING MODES The MCU uses ten different addressing modes to provide the programmer with an opportunity to optimize the code for all situations. The various indexed addressing modes make it possible to locate data tables, code coversion tables, and scaling tables anywhere in the memory space. Short indexed accesses are single-byte instructions, while the longest instructions (three bytes) permit accessing tables throughout memory. Short and long absolute addressing is also included. Two-byte direct-addressing instructions access all data bytes in most applications. Extended addressing permits jump instructions to reach all memory. The term "effective address" (EA) is used in describing the various addressing modes. Effective address is defined as the address from which the argument for an instruction is fetched or stored. ## **IMMEDIATE** In the immediate addressing mode, the operand is contained in the byte immediately following the opcode. The immediate addressing mode is used to access constants that 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 instruction. #### **EXTENDED** In the extended addressing mode, the effective address of the argument is contained in the two bytes following the opcode byte. Instructions with extended addressing mode are capable of referencing arguments anywhere in memory with a single three-byte instruction. #### RELATIVE The relative addressing mode is only used in branch instructions. In relative addressing, the contents of the 8-bit signed byte (the offset) following the opcode is added to the PC if, and only if, the branch conditions are true. Otherwise, control proceeds to the next instruction. The span of relative addressing is from $\,-\,126$ to $\,+\,129$ from the opcode address. #### INDEX, NO OFFSET In the indexed, no offset addressing mode, the effective address of the argument is contained in the 8-bit index register. This addressing mode can access the first 256 memory locations. These instructions are only one byte long. This mode is often used to move a pointer through a table or to hold the address of a frequently referenced RAM or I/O location. ## INDEXED, 8-BIT OFFSET In the indexed, 8-bit offset addressing mode, the effective address is the sum of the contents of the unsigned 8-bit index register and the unsigned byte following the oncode. The addressing mode is useful for selecting the Kth element in an n element table. With this two-byte instruction, K would typically be in X with the address of the beginning of the table in the instruction. As such, tables may begin anywhere within the first 256 addressable locations and could extend as far as location 510 (\$1FE is the last location at which the instruction may begin). ## 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. ## BIT SET/CLEAR In the bit set clear addressing mode, the bit to be set or cleared is part of the opcode. The byte following the opcode specifies the direct addressing of the byte to which the specified bit is to be set or cleared. Thus, any read write bit in the first 256 locations of memory, including i.O. can be selectively set or cleared with a single two-byte instruction. ## CAUTION The corresponding DDRs for ports A, B, and C are write-only registers irregisters at \$004, \$005, and \$006. A read operation on these registers is undefined. Since BSET and BCLR are read-modify-write Table 4. Opcode Map | Γ | Dit Mer | Manipulation | Branch | | 2 | Read-Modify-Write | Vrite | | 5 | Control | | | Regieta | Register / Memory | | | | |------------|-----------------|----------------|--------------|-------------------|---------------|-------------------|----------------|---------------|-------|---------|----------------|-------------------|----------------|-------------------|--------------|---------|------------------| | | 111 | SC | HE | e did | HN | H | × | × | H | H | MM | DIR | ESCI | 3 | × | × | | | ≢/<br>/§ | 000 | - 100 | 90,00 | E [8 | 0010 | 900 | 0110 | 0111 | 900 | e (2) | 1010 | 1(0) | υ <u>β</u> | σį | 31. | 1111 | _}<br><u>≠</u> | | -8 | BRSETO<br>3 BTB | BSET0 | BRA<br>2 REL | NEG 2 | NEG | NEG | NEG XI | NEG X | PRT! | | SUB<br>2 IMM | SUB<br>2 DIR | SUB<br>3 EXT | SUB<br>3 IX2 | SUB | SUB | 0 | | -8 | BRCLR0 | BCLR0 | BRN 2 | | | | | | 6 PTS | | CMP | CMP | S CMP | CMP | S CMP | CMP | -8 | | 2<br>0010 | BRSET1 | BSET1 | BHI<br>2 BHI | | | | | | | | SBC | SBC | SBC | 3 SBC | 5 SBC 2 | , SBC | 2<br>0<br>0<br>0 | | e,8 | BRCLR1 | BCLR1 | BLS<br>2 REL | COM<br>COM | COMA | COMX | . CO₩ | ¥<br>COM<br>- | SWI | | 2 CPX<br>2 IMM | CPX<br>2 | S CPX | 3 CPX | CPX | CPX X | e § | | 4000 | BRSET2 | BSET2 | BCC<br>PEL | 6<br>LSR<br>2 DTA | LSRA | LSRX | LSR x11 | LSP | | | 2 AND | AND 5 | S AND | a AND | S AND | AND X | 4 90 | | 200 | BRCLR2<br>BIB | BCLR2 | BCS<br>2 REL | | | | | | | | 2 BIT | BIIT BIR | 5 BIT | 6 BIT 3 | BIT<br>2 BIT | BIT IX | 5000 | | 910 | BRSET3 | BSET3 | BNE 2 | 6 ROR | 4 RORA | 4<br>RORX | POH 2 | 6 AOR | | | LDA<br>MM | LDA<br>Pla | S LDA | B LDA | S LDA | 407 ' | • 0 | | 1110 | BACLR3 | BCLR3 | BEO<br>PEL | 6 ASR<br>2 DIR | ASRA<br>I INH | ASRX | ASH x ixi | 6 ASR | | TAX | | STA<br>2 DIR | STA<br>3 EXT | STA<br>3 IX2 | STA<br>2 | STA | 7,110 | | ∞ <u>8</u> | BRSET4 | BSET4 | BHCC | LSL<br>2 DIR | LSLA 4 | LSLX | , LSL x1 | , LSL , | | CLC | EOR | EOR DIR | 5<br>EOR | 6<br>EOR<br>3 | 5 EOR | FOR X | æ8 <u>0</u> | | o <u>S</u> | BRCLR4 | BCLR4 | BHCS | BOL 2 | 4 ROLA | A ROLX | ,<br>ROL<br>x1 | , ROL | | SEC | ADC MM | ADC 2 | ADC 3 | ADC 3 | S ADC | , ADC | တန္တိ | | A OI OI | BASETS | BSET5 | BPL<br>2 REL | OEC 2 | DECA | DECX | , DEC | bec x | | CLI INH | 2 ORA | ORA<br>2 DIR | S ORA<br>3 ExT | 6 ORA<br>3 JX2 | S ORA | A ORA | €ŏ | | 101 | BRCLR5 | BCLR5 | BMI<br>REL | | | | | | | SEI | ADD 3 | ADD 5 | ADD<br>3 EXT | APD X2 | ADD X1 | ADD × | æğ | | ية<br>ق | BASET6 | BSET6<br>2 BSC | BMC<br>PEL | NC<br>OB | INCA INH | Ž<br>Ž | , INC | NC<br>NC | | RSP INH | | 3 JANP<br>2 DAP | JMP<br>3 EXT | 3 JMP | JMP<br>2 IXI | 3 JAAP | ပ<br>(ရှ | | ە<br>ۋە | BRCLR6 | BCLR6 | BMS<br>2 REL | TST 2 | TSTA | TSTX | , TST , | 6 TST | | NOP | BSR<br>2 REL | ,<br>JSR<br>2 DIR | B JSR<br>3 ExT | JSR E | B JSR | , JSR , | Oį | | F 0111 | BRSET7 | BSET7 | Bil. | | | | | | | | 2 LDX | רטא אום ? | נ באנ | ז רטא אז | רטא ל | רים א | 110 | | ٦!! | BRCLR7 | BCLR7 | BiH 2 | CLR<br>2 DIR | CLRA | CLRX | , dla | 6 CLA | | TXA | | S STX | STX<br>3 EXT | STX<br>3 STX | STX 2 | STX , | ΨĒ | f of Cycles Mnemonic Bytes Address Mode LEGEND INH inherent immediate DIR Direct EXT Extended REL Relative BSC 8n Set/Clear RTB Bit Test and Branch IX Indexed I Byte (B-Bit) Offset IXI Indexed I Byte (B-Bit) Offset IXI Indexed I Byte (B-Bit) Offset IXI Indexed I Byte (B-Bit) Offset IXI Indexed I Byte (B-Bit) Offset IXI Indexed I Byte (B-Bit) Offset Abbreviations for Address Modes functions, these instructions cannot be used to set or clear a DDR bit (all "unaffected" bits would be set). It is recommended that all DDR bits in a port be written using a single-store instruction. #### BIT TEST AND BRANCH The bit test and branch addressing mode is a combination of direct addressing and relative addressing. The bit that is to be tested and its condition (set or clear) is included in the opcode. The address of the byte to be tested is in the single byte immediately following the opcode byte. The signed relative 8-bit offset in the third byte is added to the PC if the specified bit is set or cleared in the specified memory location. This single three-byte instruction allows the program to branch based on the condition of any readable bit in the first 256 locations of memory. The span of branching is from -125 to +130 from the opcode address. The state of the tested bit is also transferred to the carry bit of the condition code register. #### INHERENT In the inherent addressing mode, all the information necessary to execute the instruction is contained in the opcode. Operations specifying only the index register or accumulator as well as the control instruction with no other arguments are included in this mode. These instructions are one byte long. #### **ELECTRICAL SPECIFICATIONS** #### MAXIMUM RATINGS | Rating | Symbol | Value | Unit | |-------------------------------------------------------------------|------------------|------------------------------------------------------------------------|------| | Supply Voltage | Vcc | - 0.3 to - 7.0 | V | | Input Voltage<br>Self-Check Mode<br>(TIMER Pin Only) | v <sub>in</sub> | 0.3 to - 15.0 | V | | Operating Temperature Range<br>MC6805R2<br>MC6805R2C<br>MC6805R2V | TA | T <sub>L</sub> to T <sub>H</sub><br>0 to -70<br>-40 to 85<br>40 to 105 | С | | Storage Temperature Range | T <sub>stg</sub> | - 55 to + 150 | ·.C | | Junction Temperature<br>Plastic<br>PLCC<br>Cerdip | Тл | 50<br>150<br>175 | С | This device contains circuitry to protect the inputs against damage due to high static voltages or 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 the Vin and Vout be constrained to the range $V_{SS} \leq (V_{in} \text{ and } V_{out}) \leq V_{CC}$ . Reliability of operation is enhanced if unused inputs, except EXTAL, are tied to an appropriate logic voltage level (e.g., either VSS or VCC). ## THERMAL CHARACTERISTICS | Characteristic | Symbol | Value | Unit | |--------------------|--------|-------|------| | Thermal Resistance | θЈΑ | | :C:W | | Plastic (P Suffix) | | 60 | l | | PLCC (FN Suffix) | | 100 | | | Cerdip (S Suffix) | | 60 | | # POWER CONSIDERATIONS The average chip-junction temperature, T<sub>J</sub>, in 'C can be obtained from: $T_A$ - Ambient Temperature, C <sup>()</sup>JA Package Thermal Resistance, Junction-to-Ambient, CW $P_D$ $= P_{INT} + P_{PORT}$ $= I_{CC} \times V_{CC}, Watts - Chip Internal Power$ PINT PPORT = Port Power Dissipation, Watts - User Determined For most applications PPORT<PINT and can be neglected. PPORT may become significant if the device is configured to drive Darlington bases or sink LED loads. An approximate relationship between PD and TJ (if PPORT is neglected) is: $$P_D = K \div (T_J + 273^{\circ}C)$$ (2) Solving equations (1) and (2) for K gives: $$K = P_D \cdot (T_A + 273^{\circ}C) + \theta_J A \cdot P_D^2$$ (3 where K is a constant pertaining to the particular part. K can be determined from equation (3) by measuring PD (at equilibrium) for a known TA. Using this value of K, the values of PD and TJ can be obtained by solving equations (1) and $(\overline{2})$ iteratively for any value of $T_A$ . $\textbf{ELECTRICAL CHARACTERISTICS} \ \, (V_{CC} = +5.25 \ \, \text{Vdc}, \, V_{SS} = 0 \ \, \text{Vdc}, \, T_A = T_L \ \, \text{to} \, T_H, \, \text{unless otherwise noted})$ | Characteristic | Symbol | Min | Тур | Max | Unit | |-------------------------------------------------------------------|------------------|-----------------------|------|-----------------------|---------------------| | Input High Voltage<br>RESET (4.75≤V <sub>CC</sub> ≤5.75) | V <sub>IH</sub> | 4.0 | _ | Vcc | V | | V <sub>CC</sub> (4.75) | | V <sub>CC</sub> - 0.5 | _ | Vcc | | | INT (4.75≤V <sub>CC</sub> ≤5.75) | | 4.0 | * | VCC | | | (V <sub>CC</sub> (4.75) | | V <sub>CC</sub> - 0.5 | * | Vcc | | | All Other | | 2.0 | | Vcc | , | | Input High Voltage Timer | $v_{1H}$ | | | | V | | Timer Mode | | 2.0 | | V <sub>CC</sub> + 1.0 | | | Self-Check Mode | | 9.0 | 10.0 | 15.0 | | | Input Low Voltage | VIL | | | | V | | RESET | | VSS | _ | 0.8 | | | INT | | VSS | • | 1.5 | | | All Other (Except A/D Inputs) | | VSS | | 0.8 | | | RESET Hysteresis Voltages | | i | | | V | | "Out of Reset" | VIRES + | 2.1 | _ | 4.0 | | | "Into Reset" | VIRES | 0.8 | | 2.0 | | | INT Zero-Crossing Input Voltage, Through a Capacitor | VINT | 2 | | 4 | V <sub>ac p-p</sub> | | Power Dissipation — (No Port Loading, V <sub>CC</sub> = 5.75 V | PD | _ | 520 | 740 | mW | | T <sub>A</sub> = 0°C | | - | 580 | 800 | | | for Steady-State Operation) T <sub>A</sub> = -40°C | | | | | | | Input Capacitance | Cin | | | | pF | | XTAL | | _ | 25 | | | | All Other Except Analog Inputs (See Note) | | | 10 | | | | Low Voltage Recover | V <sub>LVR</sub> | _ | _ | 4.75 | ν | | Low Voltage Inhibit | VLVI | 2.75 | 3.75 | 4.70 | ٧ | | Input Current | | T | | | μА | | TIMER $(V_{in} = 0.4)$ | | _ | _ | 20 | | | $\overline{INT}$ ( $V_{in} = 2.4 \text{ V to V}_{CC}$ ) | | - | 20 | 50 | | | EXTAL (V <sub>in</sub> = 2.4 V to V <sub>CC</sub> Crystal Option) | lin | 1 - | _ | 10 | | | (V <sub>in</sub> = 0.4 V Crystal Option) | | _ | | 1600 | | | RESET (V <sub>in</sub> = 0.8 V) | IRES | - 4.0 | _ | 40 | | | (External Capacitor Charging Current) | | | | | | NOTE: Port D Analog Inputs, when selected $C_{in} = 25$ pF for the first 5 out of 30 cycles. \*Due to internal biasing this input (when unused) floats to approximately 2.0 V. # SWITCHING CHARACTERISTICS (V<sub>CC</sub> = $\pm$ 5.25 Vdc $\pm$ 0.5 Vdc, V<sub>SS</sub> = 0 Vdc, T<sub>A</sub> = T<sub>L</sub> to T<sub>H</sub>) | Characteristic | Symbol | Min | Тур | Max | Unit | |---------------------------------------------|----------|------------------------|-----|-----|------| | Oscillator Frequency | fosc | 0.4 | | 4.2 | MHz | | Cycle Time (4/f <sub>osc</sub> ) | tcyc | 0.95 | _ | 10 | μs | | INT, INT2, and TIMER Pulse Width | twL, twh | t <sub>cyc</sub> - 250 | | | ns | | RESET Pulse Width | tRWL | t <sub>cyc</sub> - 250 | _ | | ns | | INT Zero-Crossing Detection Input Frequency | fINT | 0.03 | _ | 1 | kHz | | External Clock Input Duty Cycle (EXTAL) | _ | 40 | 50 | 60 | ٥. | | Crystal Oscillator Start-Up Time | | _ | _ | 100 | ms | $\textbf{A/D CONVERTER CHARACTERISTICS} \ (V_{CC} = +5.25 \ \text{Vdc} \pm 0.5 \ \text{Vdc}, \ V_{SS} = 0 \ \text{Vdc}, \ T_A = T_L \ \text{to} \ T_H), \ unless \ otherwise \ noted)$ | | Min | Тур | Max | Unit | Comments | |--------------------------------|-----------------|-----|-----------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------| | Resolution | 8 | 8 | 8 | Bits | | | Total Error | _ | _ | 2.25* | LSB | Difference between ideal and actual trans-<br>fer characteristics (includes non-linearity,<br>zero offset and full scale errors) | | Absolute Accuracy | _ | _ | + - 2.75* | LSB | Difference between the actual input voltage and the full-scale weighted equivalent of the binary output code. All error sources included | | Quantizing Error | _ | - | 5 | LSB | Uncertainty due to converter resolution (inherent) | | Conversion Range | V <sub>RL</sub> | _ | VRH | ٧ | | | VRH | _ | | Vcc | V | A/D accuracy may decrease proportionately as VRH is reduced below 4.75 V. The sum | | V <sub>RL</sub> | VSS | _ | 0.2 | ٧ | of VRH and VRL must not exceed VCC | | Conversion Time | 30 | 30 | 30 | tcyc | Includes sample time | | Monotonicity | | | | | Inherent with total error | | Sample Time | 5 | 5 | 5 | t <sub>cyc</sub> _ | | | Sample/Hold Capacitance, Input | | _ | 25 | pF | | | Analog Input Voltage | V <sub>RL</sub> | | V <sub>RH</sub> | V | Negative transients on any analog lines (Pins 19-24) are not allowed at any time during conversion. | <sup>\*</sup>Note: Accuracy may decrease at temperatures above $T_A = 85^{\circ}C$ or $f_{OSC} < 3.57$ MHz. $\textbf{PORT ELECTRICAL CHARACTERISTICS} \; (\text{V}_{CC} = +5.25 \; \text{Vdc} \; \pm 0.5 \; \text{Vdc}, \; \text{V}_{SS} = 0 \; \text{Vdc}, \; \text{T}_{A} = \text{T}_{L} \; \text{to} \; \text{T}_{H}, \; \text{unless otherwise noted})$ | Characteristic | Symbol | Min | Тур | Max | Unit | |--------------------------------------------------------|-----------------------|-----------------------|-----|-------|------| | Port A | A with CMOS Drive | Enabled | | | | | Output Low Voltage, ILoad = 1.6 mA | VOL | _ | | 0.4 | V | | Output High Voltage, I <sub>Load</sub> = -100 μA | Vон | 2.4 | _ | _ | V | | Output High Voltage, I <sub>Load</sub> = -10 μA | Vон | V <sub>CC</sub> - 1.0 | _ | _ | V | | Input High Voltage, I <sub>Load</sub> = -300 μA (max.) | VIH | 2.0 | | Vcc | ٧ | | Input Low Voltage, I <sub>Load</sub> = -500 μA (max.) | VIL | VSS | _ | 0.8 | ٧ | | Hi-Z State Input Current (Vin = 2.0 V to VCC) | ΊΗ | - | _ | - 300 | μΑ | | Hi-Z State Input Current (Vin = 0.4 V) | կլ | _ | _ | 500 | μΑ | | | Port B | | | | | | Output Low Voltage, I <sub>Load</sub> = 3.2 mA | VOL | _ | | 0.4 | ٧ | | Output Low Voltage, ILoad = 10 mA (Sink) | VOL | - | | 1.0 | V | | Output High Voltage, I <sub>Load</sub> = -200 μA | ∨он | 2.4 | _ | | ν | | Darlington Current Drive (Source), VO = 1.5 V | loн | - 1.0 | | -10 | mA | | Input High Voltage | VIH | 2.0 | | Vcc | ٧ | | Input Low Voltage | VIL | VSS | | 0.8 | V | | Hi-Z State Input Current | ITSI | | <2 | 10 | μА | | Port | C and Port A with | TTL Drive | | | | | Output Low Voltage, Load = 1.6 mA | V <sub>OL</sub> | _ | - | 0.4 | v | | Output High Voltage, I <sub>Load</sub> = -100 μA | VOH | 2.4 | | _ | v | | Input High Voltage | ViH | 2.0 | | Vcc | V | | Input Low Voltage | VIL | VSS | _ | 0.8 | v | | Hi-Z State Input Current | l <b>T</b> SI | _ | <2 | 10 | μΑ | | Po | ort C (Open-Drain C | ption) | | | | | Input High Voltage | ViH | 2.0 | | 13.0 | v | | Input Low Voltage | V <sub>1</sub> L | VSS | | 0.8 | V | | Input Leakage Current (Vin = 13.0 V) | l <sub>LOD</sub> | _ | <3 | 15 | μΑ | | Output Low Voltage I <sub>Load</sub> = 1.6 mA | VOL | _ | _ | 0.4 | V | | Po | ort D (Digital Inputs | Only) | | | - | | Input High Voltage | VIH | 2.0 | _ | Vcc | V | | Input Low Voltage | VIL | VSS | *** | 0.8 | V | | Input Current | lin | _ | <1 | 5 | μΑ | Figure 12. TTL Equivalent Test Load (Port B) Figure 13. CMOS Equivalent Test Load (Port A) Figure 14. TTL Equivalent Test Load (Ports A and C) Figure 15. Open-Drain Equivalent Test Load (Port C) Figure 16. Ports A and C Logic Diagram Figure 17. Port B Logic Diagram Figure 18. Typical Input Protection Figure 19. I/O Characteristic Measurement Circuit #### ORDERING INFORMATION The following information is required when ordering a custom MCU. The information may be transmitted to Motorola in the following media: MDOS<sup>®</sup>, disk file MS®-DOS/PC-DOS disk file EPROM(s) MC68705R3, 2532, 2732, or two 2516/2716 To initiate a ROM pattern for the MCU, it is necessary to first contact the local field service office, a sales person, or Motorola representative. #### **FLEXIBLE DISKS** Several types of flexible disks (MDOS or MS-DOS/PC-DOS disk file), programmed with the customer program (positive logic sense for address and data), may be submitted for pattern generation. In either case, the diskette should be clearly labeled with the customers name, date, project or product name, and the name of the file containing the pattern. In addition to the program pattern, a file containing the program source code listing can be included. This data will be kept confidential and used to speed up the process in case of any difficulty with the pattern file. #### MDOS Disk File MDOS is Motorola's Disk Operating System available on the EXORciser® development system. The disk media submitted must be a single-side, single-density, 8-inch MDOS compatible floppy diskette. The diskette must contain the minimum set of MDOS system files in addition to the pattern file. The .LO output of the M6805 cross assembler should be furnished. In addition, the file must be produced (using the ROLLOUT command) containing the absolute image of the M6805 memory. Include the entire memory image of both data and program space. All unused bytes, including those in the user space, must be set to zero. ### MS-DOS/PC-DOS Disk File MS-DOS is Microsoft's Disk Operating System. PC-DOS is IBM® Personal Computer (PC) Disk Operating System. Disk media submitted must be a standard density (360K) double sided 5 1/4 inch compatible floppy diskette. The diskette must contain object file code in Motorola's Srecord format. The S-record format is a character-based object file format generated by M6805 cross assemblers and linkers on IBM PC style machines. #### **EPROMs** An MC68705R3, 2532, 2732, 2516 (2), or 2716 (2) type EPROM(s), programmed with the customer program (positive logic sense for address and data) may be submitted for pattern generation. Since all program and data space information will fit on one MC68705R3/2532/2732 or two 2516 2716 type EPROM(s), the EPROM(s) must be programmed as described in the following paragraph. For the 2532, 2732, or the MC68705R3, the ROM code should be located from \$080 to \$FF; and \$700 to \$F37 and the interrupt vectors from \$FF8 to \$FFF. For the 2516's or 2716's, the ROM code should be located from \$080 to \$FF and \$7C0 to \$7FF in the first EPROM and from \$0 to \$737 in the second EPROM. The interrupt vectors should be in the second EPROM from \$7F8 to \$7FF. #### 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. To aid in the verification process, Motorola will program (customer supplied) blank EPROM(s) or DOS disk from the data file used to create the custom mask. #### **ROM VERIFICATION UNITS (RVUs)** Ten 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 the MCUs are unmarked, packaged in ceramic, and tested at room temperature and five volts. These RVUs are free with the minimum order quantity but are not production parts. These RVUs are not guaranteed by Motorola Quality Assurance. #### ORDERING INFORMATION The following table provides generic information pertaining to the package type, temperature, and MC part numbers for the MC6805R2. | Package Type | Temperature | Part Number | |--------------|----------------|-------------| | Plastic | 0°C to 70°C | MC6805R2P | | (P Suffix) | -40°C to +85°C | MC6805R2CP | | Cerdip | 0°C to 70°C | MC6805R2S | | S Suffix | -40°C to +85°C | MC6805R2CS | | PLCC | 0°C to 70°C | MC6805R2FN | | FN Suffix | -40°C to +85°C | MC6805R2CFN | MDOS is a trademark of Motorola Inc. MS is a trademark of Microsoft, Inc. EXORs ser is a registered trademark of Motorola Inc. 3V is a registered trademark of International Business Machines Corporation. # **MECHANICAL DATA** #### PIN ASSIGNMENTS # **Dual-in-Line Package** ## **PLCC Package** # MOTOROLA MICROPROCESSOR DATA 3-452