# EF6808R2 # 8-BIT MICROCOMPUTER WITH A/D #### HARDWARE FEATURES - A/D CONVERTER - 8-BIT CONVERSION, MONOTONIC - 4 MULTIPLEXED ANALOG INPUTS - RATIOMETRIC CONVERSION - 32 TTL/CMOS COMPATIBLE I/O LINES - 24 BIDIRECTIONAL (8 Lines are LED Compatible) - \_ 8 INPUT-ONLY - 2048 BYTES OF USER ROM - 64 BYTES OF RAM - SELF-CHECK MODE - ZERO-CROSSING DETECT/INTERRUPT - INTERNAL 8-BIT TIMER WITH 7-BIT MASK PROGRAMMABLE PRESCALER AND CLOCK SOURCE - 5V SINGLE SUPPLY #### SOFTWARE FEATURES - 10 POWERFUL ADDRESSING MODES - BYTE EFFICIENT INSTRUCTION SET WITH TRUE BIT MANIPULATION, BIT TEST, AND BRANCH INSTRUCTIONS - SINGLE INSTRUCTION MEMORY EXAMINE/CHANGE - POWERFUL INDEXED ADDRESSING FOR TABLES - FULL SET OF CONDITIONAL BRANCHES - MEMORY USABLE AS REGISTER/FLAGS - COMPLETE DEVELOPMENT SYSTEM SUP-PORT INICE® #### **USER SELECTABLE OPTIONS** - INTERNAL 8-BIT TIMER WITH SELECTABLE CLOCK SOURCE (external timer input or internal machine clock) - TIMER PRESCALER OPTION (7 Bits, 2<sup>n</sup>) - 8 BIDIRECTIONAL I/O LINES WITH TTL OR TTL/CMOS INTERFACE OPTION - 8 BIDIRECTIONAL I/O LINES WITH TTL OR OPEN-DRAIN INTERFACE OPTION - CRYSTAL OR LOW-COST RESISTOR OSCIL-LATOR OPTION - LOW VOLTAGE INHIBIT OPTION - VECTORED INTERRUPTS: TIMER, SOFT-WARE, AND EXTERNAL - USER CALLABLE SELF-CHECK SUBROU-TINES May 1989 #### DESCRIPTION The EF6805R2 Microcomputer Unit (MCU) is a member of the 6805 Family of low-cost single-chip Microcomputers. The 8-bit microcomputer contains a CPU, on-chip CLOCK, ROM, RAM, I/O, 4-channel 8-bit A/D, and TIMER. It is designed for the user who needs an economical microcomputer with the proven capabilities of the 6800-based instruction set. A comparison of the key features of several members of the 6805 Family of Microcomputers is shown at the end of this data sheet. The following are some of the hardware and software highlights of the EF6805R2 MCU. Figure 1: EF6805R2 HMOS Microcomputer Block Diagram. #### ABSOLUTE MAXIMUM RATINGS | Symbol | Parameter | Value | Unit | |-----------|-----------------------------------------------------------------------|-------------------------|------| | Vcc | Supply Voltage | - 0.3 to + 7.0 | V | | $V_{in}$ | Input Voltage (except TIMER in self-check mode and open-drain inputs) | - 0.3 to + 7.0 | V | | $V_{in}$ | Input Voltage (open-drain pins, TIMER pin in self-check mode) | - 0.3 to + 15.0 | V | | TA | Operating Temperature Range V Suffix | 0 to + 70<br>40 to + 85 | °C | | | (T <sub>L</sub> to T <sub>H</sub> ) T Suffix | - 40 to + 105 | | | $T_{stg}$ | Storage Temperature Range | - 55 to + 150 | °C | | TJ | Junction Temperature Plastic Package PLCC | 150<br>150 | °C | This device contains circuitry to protect the inputs against damage due to high static voltages or electrical 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_n$ and $V_{out}$ be constrained to the range $V_{SS} \le V_{CC}$ . Reliability of operation is enhanced if unused inputs except EXTAL are tied to an appropriate logic voltage level (e.g., either $V_{SS}$ or $V_{CC}$ ). #### THERMAL DATA | θJA | Thermal Resistance | Plastic | 50 | °C/W | |-----|--------------------|---------|----|------| | | | PLCC | 80 | | 2/36 SGS-THOMSON MICROELECTRONICS #### **POWER CONSIDERATIONS** The average chip-junction temperature, $T_J$ , in $^{\circ}C$ can be obtained from : $$T_{J} = T_{A} + (PD \cdot \theta J_{A}) \tag{1}$$ Where: T<sub>A</sub> = Ambient Temperature, °C $\theta$ $_{JA}=$ Package Thermal Resistance, Junction-to-Ambient, $^{\circ}C/W$ PD = PINT + PPORT PINT = Icc x Vcc, Watts - Chip Internal Power 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 $P_D$ and $T_J$ (if $P_{PORT}$ is neglected) is : $$P_D = K \div (T_J + 273^{\circ}C)$$ (2) Solving equations 1 and 2 for K gives : $$K = PD \cdot (T_A + 273^{\circ}C) + \theta JA \cdot P_D^2$$ (3) Where K is a constant pertaining to the particular part. K can be determined from equation 3 by measuring $P_D$ (at equilibrium) for a known $T_A$ . Using this value of K the values of $P_D$ and $T_J$ can be obtained by solving equations (1) and (2) iteratively for any value of $T_A$ . #### **ELECTRICAL CHARACTERISTICS** ( $V_{CC}$ = + 5.25Vdc $\pm$ 0.5Vdc, $V_{SS}$ = 0Vdc, $T_A$ = $T_L$ to $T_H$ unless otherwise noted) | Symbol | Parameter | Min. | Тур. | Max. | Unit | |---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------|------------|------------------------------------|---------------------| | V <sub>IH</sub> | Input High Voltage<br>RESET (4.75 ≤ V <sub>CC</sub> ≤ 5.75)<br>(V <sub>CC</sub> < 4.75) | 4.0<br>V <sub>CC</sub> – 0.5 | | V <sub>CC</sub><br>V <sub>CC</sub> | <b>V</b> | | | $\frac{(V_{CC} < 4.75)}{INT}$ (4.75 $\leq V_{CC} \leq 5.75$ ) | 4.0 | • | Vcc | | | | (V <sub>CC</sub> < 4.75) | V <sub>CC</sub> - 0.5 | • | Vcc | | | | All Other (except timer) | 2.0 | | Vcc | | | V <sub>IH</sub> | Input High Voltage Timer | | | | V | | | Timer Mode | 2.0 | | V <sub>CC</sub> + 1.0 | | | | Self-check Mode | 9.0 | 10.0 | 15.0 | | | VIL | Input Low Voltage | | | | V | | | RESET | Vss | | 0.8 | | | | INT | V <sub>SS</sub> | • | 1.5<br>0.8 | | | | All Other (except A/D inputs) | Vss | | 0.8 | | | | RESET Hystereris Voltages (see figures 10, 11 and 12) | | ļ | | \ \ | | VIRES + | "Out of Reset" | 2.1 | | 4.0 | | | V <sub>IRES</sub> - | "Into Reset" | 0.8 | | 2.0 | | | VINT | INT Zero Crossing Input Voltage, Through a Capacitor | 2 | | 4 | V <sub>ac p-p</sub> | | PD | Power Dissipation - (no port loading, $V_{CC}$ = 5.75V)<br>$T_A$ = 0 °C<br>$T_A$ = -40°C | | 520<br>580 | 740<br>800 | mW | | Cin | Input Capacitance EXTAL All Other Except Analog Inputs (see note) | | 25<br>10 | | pF | | VLVR | Low Voltage Recover | | | 4.75 | V | | V <sub>LVI</sub> | Low Voltage Inhibit | 2.75 | 3.75 | 4.70 | V | | lin | Input Current TIMER (V <sub>in</sub> = 0.4V) INT (V <sub>in</sub> = 2.4V to V <sub>CC</sub> ) | | 20 | 20<br>50 | μА | | | EXTAL (V <sub>in</sub> = 2.4V to V <sub>CC</sub> - crystal option) (V <sub>in</sub> = 0.4V - crystal option) RESET (V <sub>in</sub> = 0.8V) - External Capacitor Charging | - 4.0 | | 10<br>- 1600<br>- 40 | | | | Current | | <u></u> | | | Note: Port D Analog Inputs, when selected, C<sub>in</sub> = 25pF for the first 5 out of 30 cycles. \* Due to internal biasing this input (when unused) floats to approximately 2.2V. #### SWITCHING CHARACTERISTICS ( $V_{CC}$ = + 5.25Vdc $\pm$ 0.5Vdc, $V_{SS}$ = 0Vdc, $T_A$ = $T_L$ to $T_H$ unless otherwise noted) | Symbol | Parameter | Min. | Тур. | Max. | Unit | |---------------------|----------------------------------------------------------|------------------------|------|------|------| | fosc | Oscillator Frequency | 0.4 | | 4.2 | MHz | | tcyc | Cycle Time (4/f <sub>osc</sub> ) | 0.95 | | 10 | μs | | $t_{WL}$ , $t_{WH}$ | INT, INT2, and TIMER Pulse Width (see interrupt section) | t <sub>cyc</sub> + 250 | | | ns | | t <sub>RWL</sub> | RESET Pulse Width | t <sub>cyc</sub> + 250 | | | ns | | f <sub>INT</sub> | INT Zero-crossing Detection Input Frequency | 0.03 | | 1 | kHz | | | External Clock Input Duty Cycle (EXTAL) | 40 | 50 | 60 | % | | | Crystal Oscillator Start-up Time* | | | 100 | ms | <sup>\*</sup> See Figure 16 for typical crystal parameters. # 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 \text{ unless otherwise noted})$ | Parameter | Comments | Min. | Тур. | Max. | Unit | |-----------------------------------|----------------------------------------------------------------------------------------------------------------|-----------------|---------------|-----------------|------------------| | Resolution | | 8 | 8 | 8 | Bits | | Non-linearity | For V <sub>RH</sub> = 4.0 to 5.0V and V <sub>RL</sub> = 0V | | | ± 1/2 | LSB | | Quantizing Error | | | | ± 1/2 | LSB | | Conversion Range | | V <sub>RL</sub> | | V <sub>RH</sub> | V | | V <sub>RH</sub> | A/D accuracy may decrease | | | Vcc | V | | V <sub>RL</sub> | proportionately as $V_{RH}$ is reduced below 4.0V. The sum of $V_{RH}$ and $V_{RL}$ must not exceed $V_{CC}$ . | V <sub>SS</sub> | | 0.2 | V | | Conversion Time | Includes Sampling Time | 30 | 30 | 30 | t <sub>cyc</sub> | | Monotonicity | | In | herent (withi | n total error | ) | | Zero Input Reading | V <sub>in</sub> = 0 | 00 | 00 | 01 | Hexa-<br>decimal | | Ratiometric Reading | $V_{in} = V_{RH}$ | FE | FF | FF | Hexa-<br>decimal | | Sample Time | | 5 | 5 | 5 | tcyc | | Sample/hold Capacitance,<br>Input | | | | 25 | pF | | Analog Input Voltage | Negative transients on any analog<br>lines (pins 19-24) are not allowed at<br>any time during conversion | V <sub>RL</sub> | | V <sub>RH</sub> | V | #### PORT ELECTRICAL CHARACTERISTICS ( $V_{CC}$ = + 5.25Vdc $\pm$ 0.5Vdc, $V_{SS}$ = 0Vdc, $T_A$ = $T_L$ to $T_H$ unless otherwise noted) #### PORT A WITH CMOS DRIVE ENABLED | Symbol | Parameter | Min. | Тур. | Max. | Unit | |-----------------|----------------------------------------------------------------------------|------------------------------|------|-------|------| | $V_{OL}$ | Output Low Voltage (I <sub>Load</sub> = 1.6mA) | | | 0.4 | V | | V <sub>OH</sub> | Output High Voltage I <sub>Load</sub> = - 100μA I <sub>Load</sub> = - 10μA | 2.4<br>V <sub>CC</sub> - 1.0 | | | ٧ | | V <sub>IH</sub> | Input High Voltage (I <sub>Load</sub> = - 300μA max.) | 2.0 | | Vcc | V | | VIL | Input Low Voltage (I <sub>Load</sub> = - 500μA max.) | Vss | | 0.8 | V | | LiH | High Z State Input Current (V <sub>in</sub> = 2.0V to V <sub>CC</sub> ) | | | - 300 | μА | | I <sub>IL</sub> | High Z State Input Current (Vin = 0.4V) | | | - 500 | μА | #### PORT B | Symbol | Parameter | Min. | Тур. | Max. | Unit | |------------------|---------------------------------------------------------|-------|------|------------|------| | V <sub>OL</sub> | Output Low Voltage ILoad = 3.2mA ILoad = 10mA (sink) | | | 0.4<br>1.0 | V | | V <sub>OH</sub> | Output High Voltage I <sub>Load</sub> = - 200µA | 2.4 | | | V | | Іон | Darlington Current Drive (source) V <sub>O</sub> = 1.5V | - 1.0 | | - 10 | mA | | V <sub>IH</sub> | Input High Voltage | 2.0 | | Vcc | V | | VIL | Input Low Voltage | Vss | | 0.8 | V | | I <sub>TSI</sub> | High Z State Input Current | | < 2 | 10 | μА | # PORT C AND PORT A WITH CMOS DRIVE DISABLED | Symbol | Parameter | Min. | Тур. | Max. | Unit | |------------------|-------------------------------------------------|------|------|------|------| | VoL | Output Low Voltage I <sub>Load</sub> = 1.6mA | | | 0.4 | V | | $v_{oh}$ | Output High Voltage I <sub>Load</sub> = - 100μA | 2.4 | | | V | | V <sub>IH</sub> | Input High Voltage | 2.0 | | Vcc | V | | VIL | Input Low Voltage | Vss | | 0.8 | V | | I <sub>TSI</sub> | High Z State Input Current | | < 2 | 10 | μs | # PORT C (open-drain option) | Symbol | Parameter | Min. | Тур. | Max. | Unit | |-----------------|----------------------------------------------|------|------|------|------| | V <sub>IH</sub> | Input High Voltage | 2.0 | | 13.0 | V | | V <sub>IL</sub> | Input Low Voltage | Vss | | 0.8 | V | | ILOD | Input Leakage Current | | < 3 | 15 | μА | | Vol | Output Low Voltage I <sub>Load</sub> = 1.6mA | | | 0.4 | V | #### PORT D (digital inputs only) | Symbol | Parameter | Min. | Тур. | Max. | Unit | |-----------------|--------------------|-----------------|------|------|------| | V <sub>IH</sub> | Input High Voltage | 2.0 | | Vcc | V | | $V_{IL}$ | Input Low Voltage | V <sub>SS</sub> | | 0.8 | V | | lin | Input Current* | | < 1 | 5 | μА | <sup>\*</sup> PD4/VRL – PD5/VRH: The A/D conversion resistor (15kΩ typical) is connected internally between these two lines, impacting their use as digital inputs in some applications. Figure 2: TTL Equivalent Test Load (port B). Figure 4: TTL Equivalent Test Load (port A and C). #### SIGNAL DESCRIPTION The input and output signals for the MCU, shown in figure 1, are described in the following paragraphs. $V_{CC}$ and $V_{SS}$ - Power is supplied to the MCU using these two pins. $V_{CC}$ is power and $V_{SS}$ is the ground connection. **INT** - This pin provides the capability for asynchronously applying an external interrupt to the MCU. Refer to Interrupts Section for additional information. **NUM (NON USER MODE)** - This pin is not for user application and must be connected to Vss. XTAL AND EXTAL - These pins provide control input for the on-chip clock oscillator circuit. A crystal, a resistor, or an external signal, depending on user selectable manufacturing mak option, can be connected to these pins to provide a system clock with various degrees of stability/cost tradeoffs. Lead length and stray capacitance on these two pins should be minimized. Refer to Internal Clock Generator Options Section for recommendations about these inputs. **TIMER** - The pin allows an external input to be used to control the internal timer circuitry and also to initiate the self test program. Refer to Timer Section for additional information about the timer circuitry. **RESET** - This pins allows resetting of the MCU at times other than the automatic resetting capability already in the MCU. The MCU can be reset by pull- Figure 3: CMOS Equivalent Test Load (port A). Figure 5: Open-Drain Equivalent Test Load (port C). ing RESET low. Refer to Resets Section for additional information. 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 (DDRs). Port D has up to four analog inputs, plus two voltage reference inputs when the A/D converter is used (PD5/V<sub>RH</sub>, PD4/V<sub>RL</sub>), and an INT2 input, and from one to eight digital inputs. If any analog input is used, then the voltage reference pins (PD5/V<sub>RH</sub>, PD4/V<sub>RL</sub>) must be used in the analog mode. Refer to Input/Output Section, A/D Converter Section, and Interrupts Section for additional information. MEMORY - The MCU is capable of addressing 4096 bytes of memory and I/O registers with its program counter. The EF6805R2 MCU has implemented 2316 of these bytes. This consists of: 2048 user ROM bytes, 192 self-check ROM bytes, 64 user RAM bytes, 7 port I/O bytes, 2 timer registers. 2 A/D registers, and a miscellaneous register; see figure 6 for the Address map. The user ROM has been split into three areas. The main user ROM area is from \$080 to \$0FF and from \$7C0 to \$F37. The last 8 user ROM locations at the bottom of memory are for the interrupt vectors. The MCU reserves the first 16 memory locations for I/O features, of which 12 have been implemented. These locations are <u>used</u> for the ports, the ports DDRs, the timer, the INT2 miscellaneous register, and the A/D. Of the 64 RAM bytes, 31 bytes are shared with the stack area. The stack must be used with care when data shares the stack area. The shared stack area is used during the processing of an interrupt or subroutine calls to save the contents of the CPU state. The register contents are pushed onto the stack in the order shown in figure 7. Since the stack pointer decrements during pushes, the low order byte (PCL) of the program counter is stacked first, then the high order four bits (PCH) are stacked. This ensures that the program counter is loaded correctly during pulls from the stack since the stack pointer increments when it pulls data from the stack. A subroutine call results in only the program counter (PCL, PCH) contents being pushed onto the stack; the remaining CPU registers are not pushed. Figure 6: EF6805R2 MCU Address Map. Figure 7: Interrupt Stacking Order. #### **CENTRAL PROCESSING UNIT** The CPU of the EF6805 Family is implemented independently from the I/O or memory configuration. Consequently, it can be treated as an independent central processor communicating with I/O and memory via internal address, data, and control buses. #### REGISTERS The 6805 Family CPU has five registers available to the programmer. They are shown in figure 8 and are explained 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 instruction value to create an effective address. The index register can also be used for data manipulations using the read-modify-write instructions. The Index Register may also be used as a temporary storage area. Figure 8: Programming Model. 8/36 SGS-THOMSON NICROELECTRODICS **PROGRAM COUNTER (PC)** - The program counter is a 12-bit register that contains the address of the next instruction to be executed. STACK POINTER (SP) - The stack pointer is a 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 to location \$07F. The stack pointer is then decremented as data is pushed onto the stack and incremented as data is then pulled from the stack. The seven most significant bits of the stack pointer are permanently set to 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). **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 action taken as a result of their state. Each bit is explained in the following paragraphs. **Half Carry (H)** - 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 (INT and INT2) are masked (disabled). If an 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 logical "1"). **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 Logic Unit (ALU) occurred during the last arithmetic operation. This bit is also affected during bit test and branch instructions plus shifts and rotates. #### TIMER The timer circuitry for the MC6805R2 is shown in figure 10. The 8-bit counter may be loaded under program control and is decremented toward zero by the clock input (or prescaler output). When the timer reaches zero, the timer interrupt request bit (bit 7) in the timer control register (TCR) is set. The timer interrupt can be masked (disabled) by setting the timer interrupt mask bit (bit 6) in the TCR. The interrupt bit (I bit) in the condition code register also prevents a timer interrupt from being processed. The MCU responds to this interrupt by saving the present CPU state on the stack, fetching the timer interrupt vector from locations \$FF8 and \$FF9 and executing the interrupt routine (see RESET, CLOCK, AND INTERRUPT STRUCTURE SECTIONS). The timer interrupt request bit must be cleared by software. The TIMER and INT2 share the same interrupt vector. The interrupt routine must check the request bits to determine the source of the interrupt. The clock input to the timer can be from an external source (decrementing of timer counter occurs on a positive transition of the external source) applied to the TIMER input pin, or it can be the internal phase two signal. Three machine cycles are required for a change in state of the TIMER pin to decrement the timer prescaler. The maximum frequency of a signal that can be recognized by the TIMER pin logic is dependent on the parameter labeled twh. The pin logic that recognizes the high state on the pin must also recognize the low state on the pin in order to "re-arm" the internal logic. Therefore, the period can be calculated as follows (assumes 50/50 duty cycle for a given period): $$t_{cyc} \times 2 + 250 \text{ns} = \text{period} = \frac{1}{\text{freq}}$$ The period is not simply t<sub>WL</sub> + t<sub>WH</sub>. This computation is allowable, but it does reduce the maximum allowable frequency by defining an unnecessarily longer period (250 nanoseconds times two). When the phase two signal is used as the source, it can be gated by an input applied to the TIMER input pin allowing the user to easily perform pulse-width measurements. The source of the clock input is one of the mask options that is specified before manufacture of the MCU. #### NOTE For ungated phase two clock input to the timer prescaler, the TIMER pin should be tied to $V_{\rm CC}$ . A prescaler option, divide by 2<sup>n</sup>, can be applied to the clock input that extends the timing interval up to a maximum of 128 counts before decrementing the counter. This prescaling mask option is also specified before manufacture. To avoid truncation errors, the prescaler is cleared when bit 3 of the timer control register is written to a logic one (this bit always reads a logic zero). See figure 9. Figure 9: Timer Register (TCR). Figure 10: Timer Block Diagram. The timer continues to count past zero, falling through to \$FF from \$00 and then continuing the countdown. Thus, 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, and not disturb the counting process. At power up or reset, the prescaler and counter are initialized with all logic ones; the timer interrupt request bit (bit 7) is cleared and the timer interrupt mask bit (bit 6) is set. #### SELF-CHECK The self-check capability of the EF6805R2 MCU provides an internal check to determine if the part is functional. Connect the MCU as shown in figure 11 and monitor the output of Port C bit 3 for an oscillation of approximately 7Hz. A 10-volt level (through a 10k resistor) on the timer input, pin 8 and press- ing then releasing the RESET button, energizes the ROM-based self-check feature. The self-check program exercises the RAM, ROM, TIMER, A/D, interrupts, and I/O ports. Several of the self-check subroutines can be called by a user program with a JSR or BSR instruction. They are the RAM, ROM, and 4-channel A/D tests. The timer routine may also be called if the timer input is the internal 62 clock. To call those subroutines in customer applications, please contact your local SGS THOMSON sales of-fice in order to obtain the complete description of the self-check program and the entrance/exit conditions. RAM SELF-CHECK SUBROUTINE - The RAM self-check is called at location \$F6F and returns with the Z bit clear if any error is detected; otherwise the Z bit is set. The walking diagnostic pattern method is used on the EF6805R2. The RAM test must be called with the stack pointer at \$07F. When run, the test checks every RAM cell except for \$07F and \$07E which are assumed to contain the return address. The A and X registers and all RAM locations except \$07F and \$07E are modified. Figure 11: Self-Check Connections. **ROM CHECKSUM SUBROUTINE** - The ROM self-check is called at location \$F8A. If any error is detected, it returns with the Z bit cleared; otherwise Z = 1, X = 0 on return, and A is zero if the test passes. RAM location \$040 to \$043 is overwritten. The checksum is the complement of the execution OR of the contents of the user ROM. #### **LED MEANINGS** | PC0 | PC1 | PC2 | РСЗ | Remarks<br>[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 | | Α | Any Flashing | | | Good Device | Anything else bad Device. Bad Port C, etc. **ANALOG-TO-DIGITAL CONVERTER SELF-CHECK** - The A/D self-check is called at location FA4 and returns with the Z bit cleared if any error was found, otherwise Z = 1. The A and X register contents are lost. The X register must be set to 4 before the call. On return, X=8 and A/D channel 7 is selected. The A/D test uses the internal voltage references and confirms port connections. **TIMER SELF-CHECK SUBROUTINE** - The timer self-check is called at location FCF and returns with the Z bit cleared if any error was found; otherwise Z = 1. In order to work correctly as a user subroutine, the internal 2 clock must be the clocking source and interrupts must be disabled. Also, on exit, the clock is running and the interrupt mask is not set so the caller must protect from interrupts if necessary. The A and X register contents are lost. The timer self-check routine counts how many times the clock counts in 128 cycles. The number of counts should be a power of 2 since the prescaler is a power of 2. If not, the timer is probably not counting correctly. The routine also detects a timer which is not running. #### RESET The MCU can be reset three ways: by initial powerup, by the external reset input (RESET) and by an optional internal low-voltage detect circuit. The RESET input consists mainly of a Schmitt trigger which senses the RESET line logic level. A typical reset Schmitt trigger hysteresis curve is shown in figure 12. The Schmitt trigger provides an internal reset voltage if it senses a logical zero on the RESET pin. Power-On Reset (POR) - An internal reset is generated upon powerup that allows the internal clock generator to stabilize. A delay of transcription of the required before allowing the RESET input to go high. Refer to the power and reset timing diagram of figure 13. Connecting a capacitor to the RESET input (as illustrated in figure 14) typically provides sufficient delay. During powerup, the Schmitt trigger switches on (removes reset) when RESET rises to VIRESE. Figure 12: Typical Reset Schmitt Trigger Hysteresis. Figure 13: Power and Reset Timing. Figure 14: RESET Configuration. **External Reset Input** - The <u>MCU</u> will be reset if a logical zero is applied to the RESET input for a period longer than one machine cycle (t<sub>cyc</sub>). Under this type of reset, the Schmitt trigger switches off at V<sub>IRES</sub>— 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_{LVI}$ ). The only requirement is that $V_{CC}$ remains at or below the $V_{LVI}$ threshold for one $t_{cyc}$ minimum. In typical applications, the $V_{CC}$ bus filter capacitor will eliminate negative-going voltage glitches of less than one $t_{cyc}$ . 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 will be removed once the power supply voltage rises above a recovery level ( $V_{LVR}$ ), at which time a normal power-on-reset occurs. #### INTERNAL CLOCK GENERATOR OPTIONS The internal clock generator circuit is designed to require a minimum of external components. A crys- tal, a resistor, a jumper wire, or an external signal may be used to generate a system clock with various stability/cost tradeoffs. The oscillator frequency is internally divided by four to produce the internal system clocks. A manufacturing mask option is used to select crystal or resistor operation. The different connection methods are shown in figure 15. Crystal specifications and suggested PC board layouts are given in figure 16. A resistor selection graph is given in figure 17. The crystal oscillator start-up time is a function of many variables: crystal parameters (especially Rs), oscillator load capacitances, IC parameters, ambient temperature, and supply voltage. To ensure rapid oscillator start up, neither the crystal characteristics nor the load capacitances should exceed recommendations. When utilizing the on-board oscillator, the MCU should remain in a reset condition (reset pin voltage below V<sub>IRES+</sub>) until the oscillator has stabilized at its operating frequency. Several factors are involved in calculating the external reset capacitor required to satisfy this condition: the oscillator start-up voltage, SGS-THOMSON MICROELECTRONICS the oscillator stabilization time, the minimum VIRES+, and the reset charging current specification. Once V<sub>CC</sub> minimum is reached, the external RESET capacitor will begin to charge at a rate dependent on the capacitor value. The charging current is supplied from Vcc through a large resistor, so it appears almost like a constant current source until the reset voltage rises above VIRES+. Therefore, the RESET pin will charge at approximately: (VIRES+) · Cext = IRES · tRHL Assuming the external capacitor is initially discharged. Figure 15: Clock Generator Options. The recommended C<sub>L</sub> value with a 4.0MHz crystal is 27pF, maximum, including system distributed capacitance. There is an internal capacitance of approximately 25pF on the XTAL pin. For crystal frequencies other than 4MHz, the total capacitance on each pin should be scaled as the inverse of the frequency ratio. For example, with a 2MHz crystal, use approximately 50pF on EXTAL and approximately 25pF on XTAL. The exact value depends on the Motional-Arm parameters of the crystal used. Figure 16: Crystal Monotial Arm Parameters and Suggested PC Board Layout. Figure 17: Typical Frequency Selection for Resistor (oscillator option). #### INTERRUPTS The microcomputers can be interrupted four different ways: through the external interrupt (INT) input pin, the internal timer interrupt request, the external port D bit 6 (INT2) input pin, or the software interrupt instruction (SWI). When any interrupt occurs: the current instruction (including SWI) is completed, processing is suspended, the present CPU state is pushed onto the stack, the interrupt bit (I) in the condition code register is set, the address of the interrupt routine is obtained from the appropriate interrupt vector address, and the interrupt routine is executed. Stacking the CPU register, setting the I bit, and vector fetching require a total of 11 tovo periods for completion. A flowchart of the interrupt sequence is shown in figure 18. The interrupt service routine must end with a return from interrupt (RTI) instruction which allows the MCU to resume processing of the program prior to the interrupt (by unstacking the previous CPU state). 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. When the current instruction is complete, the processor checks all pending hardware interrupts and if unmasked, proceedswith 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 interupt are pending at the end of an instruction execution, the external interrupt is serviced first. The SWI is executed as any other instruction. Figure 18: Reset and Interrupt Processing Flowchard. #### NOTE The timer and $\overline{\text{INT2}}$ interrupts share the same vector address. The interrupt routine must determine the source by examining the interrupt request bits (TCR b7 and MR b7). Both TCR b7 and MR b7 can only be written to zero by software. The external interrupt, INT and INT2, are synchronized and then latched on the falling edge of the input signal. The INT2 interrupt has an interrupt request bit (bit 7) and a mask bit (bit 6) located in the miscellaneous register (MR). The INT2 interrupt is inhibited when the mask bit is set. The INT2 is always read as a digital input on port D. The INT2 and timer interrupt request bits, if set, cause the MCU to process an interrupt when the condition code I bit is clear. Figure 19: Typical Interrupt Circuits. A sinusoidal input signal (f<sub>INT</sub> maximum) can be used to generate an external interrupt for use as a zero-crossing detector. This allows applications 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. See figure 19. #### NOTE The INT (pin 3) is internally biased at approximately 2.2V due to the internal zero-crossing detection. A software interrupt (SWI) is an executable instruction which is executed regardless of the state of the I bit in the condition code register. SWIs are usually used as break-points for debugging or as systems calls. #### INPUT/OUTPUT CIRCUITRY There are 32 input/output pins. The INT pin may be polled will branch instructions to provide an additional input pin. All pins on ports A, B, and C are programmable as either inputs or outputs under software control of the corresponding data direction register (DDR). See below I/O port control registers configuration. The port I/O programming is accomplished by writing the corresponding bit in the port DDR to a logic one for output or a logic zero for input. On reset all the DDRs are initialized to a logic zero state, placing the ports in the input mode. The port output registers are not initialized on reset and should be initialized by software before changing the DDRs from input to output. A read operation on a port programmed as an output will read the contents of the output latch regardless of the logic at the output pin, due to output loading. Refer to figure 20. # PORT DATA REGISTER Port A Addr = \$000 Port B Addr = \$001 Port C Addr = \$002 Port D Addr = \$003 # PORT DATA DIRECTION REGISTER (DDR) - (1) Write Only; reads as all "1s" (2) 1 = Output, 0 = Input Cleared to 0 by Reset - (3) Port A Addr = \$004 Port B Addr = \$005 Port C Addr = \$006 Figure 20: Typical Port I/O Circuitry. 1 Pin 0 All input/output lines are TTL compatible as both inputs and outputs. Port A lines are CMOS compatible as outputs (mask option) while port B, C, and D lines are CMOS compatible as inputs. Port D lines are input only; thus, there is no corresponding DDR. When programmed as outputs, port B is capable of sinking 10 milliamperes and sourcing 1 milliampere on each pin. High-Z\*\* 1 Х 1 Ω Port D provides the reference voltage, $\overline{\text{INT2}}$ , and multiplexed analog inputs. All of these lines are shared with the port D digital inputs. Port D may always be used as digital inputs and may also be used as analog inputs providing $V_{RH}$ and $V_{RL}$ are connected to the appropriate reference voltages. The $V_{RL}$ and $V_{RH}$ lines (PD4 and PD5) are internally connected to the A/D resistor. Analog inputs may be prescaled to attain the $V_{RL}$ and $V_{RH}$ recommended input voltage range. The address map (figure 6) gives the addresses of data registers and data direction registers. Figure 21 provides some examples of port connections. #### CAUTION The corresponding DDRs for ports A, B, and C are write-only registers (registers at \$004, \$005, \$006). A read operation on these registers is undefined. Since BSET and BCLR are read-modify-write in function, they cannot be used to set or clear a single 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. The latched output data bit (see figure 20) must 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 may be used to initialize the data register and avoid undefined outputs; however, 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 corresponds to the latched output data when the DDR is an output (one). Figure 21: Typical Port Connections. SGS-THOMSON MICROELECTROMICS #### **ANALOG-TO-DIGITAL CONVERTER** The EF6805R2 has an 8-bit analog-to-digital (A/D) converter implemented on the chip using a successive approximation technique, as shown in figure 22. Up to four external analog inputs, via port D, are connected to the A/D through a multiplexer. Four internal analog channels may be selected for calibration purposes ( $V_{RH}$ - $V_{RL}$ , $V_{RH}$ - $V_{RL}$ /2, $V_{RH}$ - $V_{RL}$ /4, and $V_{RL}$ ). The accuracy of these internal channels will not necessarily meet the accuracy specifications of the external channels. The multiplexer selection is controlled by the A/D control register (ACR) bits 0, 1, and 2; see table 1. This register is cleared during any reset condition. Figure 22: A/D Block Diagram. Table 1 : A/D Input Mux Selection. | A/D | Control Reg | ister | | A/D Output (hex) | | | |------|-------------|-------|---------------------|------------------|------|------| | ACR2 | ACR1 | ACR0 | Input Selected | Min. | Тур. | Max. | | 0 | 0 | 0 | AN0 | | | | | 0 | 0 | 1 1 | AN1 | | | | | Ó | 1 | 0 | AN2 | | | | | 0 | 1 | 1 1 | AN3 | | | | | 1 | 0 | 0 | V <sub>RH</sub> * | FE | FF | FF | | 1 | 0 | 1 1 | V <sub>BL</sub> * | 00 | 00 | 01 | | 1 | 1 | 0 | V <sub>RH/4</sub> * | 3F | 40 | 41 | | 1 | 1 | 1 | V <sub>RH/2</sub> * | 7F | 80 | 81 | <sup>\*</sup> Internal (calibration) levels. # MISCELLANEOUS REGISTER (MR) A/D RESULT REGISTER (ARR) 7 6 0 7 0 Image: Control of the detected on INT2 pin, must be cleared by software. Cleared to 0 by Reset. MR6 Bit 6 – INT2 Interrupt Mask Bit : 1 = INT2 Interrupt masked (disabled). Set to 1 by Reset. MR Bits 5, 4, 3, 2, 1, 0 - Read as "1s" - unused bits. 20/36 SGS-THOMSON WICE ROBLECT ROBBES Whenever the ACR is written, the conversion in progress is aborted, the conversion complete flag (ACR bit 7) is cleared, and the selected input is sampled for five machine cycles and held internally. During these five cycles, the analog input will appear ap- proximately like a 25 picofarad (maximum) capacitor (plus approximately 10pF for packaging) charging through a 2.6 kiloohm resistor (typical). Refer to figure 23. Figure 23: Effective Analog Input Impedance (during sampling only). The converter operates continuously using 30 machine cycles to complete a conversion of the sampled analog input. When the conversion is complete, the digitized sample of digital value is placed in the A/D result register (ARR), the conversion complete flag is set, the selected input is sampled again, and a new conversion is started. The A/D is ratiometric. Two reference voltages ( $V_{RH}$ and $V_{RL}$ ) are supplied to the converter via port D pins. An input voltage equal to $V_{RH}$ converts to \$FF (full scale) and an input voltage equal to $V_{RL}$ converts to \$00. An input voltage greater than $V_{RH}$ converts to SFF and no overflow indication is provided. Similarly, an input voltage less than $V_{RL}$ , but greater than $V_{SS}$ converts to \$00. Maximum and minimum ratings must not be exceeded. For ratiometric conversion, the source of each analog input should use $V_{RH}$ as the supply voltage and be referenced to $V_{RL}$ . To maintain the full accuracy on the $A\!\!/\!D$ , $V_{RH}$ should be equal to or less than $V_{DD}$ , $V_{RL}$ should be equal to or greater than $V_{SS}$ but less than the maximum specification and $(V_{RH}\text{-}V_{RL})$ should be equal to or greater than 4 volts. The A/D has a built-in LSB offset intended to reduce the magnitude of the quantizing error to LSB, rather than + 0, - 1 LSB with no offset. This implies that, ignoring errors, the transition point from \$00 to \$01 occurs at LSB above $V_{RL}$ . Similarly, the transition from \$FE to \$FF occurs 1 1/2 LSB below $V_{RH}$ , ideally. Refer to figure 24 and 25. On release of reset, the A/D control register (ACR) is cleared therefore after reset, channel zero will be selected and the conversion complete flag will be clear. Figure 24: Ideal Converter Transfer Characteristic. SGS-THOMSON Figure 25: Types of Conversion Errors. #### **BIT MANIPULATION** The EF6805R2 as the ability to set or clear any single RAM or I/O bit (except the data direction registers) with a single instruction (BSET, BCLR) (see Caution below). Any bit in page zero can be tested using the BRSET and BRCLR instructions and the program branches as a result of its state. The carry bit equals the value of the bit references by BRSET or BRCLR. The capability to working with any bit in RAM, ROM, or I/O allows the user to have individual flags in RAM or to handle single I/O bits as control lines. #### CAUTION The corresponding data direction registers for ports A, B, and C are write-only registers locations \$004, \$005, and \$006). A read operation on these regis- ters is undefined. Since BSET and BCLR are readmodify-write functions, they cannot be used to set a data direction register bit (all "unaffected" bits would be set). It is recommended that all data direction register bits in a port be written using a single-store instruction. The coding examples shown in figure 26 illustrate the usefulness of the bit manipulation and test instruction. Assume that the microcomputer is to communicate with an external serial device. The external device has a data ready signal, a data output line, and a clock line to clock data one bit at a time, least significant bit first out, of the device. The microcomputer waits until the data is ready, clocks the external device, picks up the data in the carry flag, clears the clock line, and finally accumulates the data bit in a random-access memory location. Figure 26: Bit Manipulation Example. #### ADDRESSING MODES The EF6805R2 MCU has ten addressing modes available for use by the programmer. They are explained briefly in the following paragraphs. For additional details and graphical illustrations, refer to the EF6805 Family Users Manual. The term "effective address" (EA) is used in describing the addressing modes. EA 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 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 2-byte instruction. This address area includes all on-chip RAM and I/O registers and 128 bytes of ROM. Direct addressing is an effective use of both memory and time. 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 mode are capable of referencing arguments anywhere in memory with a single 3-byte instruction. When using the assembler, the user need not specify whether an instruction uses direct or extended addressing. The assembler automatically selects the shortest form of the instruction. RELATIVE - The relative addressing mode 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 from - 126 to + 129 from the opcode address. The programmer need not worry about calculating the correct offset if he uses the assembler, since it calculates the proper offset and checks to see if it is within the span of the branch. 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 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 opcode. This addressing mode is useful in selecting the kth element in an n element table. With this 2-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 3-byte instruction allows tables to be anywhere in memory. As with direct and extended, the assembler determines the shortest form of indexed addressing. BIT SET/CLEAR - In the bit set/clear addressing mode, the bit to be set or cleared is part of the opcode, and the byte following the opcode specifies the direct address of the byte in 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 2-byte instruction. #### CAUTION The corresponding DDRs for ports A, B, and C are write-only registers (registers at \$004, \$005, \$006). A read operation on these registers is undefined. Since BSET and BCLR are read-modify-write in function, they cannot be used to set or clear a single DDR bit (all "unaffected" bits would be set). It is recommended that all DDR bits in a port be must 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 which is to be tested and condition (set or clear) is included in the opcode, and the address of the 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 3-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 registers. #### CAUTION The corresponding DDRs for ports A, B, and C are write-only registers (registers at \$004, \$005, \$006). A read operation on these registers is undefined. Since BSET and BCLR are read-modify-write in function, they cannot be used to set or clear a single DDR bit (all "unaffected" bits would be set). It is recommended that all DDR bits in a port be must written using a single-store instruction. 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 control instructions with no other arguments, are included in this mode. These instructions are one byte long. #### INSTRUCTION SET The EF6805R2 MCU has a set of 59 basic instructions, which when combined with the 10 addressing modes produce 207 usable opcodes. 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 jump unconditional (JMP) and jump to subroutine (JSR) instructions have no register operand. Refer to table 1. 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; see Caution under Input/Output section. The test for negative or zero (TST) instruction is included in the read-modify-write instruction though it does not perform the write. Refer to table 2. BRANCH INSTRUCTIONS - The branch instructions cause a branch from the program when a certain condition is met. Refer to table 3. BIT MANIPULATION INSTRUCTIONS - The instructions are used on any bit in the first 256 bytes of the memory; One group either sets or clears. The other group performs the bit test and branch operations. Refer to table 4. # CAUTION The corresponding DDRs for ports A, B, and C are write-only registers (registers at \$004, \$005, \$006). A read operation on these registers is undefined. Since BSET and BCLR are read-modify-write in function, they cannot be used to set or clear a single DDR bit (all "unaffected" bits would be set). It is recommended that all DDR bits in a port be must written using a single-store instruction. CONTROL INSTRUCTION - The control instructions control the MCU operations during program execution. Refer to table 5. ALPHABETICAL LISTING - The complete instruction set is given in alphabetical order in table 6. OPCODE MAP - Table 8 is an opcode map for the instruction used on the MCU. Table 1 : Register/memory Instructions. | | | | | | | | | | Ad | Addressing Modes | g Mo | des | Ì | | | | | | | |------------------------------------------|---------------|--------------|-----------|-------------|-----------------|------------|--------|-------------|----------|------------------|---------|------------------------|--------|-------------|---------------------------|-----------------------------|------------|----------------------------|--------| | | | = | Immediate | ate | | Direct | | ш | Extended | p | ے – | Indexed<br>(no offset) | a G | 8 - 18 | Indexed<br>(8 bit offset) | set) | | Indexed<br>(16 bit offset) | a es | | Function | Mnemonic Op # | O p<br>G p g | Bytes | #<br>Cycles | ရ<br>စစ်<br>စစ် | #<br>Bytes | Cycles | ၀ ပ<br>ရစ္မ | Bytes | #<br>Cycles | ရီ ဝ | #<br>Bytes ( | Cycles | ရုံ<br>ဝပ္ပ | Bytes | # # Op<br>Bytes Cycles Code | a \$ | By tes | Cycles | | Load A from Memory | LDA | A6 | 2 | 2 | Be | 2 | 4 | ဗ | 3 | 5 | F6 | 1 | 4 | Ee | 2 | s | 8 | က | ဖ | | Load X from Memory | TDX | ΑE | 5 | 2 | BE | 2 | 4 | æ | 3 | 5 | FE | - | 4 | 33 | 2 | 5 | 30 | 3 | 9 | | Store A in Memory | STA | | | | B7 | 2 | 5 | C2 | 3 | 9 | F7 | +- | 2 | E7 | 2 | 9 | 20 | ၉ | 7 | | Store X in Memory | STX | | | | BF | 2 | 5 | CF | 3 | 9 | FF | - | 5 | EF | 2 | 9 | 늅 | 6 | _ | | Act Memory to A | ADD | AB | 2 | 2 | BB | 2 | 4 | CB | 3 | 5 | FB | - | 4 | EB | 2 | 2 | 8 | 6 | 9 | | Add Memory and<br>Carry to A | ADC | A9 | 2 | 2 | 88 | 2 | 4 | පී | ဗ | 5 | F9 | - | 4 | 63 | 2 | 2 | 80 | 6 | 9 | | Subtract Memory | SUB | AO | 2 | 2 | B0 | 2 | 4 | 8 | 3 | 5 | F0 | - | 4 | 8 | 2 | 5 | 8 | 3 | 9 | | Subtract Memory from<br>A with Borrow | SBC | A2 | 2 | 2 | B2 | 2 | 4 | 2 | 6 | 5 | F2 | ,- | 4 | E2 | 2 | 5 | D2 | 3 | 9 | | AND Memory to A | AND | A4 | 7 | 2 | B4 | 2 | . 4 | 2 | 3 | 5 | F4 | 1 | 4 | E4 | 2 | 5 | <b>D</b> 4 | 3 | 9 | | OR Memory with A | ORA | ¥ | 2 | 2 | Æ | 2 | 4 | S, | 3 | 5 | FA | - | 4 | Ð | 2 | 5 | Ą | 3 | 9 | | Exclusive OR Memory with A | EOR | A8 | 2 | 2 | B8 | 2 | 4 | ఔ | ဗ | လ | 85<br>8 | • | 4 | EB | 2 | 5 | 8 | င | 9 | | Arithmetic Compare A with Memory | CMP | A1 | 2 | 2 | <b>B</b> | 2 | 4 | ၓ | က | 5 | F | - | 4 | Ð | 2 | 9 | 10 | 8 | 9 | | Arithmetic Compare X with Memory | CPX | A3 | 2 | 2 | <b>B</b> 3 | 2 | 4 | ខ | က | 5 | ត | - | 4 | ន | 2 | 2 | 8 | 8 | 9 | | Bit Test Memory with A (logical compare) | ВІТ | A5 | 2 | 2 | 88 | 2 | 4 | ន | က | 2 | F5 | - | 4 | 23 | 7 | 2 | 8 | ဧ | 9 | | Jump Unconditional | JMP | | | | ည္ထ | 7 | 3 | ខ | ဗ | 4 | 윤 | - | ဗ | 잂 | 7 | 4 | 8 | 3 | 5 | | Jump to Subroutine | SR | | | | B | 2 | 7 | ខ | 3 | 8 | 윤 | - | 7 | ED | 2 | 8 | 8 | 3 | 6 | Table 2: Read- Modify-Write Instructions. | Inherent (A) | | | | | | | | | Addre | Addressing Modes | odes | | | | | | | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|----------|-------------|----------|-----|------|--------|-------------|-------------|------------------|-------------|-----------|------------------------|-------------|-------------|---------------------------|-------------| | Function Mnem Op #cde # bytes Op #cde # bytes Op #cde # bytes Op #cde # bytes Op #cde # bytes Total Shift Right AS 1 AS 1 AS AS 1 AS <th></th> <th></th> <th>Ē</th> <th>nerent (</th> <th>- ₹</th> <th>=</th> <th>Jerent</th> <th>8</th> <th></th> <th>Direct</th> <th></th> <th></th> <th>Indexed<br/>(no offset)</th> <th></th> <th>- 8)</th> <th>Indexed<br/>(8 bit offset)</th> <th>-</th> | | | Ē | nerent ( | - ₹ | = | Jerent | 8 | | Direct | | | Indexed<br>(no offset) | | - 8) | Indexed<br>(8 bit offset) | - | | INC 4C 1 4 Innent DEC 4A 1 4 Idenent CLR 4F 1 4 Idenent COM 43 1 4 Idenent COM 43 1 4 Idenent COM 43 1 4 Idenent COM 43 1 4 Idenent COM 49 1 4 Idenent Carry ROL 40 Ide | Function | Mnem | ရစ်<br>ဝ ဝိ | Bytes | | ၀ ပိ | Bytes | #<br>Cycles | ရစ္<br>ဝင္ပ | # Bytes | #<br>Cycles | ရီစ<br>ဝဝ | #<br>Bytes | #<br>Cycles | O P<br>Code | #<br>Bytes | #<br>Cycles | | DEC 4A 1 4 | rement | S | ą | - | 4 | င္ထ | - | 4 | ဘ္ထ | 2 | 9 | 5 | • | 9 | ၁မွ | 2 | 7 | | CLR 4F 1 4 1 4 1 4 1 4 1 4 1 4 1 4 1 4 1 4 1 4 1 4 1 4 1 4 1 4 1 4 1 4 1 4 1 4 1 4 1 4 1 4 1 4 1 4 1 4 1 4 1 4 1 4 1 4 1 4 1 4 1 4 1 4 1 4 1 4 1 4 1 4 1 4 1 4 1 4 1 4 1 4 1 4 1 4 1 4 1 4 1 4 1 4 1 4 1 4 1 4 1 4 1 4 1 4 1 4 1 4 1 4 1 4 1 4 1 4 1 4 1 4 1 4 4 | crement | DEC | 4 | - | 4 | 5A | - | 4 | 3A | 2 | 9 | 7A | + | တ | ₩ | 7 | 7 | | NEG 40 1 4 Y ROL 49 1 4 HOL 49 1 4 HOL 49 1 4 HOL 1SL 48 1 4 HOL 1SR 44 1 1 4 HOL 1ST 4D | ar | CLR | 4F | - | 4 | 5F | 1 | 4 | 3F | 2 | 9 | 7F | - | 8 | 9F | 7 | 7 | | NEG 40 1 4<br>POL 49 1 4<br>ROR 46 1 4<br>LSL 48 1 4<br>LSR 44 1 4<br>ASR 47 1 4<br>TST 4D 1 4 | mplement | WOO<br>O | 43 | - | 4 | 53 | - | 4 | 33 | 2 | 9 | 73 | - | 9 | 63 | 2 | ~ | | y ROL 49 1 4 4 ROR 46 1 4 4 FOR 48 1 4 4 FOR 48 1 4 4 FOR 47 6 | gate<br>complement) | SPR | 6 | - | 4 | 20 | - | 4 | 30 | 2 | 9 | 02 | - | ဖ | 8 | N | ^ | | LSL 48 1 4 1 1 4 1 1 1 1 1 1 1 1 1 1 1 1 1 | tate Left Thru Carry | PDL | 49 | - | 4 | 59 | + | 4 | 39 | 2 | ဖ | 28 | - | ۵ | 69 | 2 | 7 | | LSR 44 1 4 A SSR 47 1 4 TST 4D 1 4 | tate Right Thru | ROR | 46 | - | 4 | 56 | - | 4 | 36 | 2 | 9 | 76 | - | 9 | 99 | 2 | 7 | | LSR 44 1 4<br>ASR 47 1 4<br>TST 4D 1 4 | gical Shift Left | TST | 48 | - | 4 | 58 | - | 4 | 38 | 2 | 9 | 78 | | ဖ | 99 | 2 | - | | ASR 47 1 4 | gical Shift Right | LSR | 4 | - | 4 | 54 | 1 | 4 | 34 | 2 | 9 | 74 | 1 | 9 | 64 | ~ | ^ | | TST 4D 1 4 | thmetic Shift Right | ASB | 47 | - | 4 | 57 | - | 4 | 37 | 2 | 9 | 77 | - | g | 29 | ~ | 7 | | Zero | st for Negative or<br>ro | TST | đ | - | 4 | 50 | - | 4 | ge<br>Ge | 2 | 9 | 70 | - | 9 | 8 | 2 | 7 | Table 3: Branch Instructions. | | | Relativ | e Addressii | ng Mode | |-----------------------------------------|----------|------------|-------------|-------------| | Function | Mnemonic | Op<br>Code | #<br>Bytes | #<br>Cycles | | Branch Always | BRA | 20 | 2 | 4 | | Branch Never | BRN | 21 | 2 | 4 | | Branch IFF Higher | BHI | 22 | 2 | 4 | | Branch IFF Lower or Same | BLS | 23 | 2 | 4 | | Branch IFF Carry Clear | BCC | 24 | 2 | 4 | | Branch IFF Higher or Same | BHS | 24 | 2 | 4 | | Branch IFF Carry Set | BCS | 25 | 2 | 4 | | Branch IFF Lower | BLO | 25 | 2 | 4 | | Branch IFF Not Equal | BNE | 26 | 2 | 4 | | Branch IFF Equal | BEQ | 27 | 2 | 4 | | Branch IFF Half Carry Clear | BHCC | 28 | 2 | 4 | | Branch IFF Half Carry Set | BHCS | 29 | 2 | 4 | | Branch IFF Plus | BPL | 2 <b>A</b> | 2 | 4 | | Branch IFF Minus | ВМІ | 2B | 2 | 4 | | Branch IFF interrupt mask bit is clear. | ВМС | 2C | 2 | 4 | | Branch IFF interrupt mask bit is set. | BMS | 2D | 2 | 4 | | Branch IFF interrupt line is low. | BIL | 2E | 2 | 4 | | Branch IFF interrupt line is high. | BIH | 2F | 2 | 4 | | Branch to Subroutine | BSR | AD | .2 | 8 | Table 4: Bit Manipulation Instructions. | | | | | Addressi | ng Mode: | s | | |----------------------------|------------------|------------|------------|-------------|------------|------------|-------------| | | | Bit | Set/Cle | ear | Bit Te: | st and E | Branch | | 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 = 07) | | | | 2 • n | 3 | 10 | | Branch IFF bit n is clear. | BRCLR n (n = 07) | T | | , | 01 + 2 • n | 3 | 10 | | Set Bit n | BSET n (n = 07) | 11 + 2 • n | 2 | 7 | | | | | Clear Bit n | BCLR n (n = 07) | 11 + 2 • n | 2 | 7 | 1 | | | Table 5: Control Instructions. | | | | Inherent | | |--------------------------|----------|------------|------------|-------------| | Function | Mnemonic | Op<br>Code | #<br>Bytes | #<br>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 | 2 | | Clear Interrupt Mask Bit | CLI | 9A | 1 | 2 | | Software Interrupt | SWI | 83 | 1 | 11 | | Return from Subroutine | RTS | 81 | 1 | 6 | | Return from Interrupt | RTI | 80 | 1 | 9 | | Reset Stack Pointer | RSP | 9C | 1 | 2 | | No-operation | NOP | 9D | 1 | 2 | Table 6: Instruction Set. | | | | | | Addressi | ng Modes | | | | | С | ondi | tion | Cod | e | |-------|----------|-----------|--------|----------|----------|------------------------|---------------------|----------------------|------------------|-------------------------|---|------|------|-----|----| | Mnem | Inherent | Immediate | Direct | Extended | Relative | Indexed<br>(no offset) | Indexed<br>(8 Bits) | Indexed<br>(16 Bits) | Bit<br>Set/Clear | Bit<br>Test &<br>Branch | н | ı | N | z | • | | ADC | | Х | × | Х | | X | х | Χ . | | | ^ | • | ^ | ^ | Γ, | | ADD | | X | × | Х | | х | х | х | | | ^ | • | ^ | ^ | Ι. | | AND | | Х | x | Х | | X | х | х | | | • | • | ^ | ^ | T | | ASL | х | | x | | | × | х | | | | • | • | ^ | ^ | Γ | | ASR | х | | × | | | X | х | | | | • | • | ^ | ^ | Γ | | всс | | | | | X | | | | | | • | • | • | • | Γ | | BCLR | | | | | | | | | × | | • | • | • | • | | | BCS | | | | | х | | | | | | • | • | • | • | | | BEQ | | | | | X | | | | | | • | • | • | • | Ī | | внсс | | | | | х | | | | | | • | • | • | • | - | | внсѕ | | | | | х | | | | | | • | • | • | • | | | вні | | | | | Х | | | | | | • | • | • | • | T | | внѕ | | | | | х | | | | | | • | • | • | • | Ī | | він | | | | | Х | | | | | | • | • | • | • | Ť | | BIL | | | | | х | | | | 1 | | • | • | • | • | T | | BIT | | х | × | Х | | × | х | х | | | • | • | ^ | ^ | Ť | | BLO | | | | | х | | | | | | • | • | • | • | T | | BLS | | | | | х | | | | | | • | • | • | • | Ť | | вмс | | | | | Х | | | | | | • | • | • | • | Ť | | ВМІ | | | | | х | | | | | | • | • | • | • | Ť | | вмѕ | | | | | х | | | | | | • | • | • | • | T | | BNE | | | | | х | | | | | | • | • | • | • | Ť | | BPL | | | | | х | | | | | | • | • | • | • | Ī | | BRA | | | | | х | | | | | | • | • | • | • | T | | BRN | | | | | х | | | | | | • | • | • | • | Ť | | BRCLF | 3 | | | | | | | | | х | • | • | • | • | T | | BRSET | - | | | | | | | | | × | • | • | • | • | t | | BSET | | | | | | | | | × | | • | • | • | • | Ť | | BSR | 1 | | | | х | | | | 1 | | • | • | • | • | t | | CLL | × | 1 | | | T | | | | 1 | | • | • | • | • | t | Condition Code Symbols: Half Carry (from bit 3) Interrupt Mask Negative (sign bit) Zero Z C Carry/borrow Test and Set if True, Cleared Otherwise Not Affected Table 6: Instruction Set (continued). | | | | | | Address | ing Modes | | | | | C | ondi | ition | Cod | ie | |------|----------|-----------|--------|----------|----------|------------------------|---------------------|----------------------|------------------|-------------------------|---|------|-------|-----|-----| | Mnem | Inherent | Immediate | Direct | Extended | Relative | Indexed<br>(no offset) | Indexed<br>(8 Bits) | Indexed<br>(16 Bits) | Bit<br>Set/clear | Bit<br>Test &<br>Branch | н | 1 | N | z | С | | CLI | Х | | | | | | | | | | • | 0 | • | • | • | | CLR | х | | Х | | | Х | х | | | | • | • | 0 | 1 | • | | СМР | | х | × | × | | X | Х | × | | | • | • | ^ | ^ | _^ | | СОМ | Х | | × | | | × | × | | | | • | • | ^ | ^ | 1 | | CPX | | х | х | × | | × | × | × | | | • | • | ^ | ^ | ^ | | DEC | X | | × | | | X | × | | | | • | • | ^ | ^ | • | | EOR | | х | × | × | | × | х | × | | | • | • | ^ | ^ | • | | INC | × | | × | | | х | х | | | | • | • | ^ | ^ | • | | JMP | | | х | × | | × | х | х | | | • | • | • | • | • | | JSR | | | × | × | | х | х | х | | | • | • | • | • | • | | LDA | | х | х | × | | X | х | х | | | • | • | ^ | ^ | • | | LDX | | Х | х | х | | × | х | × | | _ | • | • | ^ | ^ | • | | LSL | х | | × | | | × | х | | | | • | • | ^ | ^ | ^ | | LSR | X | | × | | | х | х | | | | • | • | 0 | ^ | ^ | | NEQ | Х | | Х | | | Х | х | | | | • | • | ^ | ^ | ^ | | NOP | X | | | | | | | | | | • | • | • | • | • | | ORA | | Х | × | х | | × | × | Х | | | • | • | _^ | ^ | • | | ROL | Х | | × | | | х | х | | | | • | • | ^ | ^ | _^ | | RSP | х | | | | | | | | | | • | • | • | • | • | | RTI | Х | | | | | | | | i | | ? | ? | ? | ? | ? | | RTS | Х | | I | | | | | | | | • | • | • | • | • | | SBC | | Х | × | x | | Х | × | x | | | • | • | ^ | ^ | _ ^ | | SEC | Х | | | | | | | | | | • | • | • | • | 1 | | SEI | х | | | | | | | | | | • | 1 | • | • | • | | STA | | | Х | X | | Х | × | X | | | • | • | ^ | ^ | • | | STX | | | Х | X | | Х | × | X | | | • | • | ^ | ^ | • | | SUB | | Х | Х | Х | | Х | Х | х | | | • | • | ^ | ^ | ^ | | SWI | X | | | | | | | | | | 9 | 1 | • | • | • | | TAX | х | | | | | | | | | | • | 9 | • | • | | | TST | × | | Х | | | х | х | | | | • | • | ^ | ^ | • | | TXA | X | | | | | | | | | | • | • | • | | • | Condition Code Symbols : H Half Carry (from bit 3) I Interrupt Mask N Negative (sign bit) Z Zero C Carry/borrow Test and Set if True, Cleared Otherwise Not Affected ? Load CC Register from Stack #### **EF6805 HMOS FAMILY** | Features | EF6805P2 | EF6805P6 | EF6805R2 | EF6805R3 | EF6805U2 | EF6805U3 | |---------------------------|----------|----------|------------|------------|----------|----------| | Technology | HMOS | HMOS | HMOS | HMOS | HMOS | HMOS | | Number of Pins | 28 | 28 | 40 | 40 | 40 | 40 | | On-chip RAM (bytes) | 64 | 64 | 64 | 112 | 64 | 112 | | On-chip User ROM (bytes) | 1100 | 1796 | 2048 | 3776 | 2048 | 3776 | | External Bus | None | None | None | None | None | None | | Bidirectional I/O Lines | 20 | 20 | 24 | 24 | 24 | 24 | | Unidirectional I/O Lines | None | None | 6 Inputs | 6 Inputs | 8 inputs | 8 Inputs | | Other I/O Features | Timer | Timer | Timer, A/D | Timer, A/D | Timer | Timer | | External Interrupt Inputs | 1 | 1 | 2 | 2 | 2 | 2 | | STOP and WAIT | No | No | No | No | No | No | Table 7: 6805 HMOS Family Instruction Set Opcode Map. | Γ | 7 | <b>§</b> | • | _6 | 20<br>00<br>00<br>00 | ۳. | -8 | <b>∽</b> g | 910<br>0110 | , ii | <b>∞</b> 8 | æğ | 401 | 80 5 | 8ں | ق | <br>0: | 1. | |-------------------|------|----------|----------|--------------|----------------------|------------|--------------|------------|--------------|---------------|---------------|----------------|-----------------|--------------|--------------|--------------|------------------------|-------------------------| | L | | ¥ | - | -8 | | ~8<br> | 75 | | | ة | | ωğ | <b>`</b> º | | | - | <b>.</b> | - | | | × | •= | SVB. | CMP | , 58C | <b>Š</b> | AND | E . | φ<br>O | STA | , EOR | , ADC | ORA | , ADD | י אאר<br>X | , JSR | רסא י | STX | | | × | 31. | SUB | S CMP | SBC<br>SBC | S CPX | AND | 5 BIT 2 | LDA<br>Z | STA | 5<br>EOR | ADC X1 | 5<br>ORA<br>1X1 | ADD X | JMP | JSR<br>2 IXI | רטא <sup>5</sup> נסא 2 | STX | | / Memory | X | υį | SUB X2 | CMP X2 | SBC IX2 | CPX<br>XX | AND X | BIT X | LDA | STA S | EOR IX2 | ADC X2 | ORA<br>3 ORA | ADD X2 | JMP 3 | JSH 3 | רטא אז | STX | | Register/ | EX | υğ | SUB | CMP EXT | SBC | CPX<br>Ext | AND | BIT<br>EXT | LDA<br>Ext | STA | S EOR | ADC<br>3 ADC | | ADD, | JMP | JSR | LOX | STX | | | ¥ Ö | 101 | SUB | CWP | SBC | CPX<br>Pa | ANC | BIT 2 | LDA<br>2 DIR | STA<br>2 | EOR 2 | ADC 3 | ORA | ADD, | JMP<br>2 Dis | JSR 2 | LDX<br>2 | STX | | | MM | 1010 | SUB | CMP | SBC | CPX<br>'MM | AND | BIT | LDA<br>MM | | EOR | ADC ADC | ORA | ADD A | | BSR<br>2 REL | ר באים | | | ō | IN | 1001 | | | | | | | | TAX | CLC | SEC | ران<br>پيد | SEI | RSP | NOP | | TXA | | Control | HY | -8 | T. T. | BTS : | | SWI | | | | | | | | | | | | | | | × | 0,111 | NEG X | | | COM | . RS1 | | ROR A | ASR | י רצר יא | ROL | DEC . | | INC X | TST | | | | rite | Į, | 01.10 | , NEG | | | , COM | LSA | | ROR 2 | ASH | , רצר | , ROL | , DEC, 1 | | NC<br>ixi | , TST 2 | | CLF | | Read-Modify-Write | H | 1010 | NEG | | | COMX | LSRX | | RORX | ASAX | HN: | ROLX | DECX | | INCX | TSTX | | CLRX<br>N | | E. | Z | 010 | NEG<br>T | | | COMA | LSAA | | RORA | ASRA | LSLA | ROLA | DECA | | INCA | TSTA | | CLRA | | | 100 | 'n | NEG | | | COM | LSR<br>2 DIR | | ROH 2 | ASR 2 | LSL . | ROL<br>2 DIR | DEC 2 | | INC 2 | TST 2 | | CLA BIR | | Branch | Ē | 78 | , 9RA | 7 CO | Ē | BLS. | ည္ဆီ | 2 S | BNE - | . <b>9</b> E0 | BHCC<br>Salar | BHCS<br>2 BHCS | 4 BPL | BMI<br>2 PEL | BMC<br>BMC | BMS | 4 BH. | BIH | | Manipulation | BSC | - § | BSETO | BCLRO<br>RSC | BSETI | BCLR1 | , 85672 | BCLR2 | , 85ET3 | BCLR3 | BSET4 | BCLR4 | BSETS | BCLR5 | BSET6 | BCLAG | BSET7 | BCLR7 | | Rit Man | N. H | -§ | BRSETO | BRCLRO | BRSETI | BACLRI | BASETZ | BRCLR2 | BRSET3 | BRCLR3 | BRSET4<br>818 | BRCLR4 | BRSETS | BRCLRS | BRSETE | BRCLAG | 9885ET7<br>818 | BRCLR7<br>BRCLR7<br>B19 | | | | Ī/3 | ه- | - [ | 78 | ٣į | <b>→</b> § | ر<br>او | • 5 | ٦- | Ϥ | ΦŽ | ٩ğ | œ Ş | ق م | قِم | ۳ | u. E | # of Cycles IMM Inherent Innerent Indexed 1 Byte (6 Bit) Offset Indexed 2 Byte (6 Bit) Offset Indexed 2 Byte (6 Bit) Offset Indexed 2 Byte (6 Bit) Offset Indexed 2 Byte (6 Bit) Offset Innerent Indexed 2 Byte (6 Bit) Offset Indexed 2 Byte (6 Bit) Offset Indexed 2 Byte (6 Bit) Offset Indexed 3 Bi Abbreviations for Address Modes 32/36 SGS-THOMSON MICROELECTRONICS #### PACKAGE MECHANICAL DATA #### P SUFFIX - PLASTIC PACKAGE #### FN SUFFIX - PLCC44 #### ORDERING INFORMATION The information required when ordering a custom MCU is listed below. The ROM program may be transmitted to SGS-THOMSON on EPROM(s) or an EFDOS/MDOS\* disk file. To initiate a ROM pattern for the MCU, it is necessary to first contact your local SGS THOMSON representative or distributor. #### **EPROMs** Two 2716 or one 2732 type EPROMs, programmed with the customer program (positive logic sense for address and data), may be submitted for pattern generation. The EPROM must be clearly marked to indicate which EPROM corresponds to which address space. The recommended marking procedure is illustrated below: After the EPROM(s) are marked, they should be placed in conductive IC carriers and securely packed. Do not use styrofoam. #### **VERIFICATION MEDIA** All original pattern media (EPROMs or floppy disk) are filled 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 SGS THOMSON. The signed verification form constitutes the contractual agreement for creation of the customer mask. If desired, SGS—THOMSON will program on blank EPROM from the data file used to create the custom mask and aid in the verification process. #### **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 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. The RVUs are thus not guaranteed by SGS—THOMSON. Quality Assurance, and should be discarded after verification is completed. #### FLEXIBLE DISKS The disk media submitted must be single-sided, EFDOS/MDOS\* compatible floppies. The customer must write the binary file name and company name on the disk with a felt-tip-pen. The minimum EFDOS/MDOS\* system files, as well as the absolute binary object file (Filename .LO type of file) from the 6805 cross assembler, must be on the disk. An object file made from a memory dump using the ROLLOUT command is also acceptable. Consider submitting a source listing as well as the following files: filename .LX (DEVICE/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 inhouse if any problems arise, and 2) to speed up the user-to-factory interface if the user finds any software errors and needs assistance quickly from SGS-THOMSON factory representatives. EFDOS is SGS THOMSON' Disk Operating System available on development systems such as DE-VICE... MDOS\* is MOTOROLA's Disk Operating System available on development systems such as EXORciser, ... Whenever ordering a custom MCU is required, please contact your local SGS THOMSON representative or SGS THOMSON distributor and/or complete and send the attached "MCU customer ordering sheet" to your local SGS THOMSON representative. <sup>\*</sup> Requires prior factory approval. # **ORDER CODES** The table below horizontally shows all available suffix combinations for package, operating and screening level. Other possibilities on request. | Davisa | | F | ackaç | je | | O | per. Te | mp | | Screen | ingLeve | I | |------------------------|---------|-------|-------|-------|-------|-------|---------|----|-----|--------|---------|-----| | Device | С | J | P | E | FN | L* | v | Т | Std | D | G/B | B/B | | | | | • | | • | • | • | • | • | • | | | | EF6805R2 | | | | | | | | | | | | | | | | | | | | | | | | | | | | Examples: EF6805R2P. E | F6805B2 | FN. E | F6805 | B2PV. | EF680 | 5R2FN | IV. | | 1 | • | | | Package: C: Ceramic DIL, J: Cerdip DIL, P: Plastic DIL, E: LCCC, FN: PLCC. Oper. temp.: L\*: 0°C to +70°C, V: -40°C to +85°C, T: -40°C to +105°C, \*: may be omitted. Screening level: Std: (no-end suffix), D: NFC 96883 level D, G/B: NFC 96883 level G, B/B: NFC 96883 level B and MIL-STD-883C level B. EXORciser is a registered trademark of MOTOROLA Inc. | EF6805 FAMILY - MCU CUST | OMER ORDERING SHEET | |--------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------| | Commercial reference : | Customer name : | | oustomer's marking . | | | Application : | Specification reference ; SGS-THOMSON Microelectronic reference | | | Special customer data reference* | | ROM capacity required : bytes | | | Temperature range : □ 0°C/+70°C □ -25°C/+70°C □ -40°C/+85°C | Quality level: STD D Other* (customer's quality specification ref.): | | Package ☐ Plastic ☐ PLCC | Software developped by : SGS-THOMSON Microelectronic application lab. External lab. Customer | | PATTERN MEDIA (a listing may be supplied in addition for checking purpose): EPROM Reference: EFDOS/MDOS* disk file 8" floppy 5" 1/4 floppy Other * | OPTION LIST -Oscillator input Xtal RC -Port A output drive: CMOS and TTL TTL only -Timer clock source: Internal f2 clock Timer input pin | | * Requires prior factory approval | | | Yearly quantity forecast | start of production date : for a shipment period of : | | CUSTOMER CONTACT NAME : DATE : | SIGNATURE : | | | | 36/36 SGS-THOMSON MICROELECTRORICS