MC68HC705K1/D Rev. 2.0 # MC68HC705K1 **HCMOS Microcontroller Unit** **TECHNICAL DATA** ### Technical Data — MC68HC705K1 ## **List of Sections** | Section 1. General Description15 | |-------------------------------------------| | Section 2. Memory25 | | Section 3. Central Processor Unit (CPU)31 | | Section 4. Interrupts | | Section 5. Resets51 | | Section 6. Low-Power Modes57 | | Section 7. Parallel Input/Output (I/O)63 | | Section 8. Multifunction Timer75 | | Section 9. EPROM/OTPROM83 | | Section 10. Personality EPROM (PEPROM)91 | | Section 11. Instruction Set | | Section 12. Electrical Specifications117 | | Section 13. Mechanical Specifications | | Section 13. Ordering Information | MC68HC705K1 — Rev. 2.0 Technical Data **List of Sections** ### Technical Data — MC68HC705K1 ## **Table of Contents** ### **Section 1. General Description** | 1.1 | Contents | |--------------------------------------------------------------------------------------|---------------------------------------------------------------------| | 1.2 | Introduction | | 1.3 | Features | | 1.4 | Mask Options | | 1.5 | MCU Structure | | 1.6<br>1.6.2<br>1.6.2<br>1.6.2<br>1.6.2<br>1.6.2<br>1.6.3<br>1.6.4<br>1.6.5<br>1.6.6 | 2Ceramic Resonator.2132-Pin RC Oscillator.2243-Pin RC Oscillator.23 | | 1.0.0 | | | | Section 2. Memory | | 2.1 | Contents | | 2.2 | Introduction | | 2.3 | Memory Map | | 2.4 | Input/Output Section | | 2.5 | Random-Access Memory (RAM)26 | | | | MC68HC705K1 — Rev. 2.0 **Technical Data** ## **Table of Contents** | 2.6 | EPROM/OTPROM | |-----------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 2.7 | Personality EPROM/OTPROM30 | | | Section 3. Central Processor Unit (CPU) | | 3.1 | Contents | | 3.2 | Introduction | | 3.3<br>3.3.1<br>3.3.2<br>3.3.3<br>3.3.4<br>3.3.5 | CPU Registers 32 Accumulator 33 Index Register 33 Stack Pointer 34 Program Counter 35 Condition Code Register 36 Arithmetic/Logic Unit (ALU) 37 | | 3.4 | Antimetic/Logic Offit (ALO) | | | Section 4. Interrupts | | 4.1 | Contents | | 4.2 | Introduction | | 4.3<br>4.3.1<br>4.3.2<br>4.3.2<br>4.3.2<br>4.3.3<br>4.3.3 | .2 PA3-PA0 Pins .43 .3 IRQ Status and Control Register .45 Timer Interrupts .46 .1 Timer Overflow Interrupt .46 .2 Real-Time Interrupt .46 | | 4.4 | Interrupt Processing | | | Section 5. Resets | | 5.1 | Contents | | 5.2 | Introduction51 | | | MC68HC705K1 — Rev. 2.0 | | 5.3 | Reset Types | |--------------|-------------------------------------------| | 5.3.1 | Power-On Reset52 | | 5.3.2 | External Reset | | 5.3.3 | Computer Operating Properly (COP) Reset54 | | 5.3.4 | Illegal Address Reset | | 5.3.5 | Low-Voltage Reset | | 5.4 | Reset States | | 5.4.1 | CPU | | 5.4.2 | I/O Port Registers | | 5.4.3 | Multifunction Timer | | 5.4.4 | COP Watchdog56 | | | Section 6. Low-Power Modes | | 6.1 | Contents | | 6.2 | Introduction57 | | 6.3 | Stop Mode | | 6.4 | Wait Mode58 | | 6.5 | Halt Mode | | 6.6 | Data-Retention Mode | | | Section 7. Parallel Input/Output (I/O) | | 7.1 | Contents | | 7.2 | Introduction | | 7.3 | I/O Port Function | | 7.4 | | | 7.4<br>7.4.1 | Port A | | 7.4.1 | Data Direction Register A | | 7.4.3 | Pulldown Register A | | 7.4.4 | Port A External Interrupts | | 745 | Port A Logic | MC68HC705K1 — Rev. 2.0 **Technical Data** | 7.5 | Port B | | |------------------|----------------------------------------|----| | 7.5.1 | Port B Data Register | | | 7.5.2<br>7.5.3 | Data Direction Register B | | | 7.5.4 | Port B Logic | | | | Section 8. Multifunction Timer | | | 8.1 | Contents | 5 | | 8.2 | Introduction | 5 | | 8.3 | Timer Status and Control Register | 7 | | 8.4 | Timer Counter Register | 9 | | 8.5 | COP Watchdog8 | 0 | | | Section 9. EPROM/OTPROM | | | 9.1 | Contents | 3 | | 9.2 | Introduction | 3 | | 9.3 | EPROM Programming Register | 4 | | 9.4 | EPROM/OTPROM Programming | 5 | | 9.5 | EPROM Erasing | 7 | | 9.6 | Mask Option Register | 7 | | | Section 10. Personality EPROM (PEPROM) | | | 10.1 | Contents | 1 | | 10.2 | Introduction9 | 1 | | 10.3 | PEPROM Registers | | | 10.3.1<br>10.3.2 | <b>9</b> | | | 10.4 | PEPROM Programming | 6 | | 10.5 | PEPROM Reading | 6 | | 10.6 | PEPROM Erasing9 | 7 | | | MC68HC705K1 — Rev. 2. | .0 | | | | | Freescale Semiconductor, Inc. ### **Section 11. Instruction Set** | 11.1 | Contents | |------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 11.2 | Introduction | | 11.3<br>11.3.1<br>11.3.2<br>11.3.3<br>11.3.5<br>11.3.6<br>11.3.7 | 2. Immediate. .101 3. Direct .101 4. Extended .101 5. Indexed, No Offset .102 6. Indexed, 8-Bit Offset .102 7. Indexed, 16-Bit Offset .102 | | 11.4<br>11.4.1<br>11.4.2<br>11.4.3<br>11.4.4 | Read-Modify-Write Instructions | | 11.5 | Instruction Set Summary | | 11.6 | Opcode Map | | | Section 12. Electrical Specifications | | 12.1 | Contents | | 12.2 | Introduction | | 12.3 | Maximum Ratings118 | | 12.4 | Operating Temperature Range118 | | 12.5 | Thermal Characteristics | | 12.6 | Power Considerations | | 12.7 | Equivalent Pin Loading120 | | 12.8 | 5.0-Volt DC Electrical Characteristics121 | MC68HC705K1 — Rev. 2.0 ## **Table of Contents** | | | | ı | |-----|---------|----|----| | | | _ | | | | 1 | ø | ч | | | ١ | ь | d | | | | Ξ | = | | | ( | P | | | | ì | ь | - | | | ı | - | | | | | | | | | | | | | | | | | | | | | н | | | ÷ | | - | | | ì | | - | | | ľ | Ξ | Ξ | | | 1 | ρ | ۹ | | | ı | ь | d | | | | 4 | | | | | ь | d | | | 7 | - | - | | | 4 | ď | h | | | ( | Ľ | .1 | | | ٦ | | | | | į | | | | | | _ | | | | I | | | | - 1 | Ú | į. | | | | 7 | r | 7 | | | ٩ | | | | | 4 | ã | i | | | ( | r | - | | | Ì | | | | | | _ | _ | | | ( | P | 9 | | | ١ | ь | d | | | | 7 | 7 | | | | | | | | | и | ч | | | ( | Ľ | 3 | | | ٩ | Ġ | J | | ı | ٩ | | 1 | | | Ì | | | | | ٩ | | | | | 1 | | | | | 1 | | | | ۰ | 1 | | | | | ( ( ( ) | | | | | 1 | | | | | 1001 | | | | | 1001 | | | | | ( ( ( ) | | | | | 1001 | | | | | 1001 | | | | | 1001 | | | | | 1001 | | | | | 1001 | | | | | 1001 | | | | | 1001 | | | | | 1001 | | | | | 1001 | | | | | 1001 | | | | | 1001 | | | | | 1001 | | | | | 1001 | | | | | 1001 | | | | | 1001 | | | | | 1001 | | | | | 1001 | | | | | 1001 | | | | | 1001 | | | | | 1001 | | | | | 1001 | | | | | 1001 | | | | | | | | | | | 2 | | | | | 2 | | | 12.9 | 3.3-Volt DC Electrical Characteristics122 | |-------|---------------------------------------------| | 12.10 | 5.0-Volt Control Timing126 | | 12.11 | 3.3-Volt Control Timing127 | | 12.12 | Typical Oscillator Characteristics | | | Section 13. Mechanical Specifications | | 13.1 | Contents | | 13.2 | Introduction | | 13.3 | Plastic Dual In-Line Package (Case 648)134 | | 13.4 | Small Outline Integrated Circuit (Case 751) | | 13.5 | Ceramic Dual In-Line Package (Case 620)135 | | | Section 13. Ordering Information | | 13.1 | Contents | | 13.2 | Introduction | | 13.3 | MCU Order Numbers | Technical Data — MC68HC705K1 # **List of Figures** | Figure | Title | Page | |------------------------|----------------------------------------|----------------| | 1-1 | MC68HC705K1 Block Diagram | | | 1-2 | Pin Assignments | 19 | | 1-3 | Bypassing Layout Recommendation | 19 | | 1-4 | Crystal Connections | | | 1-5 | 2-Pin Ceramic Resonator Connections | | | 1-6 | 3-Pin Ceramic Resonator Connections | | | 1-7 | 2-Pin RC Oscillator Connections | | | 1-8 | 3-Pin RC Oscillator Connections | | | 1-9 | External Clock Connections | | | 2-1 | Memory Map | | | 2-2 | I/O Register Summary | 28 | | 3-1 | Programming Model | 32 | | 3-2 | Accumulator (A) | | | 3-3 | Index Register (X) | | | 3-4 | Stack Pointer (SP) | | | 3-5 | Program Counter (PC) | | | 3-6 | Condition Code Register (CCR) | 36 | | 4-1 | External Interrupt Logic | 42 | | 4-2 | IRQ Status and Control Register (ISCR) | | | 4-3 | Interrupt Stacking Order | | | 4-4 | Interrupt Flowchart | 49 | | 5-1 | Reset Sources | 53 | | 5-2 | COP Register (COPR) | | | 6-1 | Stop/Wait/Halt Flowchart | 60 | | MC68HC705K1 — Rev. 2.0 | | Technical Data | **Technical Data** ## List of Figures | Figure | Title | Page | |--------|----------------------------------------------------------------------|----------| | 7-1 | Port A Data Register (PORTA) | 64 | | 7-2 | Data Direction Register A (DDRA) | 65 | | 7-3 | Pulldown Register A (PDRA) | 66 | | 7-4 | Port A I/O Circuit | | | 7-5 | Port B Data Register (PORTB) | 69 | | 7-6 | Data Direction Register B (DDRB) | 70 | | 7-7 | Pulldown Register B (PDRB) | 71 | | 7-8 | Port B I/O Circuit | 72 | | 8-1 | Multifunction Timer Block Diagram | 76 | | 8-2 | Timer Status and Control Register (TSCR) | 77 | | 8-3 | Timer Counter Register (TCNTR) | 79 | | 8-4 | COP Register (COPR) | 80 | | 9-1 | EPROM Programming Register (EPROG) | 84 | | 9-2 | Programming Circuit | 86 | | 9-3 | Mask Option Register (MOR) | 87 | | 10-1 | Personality EPROM | 92 | | 10-2 | PEPROM Bit Select Register (PEBSR) | 93 | | 10-3 | PEPROM Status and Control Register (PESCR) | 95 | | 12-1 | Equivalent Test Load | 120 | | 12-2 | Typical High-Side Driver Characteristics | 123 | | 12-3 | Typical Low-Side Driver Characteristics | 123 | | 12-4 | Run I <sub>DD</sub> versus Internal Clock Frequency | 124 | | 12-5 | Wait I <sub>DD</sub> versus Internal Clock Frequency | | | 12-6 | Stop I <sub>DD</sub> versus Temperature | | | 12-7 | External Interrupt Timing | | | 12-8 | Stop Mode Recovery Timing | | | 12-9 | Power-On Reset Timing | | | 12-10 | External Reset Timing | | | 12-11 | 2-Pin RC Oscillator R versus Frequency ( $V_{DD} = 5.0 \text{ V}$ ). | | | 12-12 | 3-Pin RC Oscillator R versus Frequency (V <sub>DD</sub> = 5.0 V) | | | 12-13 | 2-Pin Oscillator R versus Frequency (V <sub>DD</sub> = 3.0 V) | | | 12-14 | 3-Pin Oscillator R versus Frequency (V <sub>DD</sub> = 3.0 V) | 132 | | | MC68HC705K1 — F | Rev. 2.0 | ### Technical Data — MC68HC705K1 ## **List of Tables** | Table | Title | Page | |------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------| | 4-1 | Reset/Interrupt Vector Addresses | 48 | | 7-1<br>7-2<br>7-3 | Port A Pin Functions | 73 | | 8-1<br>8-2 | Real-Time Interrupt Rate Selection | | | 10-1 | PEPROM Bit Selection | 94 | | 11-1<br>11-2<br>11-3<br>11-4<br>11-5<br>11-6<br>11-7 | Register/Memory Instructions Read-Modify-Write Instructions Jump and Branch Instructions Bit Manipulation Instructions. Control Instructions. Instruction Set Summary Opcode Map. | 105107108109 | | 13-1 | MC68HC705K1 Order Numbers | 137 | MC68HC705K1 — Rev. 2.0 Technical Data List of Tables ### Technical Data — MC68HC705K1 ## **Section 1. General Description** #### 1.1 Contents | 1.2 Ir | ntroduction15 | |---------|----------------------------------------| | 1.3 F | eatures | | 1.4 N | lask Options | | 1.5 N | ICU Structure17 | | 1.6 P | in Assignments19 | | 1.6.1 | V <sub>DD</sub> and V <sub>SS</sub> 19 | | 1.6.2 | OSC1 and OSC2 | | 1.6.2.1 | Crystal | | 1.6.2.2 | Ceramic Resonator | | 1.6.2.3 | 2-Pin RC Oscillator | | 1.6.2.4 | 3-Pin RC Oscillator | | 1.6.2.5 | External Clock | | 1.6.3 | RESET | | 1.6.4 | ĪRQ/V <sub>PP</sub> | | 1.6.5 | PA7–PA0 | | 1.6.6 | PB1/OSC3 and PB024 | | | PB1/OSC3 and PB0 | #### 1.2 Introduction The MC68HC705K1 is a member of the low-cost, high-performance M68HC05 Family of 8-bit microcontroller units (MCU). The M68HC05 Family is based on the customer-specified integrated circuit (CSIC) design strategy. All MCUs in the family use the popular M68HC05 central processor unit (CPU) and are available with a variety of subsystems, memory sizes and types, and package types. MC68HC705K1 — Rev. 2.0 ### **General Description** On-chip memory of the MC68HC705K1 includes 504 bytes of erasable, programmable read-only memory (EPROM). In packages without the transparent window for EPROM erasure, the 504 EPROM bytes serve as one-time programmable read-only memory (OTPROM). #### 1.3 Features #### Features of the MCU include: - Popular M68HC05 CPU - Memory-mapped input/output (I/O) registers - 504 bytes of EPROM/OTPROM, including eight user vector locations - 32 bytes of user random-access memory (RAM) - 64-bit personality EPROM - 10 bidirectional I/O pins with these features: - Software programmable pulldown devices - Four I/O pins with 8-mA current sinking capability - Four I/O pins with maskable external interrupt capability - Hardware mask and flag for external interrupts - Fully static operation with no minimum clock speed - On-chip oscillator with connections for: - Crystal or ceramic resonator - Mask-optional 2-pin or 3-pin resistor-capacitor (RC) oscillator - Computer operating properly (COP) watchdog - 15-bit multifunction timer with real-time interrupt circuit - Power-saving stop, wait, halt, and data-retention modes - 8 × 8 unsigned multiply instruction - Illegal address reset - Low-voltage reset **General Description** Mask Options - 16-pin plastic dual in-line package (PDIP) - 16-pin small outline integrated circuit package (SOIC) - 16-pin ceramic DIP (cerdip) ### 1.4 Mask Options These MC68HC705K1 options are programmable in the mask option register (MOR): - Enabled or disabled COP watchdog - Edge-triggered or edge- and level-triggered external interrupt pins - Enabled or disabled port A external interrupt function - Enabled or disabled low-voltage reset function - Enabled or disabled STOP instruction - Oscillator driven by crystal or ceramic resonator or oscillator driven by RC circuit - 2-pin RC-driven oscillator or 3-pin RC-driven oscillator - Enabled or disabled port A and port B programmable pulldown devices The mask option register is an EPROM/OTPROM byte at location \$0017. Section 9. EPROM/OTPROM describes the mask option register and the EPROM/OTPROM programming procedure. #### 1.5 MCU Structure Figure 1-1 shows the structure of the MC68HC705K1 MCU. ### **General Description** Figure 1-1. MC68HC705K1 Block Diagram ### 1.6 Pin Assignments Figure 1-2 shows the MC68HC705K1 pin assignments. Figure 1-2. Pin Assignments ### 1.6.1 $V_{DD}$ and $V_{SS}$ $V_{DD}$ and $V_{SS}$ are the power supply and ground pins. The MCU operates from a single 5-volt power supply. Very fast signal transitions occur on the MCU pins, placing high short-duration current demands on the power supply. To prevent noise problems, take special care to provide good power supply bypassing at the MCU. Place bypass capacitors as close to the MCU as possible, as **Figure 1-3** shows. Figure 1-3. Bypassing Layout Recommendation MC68HC705K1 — Rev. 2.0 Technical Data ### **General Description** #### 1.6.2 OSC1 and OSC2 The OSC1, OSC2, and PB1/OSC3 pins are the control connections for the 2-pin or 3-pin on-chip oscillator. The oscillator can be driven by any of these: - Crystal - · Ceramic resonator - Resistor-capacitor network - External clock signal The frequency of the internal oscillator is f<sub>OSC</sub>. The MCU divides the internal oscillator output by two to produce the internal clock with a frequency of f<sub>OP</sub>. #### 1.6.2.1 Crystal The circuit in **Figure 1-4** shows a typical crystal oscillator circuit for an AT-cut, parallel resonant crystal. Follow the crystal supplier's recommendations, as the crystal parameters determine the external component values required to provide reliable start-up and maximum stability. The load capacitance values used in the oscillator circuit design should include all stray layout capacitances. To minimize output distortion, mount the crystal and capacitors as close as possible to the pins. Figure 1-4. Crystal Connections General Description Pin Assignments **NOTE:** Use an AT-cut crystal and not a strip or tuning fork crystal. The MCU may overdrive or have the wrong characteristic impedance for a strip or tuning fork crystal. To use the crystal-driven oscillator, the RC and PIN3 bits in the mask option register must be clear. See **9.6 Mask Option Register**. Clearing the RC bit connects an internal 2-M $\Omega$ startup resistor between OSC1 and OSC2. #### 1.6.2.2 Ceramic Resonator To reduce cost, use a ceramic resonator in place of the crystal. Use the circuit in **Figure 1-5** for a 2-pin ceramic resonator or **Figure 1-6** for a 3-pin ceramic resonator, and follow the resonator manufacturer's recommendations. The resonator parameters determine the external component values required for maximum stability and reliable starting. The load capacitance values used in the oscillator circuit design should include all stray layout capacitances. To minimize output distortion, mount the resonator and capacitors as close as possible to the pins. Figure 1-5. 2-Pin Ceramic Resonator Connections MC68HC705K1 — Rev. 2.0 ### **General Description** Figure 1-6. 3-Pin Ceramic Resonator Connections To use the resonator-driven oscillator, the RC bit in the mask option register must be clear. See **9.6 Mask Option Register**. Clearing the RC bit connects an internal 2-M $\Omega$ startup resistor between OSC1 and OSC2. #### 1.6.2.3 2-Pin RC Oscillator For maximum cost reduction, use the 2-pin RC oscillator configuration shown in **Figure 1-7**. The OSC2 signal is a square wave, and the signal on OSC1 is a triangular wave. The optimum frequency for the 2-pin oscillator configuration is 2 MHz. Figure 1-7. 2-Pin RC Oscillator Connections To use the 2-pin RC oscillator configuration, the RC bit in the mask option register must be programmed to a logic 1. Setting the RC bit General Description Pin Assignments disconnects the internal startup resistor. The PIN3 bit in the mask option register must remain erased (logic 0). The PIN3 bit selects the 3-pin RC oscillator configuration. See **9.6 Mask Option Register**. #### 1.6.2.4 3-Pin RC Oscillator Another low-cost option is the 3-pin RC oscillator configuration shown in **Figure 1-8**. The 3-pin oscillator is more stable than the 2-pin oscillator. The OSC2 and PB1/OSC3 signals are square waves, and the signal on OSC1 is a triangular wave. The 3-pin RC oscillator configuration is recommended for frequencies of 1 MHz and less. Figure 1-8. 3-Pin RC Oscillator Connections To use the 3-pin RC oscillator configuration, both the RC and PIN3 bits in the mask option register must be programmed to logic 1s. See **9.6 Mask Option Register**. #### **NOTE:** In 3-pin RC oscillator configurations, the personality EPROM (PEPROM) cannot be programmed by user software. If the voltage on $\overline{IRQ}/V_{PP}$ is raised above $V_{DD}$ , the oscillator will revert to a 2-pin oscillator configuration and device operation will be disrupted. #### 1.6.2.5 External Clock An external clock from another CMOS-compatible device can drive the OSC1 input, with the OSC2 pin unconnected, as **Figure 1-9** shows. MC68HC705K1 — Rev. 2.0 ### **General Description** Figure 1-9. External Clock Connections #### 1.6.3 **RESET** A logic 0 on the RESET pin forces the MCU to a known startup state. See **5.3.2 External Reset** for more information. ### 1.6.4 **IRQ/V**<sub>PP</sub> The $\overline{IRQ}/V_{PP}$ pin has these functions: - Applying asynchronous external interrupt signals, see 4.3.2 External Interrupts - Applying the EPROM/OTPROM programming voltage, see 9.4 EPROM/OTPROM Programming #### 1.6.5 PA7-PA0 PA7–PA0 are the pins of port A, a general-purpose, bidirectional I/O port. See **7.4 Port A**. #### 1.6.6 PB1/OSC3 and PB0 PB1/OSC3 and PB0 are the pins of port B, a general-purpose, bidirectional I/O port. See **7.5 Port B**. #### Technical Data — MC68HC705K1 ## Section 2. Memory #### 2.1 Contents | 2.2 | Introduction | |-----|------------------------------| | 2.3 | Memory Map | | 2.4 | Input/Output Section | | 2.5 | Random-Access Memory (RAM)26 | | 2.6 | EPROM/OTPROM | | 2.7 | Personality EPROM/OTPROM30 | #### 2.2 Introduction This section describes the organization of the on-chip memory. ### 2.3 Memory Map The central processor unit (CPU) can address 1 Kbyte of memory space. The program counter typically advances one address at a time through the memory, reading the program instructions and data. The erasable, programmable read-only memory (EPROM) portion of memory holds the program instructions, fixed data, user-defined vectors, and interrupt service routines. The random-access memory (RAM) portion of memory holds variable data. Input/output (I/O) registers are memory-mapped so that the CPU can access their locations in the same way that it accesses all other memory locations. **Figure 2-1** is a memory map of the microcontroller unit (MCU). Refer to **Figure 2-2** for a more detailed memory map of the 32-byte I/O register section. MC68HC705K1 — Rev. 2.0 ### **Memory** ### 2.4 Input/Output Section The first 32 addresses of the memory space, \$0001–\$001F, are the I/O section. These are the addresses of the I/O control registers, status registers, and data registers. See **Figure 2-2**. ### 2.5 Random-Access Memory (RAM) The 32 addresses from \$00E0 to \$00FF serve as both the user RAM and the stack RAM. The CPU uses five RAM bytes to save all CPU register contents before processing an interrupt. During a subroutine call, the CPU uses two bytes to store the return address. The stack pointer decrements during pushes and increments during pulls. **NOTE:** Be careful when using nested subroutines or multiple interrupt levels. The CPU may overwrite data in the RAM during a subroutine or during the interrupt stacking operation. Memory Random-Access Memory (RAM) <sup>\*</sup>Writing to bit 0 of \$03F0 clears the COP watchdog. Reading \$03F0 returns ROM data. Figure 2-1. Memory Map MC68HC705K1 — Rev. 2.0 Technical Data **Memory** ### Freescale Semiconductor, Inc. #### Addr. **Register Name** Bit 7 6 5 4 3 2 1 Bit 0 Read: Port A Data Register PA7 PA6 PA5 PA4 PA3 PA2 PA1 PA0 \$0000 (PORTA) Write: See page 64. Reset: Unaffected by reset 0 0 0 0 0 0 Read: PB1/ Port B Data Register PB0 OSC3 \$0001 (PORTB) Write: See page 69. Reset: Unaffected by reset \$0002 Unimplemented \$0003 Unimplemented Read: Data Direction Register A DDRA7 DDRA6 DDRA5 DDRA4 DDRA3 DDRA2 DDRA1 DDRA0 \$0004 (DDRA) Write: See page 65. Reset: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 Read: Data Direction Register B DDRB1 DDRB0 \$0005 (DDRB) Write: See page 70. Reset: 0 0 0 0 0 0 0 0 \$0006 Unimplemented \$0007 Unimplemented **TOF RTIF** Read: **Timer Status and Control TOIE RTIE** RT0 RT1 **RTIFR** \$0008 Register (TSCR) Write: **TOFR** See page 77. 0 U U Reset: 0 0 0 1 1 Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0 Read: **Timer Counter Register** \$0009 (TCNTR) Write: See page 79. 0 0 0 Reset: 0 0 0 0 0 **IRQF** Read: IRQ Status and Control **IRQE** 0 0 0 0 0 \$000A Register (ISCR) Write: **IRQR** See page 45. Figure 2-2. I/O Register Summary (Sheet 1 of 3) = Unimplemented 0 R 0 = Reserved U U = Unaffected 0 Reset: Memory Random-Access Memory (RAM) Figure 2-2. I/O Register Summary (Sheet 2 of 3) MC68HC705K1 — Rev. 2.0 Figure 2-2. I/O Register Summary (Sheet 3 of 3) ### 2.6 EPROM/OTPROM An MCU with a quartz window has 504 bytes of erasable, programmable ROM (EPROM). The quartz window allows EPROM erasure with ultraviolet light. In an MCU without the quartz window, the EPROM cannot be erased and serves as 504 bytes of one-time programmable ROM (OTPROM). Addresses \$0020-\$03EF contain 496 bytes of user EPROM/OTPROM. The eight addresses from \$03F8 to \$03FF are EPROM/OTPROM locations reserved for interrupt vectors and reset vectors. ### 2.7 Personality EPROM/OTPROM An MCU with a quartz window has a 64-bit array of erasable, programmable ROM (EPROM) to serve as a personality EPROM. The quartz window allows EPROM erasure with ultraviolet light. In an MCU without the quartz window, the personality EPROM cannot be erased and serves as a 64-bit array of OTPROM. Technical Data — MC68HC705K1 ## **Section 3. Central Processor Unit (CPU)** Freescale Semiconductor, Inc. #### 3.1 Contents | 3.2 | Introduction31 | |-------|-----------------------------| | 3.3 | CPU Registers | | 3.3.1 | Accumulator | | 3.3.2 | Index Register | | 3.3.3 | Stack Pointer34 | | 3.3.4 | Program Counter | | 3.3.5 | Condition Code Register | | 3.4 | Arithmetic/Logic Unit (ALU) | ### 3.2 Introduction This section describes the central processor unit (CPU) registers. MC68HC705K1 — Rev. 2.0 ### **Central Processor Unit (CPU)** ### 3.3 CPU Registers **Figure 3-1** shows the five CPU registers. CPU registers and are not part of the memory map. Figure 3-1. Programming Model Central Processor Unit (CPU) CPU Registers #### 3.3.1 Accumulator The accumulator (A) shown in **Figure 3-2** is a general-purpose 8-bit register. The CPU uses the accumulator to hold operands and results of arithmetic and non-arithmetic operations. Figure 3-2. Accumulator (A) ### 3.3.2 Index Register In the indexed addressing modes, the CPU uses the byte in the index register (X) shown in **Figure 3-3** to determine the conditional address of the operand. See **11.3.5 Indexed**, **No Offset**, **11.3.6 Indexed**, **8-Bit Offset**, and **11.3.7 Indexed**, **16-Bit Offset** for more information on indexed addressing. The 8-bit index register also can serve as a temporary data storage location. Figure 3-3. Index Register (X) MC68HC705K1 — Rev. 2.0 Technical Data ### **Central Processor Unit (CPU)** #### 3.3.3 Stack Pointer The stack pointer (SP) shown in **Figure 3-4** is a 16-bit register that contains the address of the next free location on the stack. During a reset or after the reset stack pointer (RSP) instruction, the stack pointer initializes to \$00FF. The address in the stack pointer decrements as data is pushed onto the stack and increments as data is pulled from the stack. The 11 most significant bits of the stack pointer are fixed permanently at 00000000111, so the stack pointer produces addresses from \$00E0 to \$00FF. If subroutines and interrupts use more than 32 stack locations, the stack pointer wraps around to address \$00FF and begins writing over the previously stored data. A subroutine uses two stack locations. An interrupt uses five locations. Figure 3-4. Stack Pointer (SP) Central Processor Unit (CPU) CPU Registers ### 3.3.4 Program Counter The program counter (PC) shown in **Figure 3-5** is a 16-bit register that contains the address of the next instruction or operand to be fetched. The six most significant bits of the program counter are ignored internally and appear as 000000. Normally, the address in the program counter automatically increments to the next sequential memory location every time an instruction or operand is fetched. Jump, branch, and interrupt operations load the program counter with an address other than that of the next sequential location. Figure 3-5. Program Counter (PC) ### Central Processor Unit (CPU) ### 3.3.5 Condition Code Register The condition code register (CCR) shown in **Figure 3-6** is an 8-bit register whose three most significant bits are permanently fixed at 111. The condition code register contains the interrupt mask and four flags that indicate the results of prior instructions. Figure 3-6. Condition Code Register (CCR) #### H — Half-Carry Flag The CPU sets the half-carry flag when a carry occurs between bits 3 and 4 of the accumulator during an add without carry (ADD) or add with carry (ADC) operation. The half-carry bit is required for binary-coded decimal (BCD) arithmetic operations. Reset has no affect on the half-carry flag. #### I — Interrupt Mask Flag Setting the interrupt mask (I) disables interrupts. If an interrupt request occurs while the interrupt mask is a logic 0, the CPU saves the CPU registers on the stack, sets the interrupt mask, and then fetches the interrupt vector. If an interrupt request occurs while the interrupt mask is set, the interrupt request is latched. The CPU processes the latched interrupt as soon as the interrupt mask is cleared again. A return-from-interrupt (RTI) instruction pulls the CPU registers from the stack, restoring the interrupt mask to its cleared state. After a reset, the interrupt mask is set and can be cleared only by a clear interrupt mask bit (CLI), STOP, or WAIT instruction. ## Freescale Semiconductor, Inc. Central Processor Unit (CPU) Arithmetic/Logic Unit (ALU) #### N — Negative Flag The CPU sets the negative flag when an arithmetic operation, logical operation, or data manipulation produces a negative result (bit 7 in the results is a logic 1). Reset has no effect on the negative flag. #### Z — Zero Flag The CPU sets the zero flag when an arithmetic operation, logical operation, or data manipulation produces a result of \$00. Reset has no effect on the zero flag. #### C — Carry/Borrow Flag The CPU sets the carry/borrow flag when an addition operation produces a carry out of bit 7 of the accumulator or when a subtraction operation requires a borrow. Some logical operations and data manipulation instructions also clear or set the carry/borrow bit. Reset has no effect on the carry/borrow flag. # 3.4 Arithmetic/Logic Unit (ALU) The arithmetic/logic unit (ALU) performs the arithmetic and logical operations defined by the instruction set. The binary arithmetic circuits decode instructions and set up the ALU for the selected operation. Most binary arithmetic is based on the addition algorithm, carrying out subtraction as negative addition. Multiplication is not performed as a discrete operation but as a chain of addition and shift operations within the ALU. The multiply instruction requires 11 internal clock cycles to complete this chain of operations. **Central Processor Unit (CPU)** # Technical Data — MC68HC705K1 # **Section 4. Interrupts** #### 4.1 Contents | 4.2 | Introduction39 | |---------|---------------------------------| | 4.3 | Interrupt Types | | 4.3.1 | Software Interrupt40 | | 4.3.2 | External Interrupts40 | | 4.3.2.1 | IRQ/V <sub>PP</sub> Pin | | 4.3.2.2 | PA3–PA0 Pins | | 4.3.2.3 | IRQ Status and Control Register | | 4.3.3 | Timer Interrupts | | 4.3.3.1 | Timer Overflow Interrupt46 | | 4.3.3.2 | Real-Time Interrupt | | 4.4 | Interrupt Processing | ### 4.2 Introduction This section describes how interrupts temporarily change the normal processing sequence. MC68HC705K1 — Rev. 2.0 ### Interrupts # 4.3 Interrupt Types These conditions generate interrupts: - SWI instruction (software interrupt) - A logic 0 applied to the IRQ/V<sub>PP</sub> pin (external interrupt) - A logic 1 applied to one of the PA3–PA0 pins when port A external interrupts are enabled (external interrupt) - A timer overflow (timer interrupt) - Expiration of the real-time interrupt period (timer interrupt) An interrupt temporarily stops normal program execution to process a particular event. An interrupt does not stop the execution of the instruction in progress, but takes effect when the current instruction completes its execution. Interrupt processing automatically saves the central processor unit (CPU) registers on the stack and loads the program counter with a user-defined vector address. ### 4.3.1 Software Interrupt The software interrupt (SWI) instruction causes a non-maskable interrupt. #### 4.3.2 External Interrupts These sources can generate external interrupts: - ĪRQ/V<sub>PP</sub> pin - PA3–PA0 pins when port A external interrupts are enabled Setting the I bit in the condition code register or clearing the IRQE bit in the interrupt status and control register disables external interrupts. Interrupts Interrupt Types # $4.3.2.1 \overline{IRQ}/V_{PP} Pin$ An interrupt signal on the IRQ/V<sub>PP</sub> pin latches an external interrupt request. After completing the current instruction, the CPU tests these bits: - IRQ latch - IRQE bit in the interrupt status and control register - I bit in the condition code register If both the IRQ latch and the IRQE bit are set, and the I bit is clear, the CPU then begins the interrupt sequence. The CPU clears the IRQ latch while it fetches the interrupt vector, so that another external interrupt request can be latched during the interrupt service routine. As soon as the I bit is cleared during the return from interrupt, the CPU can recognize the new interrupt request. **Figure 4-1** shows the logic for external interrupts. The IRQ/V<sub>PP</sub> pin is negative edge-triggered only or negative edge- and low-level-triggered, depending on the state of the LEVEL bit in the mask option register (MOR). See **9.6 Mask Option Register**. Programming the LEVEL bit to a logic 1 selects the edge- and level-sensitive trigger option. When LEVEL = 1: - A falling edge or a low level on the IRQ/V<sub>PP</sub> pin latches an external interrupt request. - As long as the IRQ/V<sub>PP</sub> is low, an external interrupt request is present, and the CPU continues to execute the interrupt service routine. The edge- and level-sensitive trigger option allows connection to the IRQ/V<sub>PP</sub> pin of multiple wired-OR interrupt sources. Programming the LEVEL bit to a logic 0 selects the edge-sensitive-only trigger option. When LEVEL = 0: - A falling edge on the IRQ/V<sub>PP</sub> pin latches an external interrupt request. - A subsequent interrupt request can be latched only after the voltage level on the IRQ/V<sub>PP</sub> pin returns to logic 1 and then falls again to logic 0. **NOTE:** If the $\overline{IRQ}/V_{PP}$ pin is not in use, connect it to the $V_{DD}$ pin. Figure 4-1. External Interrupt Logic Interrupts Interrupt Types #### 4.3.2.2 PA3-PA0 Pins Programming the PIRQ bit in the mask option register to a logic 1 enables pins PA3–PA0 to serve as additional external interrupt sources. See **9.6 Mask Option Register**. An interrupt signal on a PA3–PA0 pin latches an external interrupt request. After completing the current instruction, the CPU tests these bits: - IRQ latch - IRQE bit in the IRQ status and control register - I bit in the condition code register. If both the IRQ latch and the IRQE bit are set, and the I bit is clear, the CPU then begins the interrupt sequence. The CPU clears the IRQ latch while it fetches the interrupt vector, so that another external interrupt request can be latched during the interrupt service routine. As soon as the I bit is cleared during the return from interrupt, the CPU can recognize the new interrupt request. The PA3–PA0 pins are edge-triggered only or both edge- and level-triggered, depending on the state of the LEVEL bit in the MOR. Programming the LEVEL bit to a logic 1 selects the edge- and level-sensitive trigger option. When LEVEL = 1: - A rising edge or a high level on a PA3–PA0 pin latches an external interrupt request if and only if all other PA3–PA0 pins are low and the IRQ/V<sub>PP</sub> pin is high. - A falling edge or a low level on the IRQ/V<sub>PP</sub> pin latches an external interrupt request if and only if all of the PA3–PA0 pins are low. - As long as any PA3-PA0 pin is high or the IRQ/V<sub>PP</sub> pin is low, an external interrupt request is present, and the CPU continues to execute the interrupt service routine. # Interrupts Programming the LEVEL bit to a logic 0 selects the edge-sensitive only trigger option. When LEVEL = 0: - A rising edge on a PA3–PA0 pin latches an external interrupt request if and only if all other PA3–PA0 pins are low and the IRQ/V<sub>PP</sub> pin is high. - A falling edge on the IRQ/V<sub>PP</sub> pin latches an external interrupt request if and only if all of the PA3–PA0 pins are low. - A subsequent PA3–PA0 pin interrupt request can be latched only after the voltage level of the previous PA3–PA0 interrupt signal returns to a logic 0 and then rises again to a logic 1. - A subsequent IRQ/V<sub>PP</sub> pin interrupt request can be latched only after the voltage level of the previous IRQ/V<sub>PP</sub> interrupt signal returns to a logic 1 and then falls again to a logic 0. Interrupts Interrupt Types #### 4.3.2.3 IRQ Status and Control Register The IRQ status and control register (ISCR) contains an external interrupt mask, an external interrupt flag, and a flag reset bit. Unused bits read as logic 0s. Figure 4-2. IRQ Status and Control Register (ISCR) #### IRQE — External Interrupt Request Enable Bit This read/write bit enables external interrupts. Reset sets the IRQE bit. - 1 = External interrupt processing enabled - 0 = External interrupt processing disabled #### IRQF — External Interrupt Request Flag The IRQF bit is a clearable, read-only flag that is set when an external interrupt request is pending. Reset clears the IRQF bit. - 1 = Interrupt request pending - 0 = No interrupt request pending These conditions set the IRQF bit: - a. An external interrupt signal on the $\overline{IRQ}/V_{PP}$ pin - An external interrupt signal on pin PA3, PA2, PA1, or PA0 when PA3–PA0 are enabled to serve as external interrupt sources The CPU clears the IRQF bit when fetching the interrupt vector. Writing to the IRQF bit has no effect. Writing a logic 1 to the IRQR bit clears the IRQF bit. MC68HC705K1 — Rev. 2.0 ### Interrupts IRQR — Interrupt Request Reset Bit Writing a logic 1 to this write-only bit clears the IRQF bit. Writing a logic 0 to IRQR has no effect. Reset has no effect on IRQR. 1 = IRQF bit cleared 0 = No effect #### 4.3.3 Timer Interrupts The multifunction timer can generate these interrupts: - Timer overflow interrupt - Real-time interrupt Setting the I bit in the condition code register disables all timer interrupts. ### 4.3.3.1 Timer Overflow Interrupt A timer overflow interrupt request occurs if the timer overflow flag, TOF, becomes set while the timer overflow interrupt enable bit, TOIE, is also set. See **8.3 Timer Status and Control Register**. #### 4.3.3.2 Real-Time Interrupt A real-time interrupt request occurs if the real-time interrupt flag, RTIF, becomes set while the real-time interrupt enable bit, RTIE, is also set. See **8.3 Timer Status and Control Register**. # 4.4 Interrupt Processing The CPU does these things to begin servicing an interrupt: - Stores the CPU registers on the stack in the order shown in Figure 4-3 - Sets the I bit in the condition code register to prevent further interrupts - Loads the program counter with the contents of the appropriate interrupt vector locations: - \$03FC and \$03FD (software interrupt vector) - \$03FA and \$03FB (external interrupt vector) - \$03F8 and \$03F9 (timer interrupt vector) The return-from-interrupt (RTI) instruction causes the CPU to recover the CPU registers from the stack as shown in **Figure 4-3**. Figure 4-3. Interrupt Stacking Order MC68HC705K1 — Rev. 2.0 Technical Data ### Interrupts **Table 4-1** summarizes the reset and interrupt sources and vector assignments. Table 4-1. Reset/Interrupt Vector Addresses | Function | Source | Local<br>Mask | Global<br>Mask | MOR<br>Control<br>Bit | Priority<br>(1 = Highest) | Vector<br>Address | | |--------------------------|-------------------------|---------------|----------------|-----------------------|------------------------------|------------------------|--| | | Power-on logic | | None | None | | \$03FE-\$03FF | | | | RESET pin | | | None | | | | | Reset | COP watchdog | None | | COPEN <sup>(1)</sup> | 1 | | | | | Low voltage detect | | | LVIE <sup>(2)</sup> | | | | | | Illegal address logic | | | None | | | | | Software interrupt (SWI) | User code | None | None | None | Same priority as instruction | \$03FC-\$03FD | | | | ĪRQ/V <sub>PP</sub> pin | | I bit | None | | | | | | PA3 pin | | | PIRQ <sup>(3)</sup> | | | | | External interrupts | PA2 pin | IRQE bit | | PIRQ <sup>3</sup> | 2 | \$03FA-\$03FB | | | | PA1 pin | | | PIRQ <sup>3</sup> | | | | | | PA0 pin | | | PIRQ <sup>3</sup> | | | | | Timer | TOF bit | TOFE bit | l bit | None | 3 | \$03F8 <b>–</b> \$03F9 | | | interrupts | RTIF bit | RTIE bit | I DIL | None | 3 | | | - 1. COPEN enables the COP watchdog. - 2. LVIE enables low-voltage resets. - 3. PIRQ enables port A external interrupts. #### **NOTE:** If more than one interrupt request is pending, the CPU fetches the vector of the higher priority interrupt first. A higher priority interrupt does not interrupt a lower priority interrupt service routine unless the lower priority interrupt service routine clears the I bit. Interrupts Interrupt Processing Figure 4-4 shows the sequence of events caused by an interrupt. Figure 4-4. Interrupt Flowchart MC68HC705K1 — Rev. 2.0 Technical Data Interrupts # Freescale Semiconductor, Inc. ### Technical Data — MC68HC705K1 # Section 5. Resets #### 5.1 Contents | 5.3 | Reset Types | |-------|-------------------------------------------| | 5.3.1 | Power-On Reset52 | | 5.3.2 | External Reset | | 5.3.3 | Computer Operating Properly (COP) Reset54 | | 5.3.4 | Illegal Address Reset | | 5.3.5 | Low-Voltage Reset | | 5.4 | Reset States | | 5.4.1 | CPU | | 5.4.2 | I/O Port Registers56 | | 5.4.3 | Multifunction Timer56 | | 5.4.4 | COP Watchdog | ### 5.2 Introduction This section describes the five reset sources and how they initialize the microcontroller unit (MCU). MC68HC705K1 — Rev. 2.0 # 5.3 Reset Types A reset immediately stops the operation of the instruction being executed, initializes certain control bits, and loads the program counter with a user-defined reset vector address. These conditions produce a reset: - Initial power-up (power-on reset) - A logic 0 applied to the RESET pin (external reset) - Timeout of the computer operating properly (COP) watchdog (COP reset) - An opcode fetch from an address not in the memory map (illegal address reset) - V<sub>DD</sub> voltage below nominal 3.5 volts (low-voltage reset) #### 5.3.1 Power-On Reset A positive transition on the V<sub>DD</sub> pin generates a power-on reset. The power-on reset is strictly for power-up conditions and cannot be used to detect drops in power supply voltage. A 4064 $t_{CYC}$ (internal clock cycle) delay after the oscillator becomes active allows the clock generator to stabilize. If the $\overline{\text{RESET}}$ pin is at logic 0 at the end of 4064 $t_{CYC}$ , the MCU remains in the reset condition until the signal on the $\overline{\text{RESET}}$ pin goes to logic 1. #### 5.3.2 External Reset A logic 0 applied to the $\overline{\text{RESET}}$ pin for one and one-half $t_{\text{CYC}}$ generates an external reset. A Schmitt trigger senses the logic level at the $\overline{\text{RESET}}$ pin. A COP reset or an illegal address reset pulls the RESET pin low for one internal clock cycle. A low-voltage reset pulls the RESET pin low for as long as the low-voltage condition exists. Resets Reset Types Figure 5-1. Reset Sources **NOTE:** To avoid overloading some power supply designs, do not connect the $\overline{RESET}$ pin directly to $V_{DD}$ . Use a pullup resistor of 10 $k\Omega$ or more. #### 5.3.3 Computer Operating Properly (COP) Reset A timeout of the COP watchdog generates a COP reset. The COP watchdog is part of a software error detection system and must be cleared periodically to start a new timeout period. (See **8.5 COP Watchdog**.) To clear the COP watchdog and prevent a COP reset, write a logic 0 to bit 0 (COPC) of the COP register at location \$03F0. The COP register is a write-only register that returns the contents of a ROM location when read. Figure 5-2. COP Register (COPR) COPC — COP Clear Bit COPC is a write-only bit. Periodically writing a logic 0 to COPC prevents the COP watchdog from resetting the MCU. Writing a logic 1 has no effect. Reset clears the COPC bit. #### 5.3.4 Illegal Address Reset An opcode fetch from an address that is not in the erasable, programmable read-only memory (EPROM) (locations \$0200–\$03FF) or the random-access memory (RAM) (locations \$00E0–\$00FF) generates an illegal address reset. An illegal address reset pulls the RESET pin low for one cycle of the internal clock. Resets Reset States #### 5.3.5 Low-Voltage Reset The low-voltage reset circuit generates a reset signal if the voltage on the $V_{DD}$ pin falls below 3.5 V (nominal). $V_{DD}$ must be set at 5 V $\pm 10\%$ while the low-voltage reset circuit is enabled. Programming the LVRE bit to a logic 1 enables the low-voltage reset function. When erased, the LVRE bit in the mask option register disables the low-voltage reset circuit. See **9.6 Mask Option Register**. A low-voltage reset pulls the RESET pin low for as long as the low-voltage condition exists. The state of the low-voltage reset circuit is readable in the test register at location \$001F. Bit 1 of the test register is the low-voltage reset flag (LVRF). Regardless of the LVRE bit in the mask option register, the low-voltage reset circuit is active in all modes except stop mode. #### 5.4 Reset States This subsection describes how resets initialize the MCU. #### 5.4.1 CPU A reset has these effects on the central processor unit (CPU): - Loads the stack pointer with \$FF - Sets the I bit in the condition code register, inhibiting interrupts - Sets the IRQE bit in the interrupt status and control register - Loads the program counter with the user-defined reset vector from locations \$03FE and \$03FF - Clears the stop latch, enabling the CPU clock - Clears the wait latch, waking the CPU from the wait mode MC68HC705K1 — Rev. 2.0 #### 5.4.2 I/O Port Registers A reset has these effects on input/output (I/O) port registers: - Clears bits DDRA7–DDRA0 in data direction register A so that port A pins are inputs - Clears bits PDIA7–PDIA0 in pulldown register A so that port A pulldown devices are enabled (if the SWPDI bit in the mask option register is programmed to a logic 0) - Clears bits DDRB1 and DDRB0 in data direction register B so that port B pins are inputs (if the SWPDI bit in the mask option register is programmed to logic 0) - Clears bits PDIB1 and PDIB0 in pulldown register B so that port B pulldown devices are enabled - Has no effect on port A or port B data registers #### **5.4.3 Multifunction Timer** A reset has these effects on the multifunction timer: - Clears the timer status and control register - Clears the timer counter register #### 5.4.4 COP Watchdog A reset clears the COP watchdog timeout counter. # Freescale Semiconductor, Inc. #### Technical Data — MC68HC705K1 # Section 6. Low-Power Modes #### 6.1 Contents | 6.2 | Introduction57 | |-----|---------------------| | 6.3 | Stop Mode | | 6.4 | Wait Mode58 | | 6.5 | Halt Mode | | 6.6 | Data-Retention Mode | #### 6.2 Introduction This section describes the four low-power modes: - Stop mode - · Wait mode - Halt mode - Data-retention mode # 6.3 Stop Mode If the SWAIT bit in the mask option register (MOR) is programmed to a logic 0, the STOP instruction puts the microcontroller unit (MCU) in its lowest power-consumption mode and has these effects on the MCU: - Clears TOF and RTIF, the timer interrupt flags in the timer status and control register, removing any pending timer interrupts - Clears TOIE and RTIE, the timer interrupt enable bits in the timer status and control register, disabling further timer interrupts - · Clears the multifunction timer counter register MC68HC705K1 — Rev. 2.0 Technical Data - Sets the IRQE bit in the IRQ status and control register to enable external interrupts - Clears the I bit in the condition code register, enabling interrupts - Stops the internal oscillator, turning off the central processor unit (CPU) clock and the timer clock, including the computer operating properly (COP) watchdog The STOP instruction does not affect any other registers or any input/output (I/O) lines. These conditions bring the MCU out of stop mode: - An external interrupt signal on the IRQ/V<sub>PP</sub> pin A high-to-low transition on the IRQ/V<sub>PP</sub> pin loads the program counter with the contents of locations \$03FA and \$03FB. - An external interrupt signal on a port A external interrupt pin If the PIRQ bit in the mask option register is programmed to a logic 1, a low-to-high transition on a PA3—PA0 pin loads the program counter with the contents of locations \$03FA and \$03FB. - External reset A logic 0 on the RESET pin resets the MCU and loads the program counter with the contents of locations \$03FE and \$03FF. When the MCU exits stop mode, processing resumes after a stabilization delay of 4064 oscillator cycles. ### 6.4 Wait Mode The WAIT instruction puts the MCU in an intermediate power-consumption mode and has these effects on the MCU: - Clears the I bit in the condition code register, enabling interrupts - Sets the IRQE bit in the IRQ status and control register, enabling external interrupts - Stops the CPU clock, but allows the internal oscillator and timer clock to continue to run The WAIT instruction does not affect any other registers or any I/O lines. Low-Power Modes Halt Mode These conditions restart the CPU clock and bring the MCU out of wait mode: - An external interrupt signal on the IRQ/V<sub>PP</sub> pin A high-to-low transition on the IRQ/V<sub>PP</sub> pin loads the program counter with the contents of locations \$03FA and \$03FB. - An external interrupt signal on a port A external interrupt pin If the PIRQ bit in the mask option register is programmed to a logic 1, a low-to-high transition on a PA3—PA0 pin loads the program counter with the contents of locations \$03FA and \$03FB. - A timer interrupt A timer overflow or a real-time interrupt request loads the program counter with the contents of locations \$03F8 and \$03F9. - A COP watchdog reset A timeout of the COP watchdog resets the MCU and loads the program counter with the contents of locations \$03FE and \$03FF. Software can enable real-time interrupts so that the MCU can periodically exit wait mode to reset the COP watchdog. - External reset A logic 0 on the RESET pin resets the MCU and loads the program counter with the contents of locations \$03FE and \$03FF. #### 6.5 Halt Mode The STOP instruction puts the MCU in halt mode if the SWAIT bit in the mask option register is programmed to a logic 1. Halt mode is identical to wait mode, except that a recovery delay of 1–4064 internal clock cycles occurs when the MCU exits halt mode. When the SWAIT bit is set, the COP watchdog cannot be inadvertently turned off by a STOP instruction. Figure 6-1 shows the sequence of events in stop, wait, and halt modes. # **Low-Power Modes** Figure 6-1. Stop/Wait/Halt Flowchart Low-Power Modes Data-Retention Mode #### 6.6 Data-Retention Mode In data-retention mode, the MCU retains random-access memory (RAM) contents and CPU register contents at $V_{DD}$ voltages as low as 2.0 Vdc. Data-retention mode allows the MCU to remain in a low power-consumption state during which it retains data, but the CPU cannot execute instructions. To put the MCU in data-retention mode: - 1. Drive the $\overline{RESET}$ pin to a logic 0. - 2. Lower the V<sub>DD</sub> voltage. The RESET pin must remain low continuously during data-retention mode. To take the MCU out of data-retention mode: - 1. Return V<sub>DD</sub> to normal operating voltage. - 2. Return the $\overline{RESET}$ pin to a logic 1. **Low-Power Modes** ### Technical Data — MC68HC705K1 # Section 7. Parallel Input/Output (I/O) #### 7.1 Contents | · | Introduction | |-------|------------------------------------------------------------------------------------| | 7.3 | I/O Port Function | | 7.4 | Port A | | 7.4.1 | Port A Data Register2 | | 7.4.2 | Data Direction Register A2 | | 7.4.3 | Pulldown Register A (PDRA) | | 7.4.4 | Port A External Interrupts | | 7.4.5 | Port A Logic | | 7.5 | Port B | | 7.5.1 | Port B Data Register (PORTB)6 | | 7.5.2 | Data Direction Register B (DDRB) | | 7.5.3 | Pulldown Register B (PDRB) | | 7.5.4 | Port B Logic | | | 7.4<br>7.4.1<br>7.4.2<br>7.4.3<br>7.4.4<br>7.4.5<br>7.5<br>7.5.1<br>7.5.2<br>7.5.3 | ### 7.2 Introduction This section describes the two bidirectional input/output (I/O) ports: - Port A - Port B MC68HC705K1 — Rev. 2.0 # Parallel Input/Output (I/O) #### 7.3 I/O Port Function The 10 bidirectional input/output (I/O) pins form two parallel I/O ports. Each I/O pin is programmable as an input or an output. The contents of the data direction registers determine the data direction of each I/O pin. All 10 I/O pins have software-programmable pulldown devices. #### **7.4 Port A** Port A is an 8-bit, general-purpose, bidirectional I/O port with these features: - Programmable pulldown devices - 8-mA current sinking capability (pins PA7–PA4) - External interrupt capability (pins PA3–PA0) #### 7.4.1 Port A Data Register The port A data register (PORTA) contains a bit for each of the port A pins. When a port A pin is programmed to be an output, the state of its data register bit determines the state of the output pin. When a port A pin is programmed to be an input, reading the port A data register returns the logic state of the pin. Figure 7-1. Port A Data Register (PORTA) PA7-PA0 — Port A Data Bits These read/write bits are software-programmable. Data direction of each bit is under the control of the corresponding bit in data direction register A. Reset has no effect on port A data. Parallel Input/Output (I/O) Port A ### 7.4.2 Data Direction Register A The contents of data direction register A (DDRA) determine whether each port A pin is an input or an output. Writing a logic 1 to a DDRA bit enables the output buffer for the associated port A pin; a logic 0 disables the output buffer. A reset initializes all DDRA bits to logic 0s, configuring all port A pins as inputs. If the pulldown devices are enabled, setting a DDRA bit to a logic 1 turns off the pulldown device for that pin. Figure 7-2. Data Direction Register A (DDRA) DDRA7-DDRA0 — Port A Data Direction Bits These read/write bits control port A data direction. Reset clears bits DDRA7–DDRA0. - 1 = Corresponding port A pin configured as output - 0 = Corresponding port A pin configured as input **NOTE:** Avoid glitches on port A pins by writing to the port A data register before changing DDRA bits from logic 0 to logic 1. # Parallel Input/Output (I/O) ### 7.4.3 Pulldown Register A Programming the SWPDI bit in the mask option register to a logic 0 enables the port A and port B pulldown devices. The port A pulldown devices sink approximately 100 µA and are under the control of the PDIA7–PDIA0 bits in pulldown register A (PDRA). Clearing the PDIA7–PDIA0 bits turns on the pulldown devices of the port A pins that are configured as inputs. A pulldown device can be turned on only when its pin is an input. When SWPDI is a logic 0, reset initializes all port A pins as inputs with pulldown devices turned on. Programming the SWPDI bit to a logic 1 disables the port A and port B pulldown devices. Reset initializes all port A pins as inputs with pulldown devices disabled when the SWPDI bit is programmed to a logic 1. Figure 7-3. Pulldown Register A (PDRA) PDIA7-PDIA0 — Port A Pulldown Inhibit Bits 7-0 Writing logic 0s to these write-only bits turns on the port A pulldown devices. Reading pulldown register A returns undefined data. Reset clears bits PDIA7–PDIA0. - 1 = Corresponding port A pin pulldown device turned off - 0 = Corresponding port A pin pulldown device turned on **NOTE:** Avoid a floating port A input by clearing its pulldown register bit before changing its DDRA bit from logic 1 to logic 0. Do not use read-modify-write instructions on pulldown register A. Parallel Input/Output (I/O) Port A #### 7.4.4 Port A External Interrupts Programming the PIRQ bit in the mask option register to a logic 1 enables the PA3–PA0 pins to serve as external interrupt pins in addition to the $\overline{IRQ}/V_{PP}$ pin. The active interrupt state for the PA3–PA0 pins is a logic 1 or a rising edge. The active interrupt state for the $\overline{IRQ}/V_{PP}$ pin is a logic 0 or a falling edge. The state of the LEVEL bit in the mask option register determines whether external interrupt inputs are edge-sensitive only or both edge- and level-sensitive. NOTE: When testing for external interrupts, the branch if interrupt pin is high (BIH) and branch if interrupt pin is low (BIL) instructions test the voltage on the $\overline{IRQ}/V_{PP}$ pin, not the state of the internal IRQ signal. Therefore, BIH and BIL cannot test the port A external interrupt pins. #### 7.4.5 Port A Logic Figure 7-4 shows the port A I/O logic. Figure 7-4. Port A I/O Circuit MC68HC705K1 — Rev. 2.0 Technical Data # Freescale Semiconductor, Inc. # Parallel Input/Output (I/O) When a port A pin is programmed as an output, reading the port bit actually reads the value of the data latch and not the voltage on the pin itself. When a port A pin is programmed as an input, reading the port bit reads the voltage level on the pin. The data latch can always be written, regardless of the state of its data direction register bit. **Table 7-1** summarizes the operations of the port A pins. **Table 7-1. Port A Pin Functions** | Pulldown<br>Mask<br>Option | Control Bits | | I/O Pin<br>Mode | Accesses<br>to PDRA | | Accesses<br>to DDRA | Accesses<br>to PORTA | | |----------------------------|------------------|-------|-----------------------|---------------------|-------------|---------------------|----------------------|---------| | | PDIAx | DDRAx | Wode | Read | Write | Read/Write | Read | Write | | No | X <sup>(1)</sup> | 0 | Input, hi-z | U <sup>(2)</sup> | PDIA7-PDIA0 | DDRA7-DDRA0 | Pin | PA7-PA0 | | No | Х | 1 | Output | U | PDIA7-PDIA0 | DDRA7-DDRA0 | PA7-PA0 | PA7-PA0 | | Yes | 0 | 0 | Input,<br>pulldown on | U | PDIA7-PDIA0 | DDRA7-DDRA0 | Pin | PA7-PA0 | | Yes | 0 | 1 | Output | U | PDIA7-PDIA0 | DDRA7-DDRA0 | PA7-PA0 | PA7-PA0 | | Yes | 1 | 0 | Input, hi-z | U | PDIA7-PDIA0 | DDRA7-DDRA0 | Pin | PA7-PA0 | | Yes | 1 | 1 | Output | U | PDIA7-PDIA0 | DDRA7-DDRA0 | PA7-PA0 | PA7-PA0 | <sup>1.</sup> X = Don't care #### **7.5 Port B** Port B is a 2-bit, general-purpose, bidirectional I/O port with these features: - Programmable pulldown devices - Oscillator output for 3-pin resistance-capacitance (RC) oscillator configuration # 7.5.1 Port B Data Register The port B data register (PORTB) contains a bit for each of the port B pins. When a port B pin is programmed to be an output, the state of its data register bit determines the state of the output pin. When a port B pin <sup>2.</sup> U = Undefined ## Freescale Semiconductor, Inc. Parallel Input/Output (I/O) Port B is programmed to be an input, reading the port B data register returns the logic state of the pin. Reset has no effect on port B data. Figure 7-5. Port B Data Register (PORTB) #### PB1/OSC3 — Port B Data Bit 1/Oscillator Output Bit This read/write data bit is software programmable. Data direction of PB1 bit is under the control of the DDRB1 bit in data direction register B. When both the RC and PIN3 bits in the mask option register are set, PB1/OSC3 can be used as an oscillator output in the 3-pin RC oscillator configuration. Using PB1/OSC3 as an oscillator output affects port B in these ways: - a. Bit PB1 can be used as a read/write storage location without affecting the oscillator. Reset has no effect on bit PB1. - Bit DDRB1 in data direction register B can be used as a read/write storage location without affecting the oscillator. Reset clears DDRB1. - c. The PB1/OSC3 pulldown device is disabled, regardless of the state of the SWPDI bit in the mask option register. #### PB0 — Port B Data Bit 0 This read/write data bit is software programmable. Data direction of PB0 is under the control of the DDRB0 bit in data direction register B. Bits 7–2 — Not Used Bits 7–2 always read as logic 0s. Writes to these bits have no effect. MC68HC705K1 — Rev. 2.0 # Parallel Input/Output (I/O) #### 7.5.2 Data Direction Register B The contents of data direction register B (DDRB) determine whether each port B pin is an input or an output. Writing a logic 1 to a DDRB bit enables the output buffer for the associated port B pin; a logic 0 disables the output buffer. A reset initializes all DDRB bits to logic 0, configuring all port B pins as inputs. Setting a DDRB bit to a logic 1 turns off the pulldown device for that pin. Figure 7-6. Data Direction Register B (DDRB) DDRB1 and DDRB0 — Data Direction Bits 1 and 0 These read/write bits control port B data direction. 1 = Corresponding port B pin configured as output 0 = Corresponding port B pin configured as input Bit 7-2 — Not Used Bits 7–2 always read as logic 0s. Writes to these bits have no effect. **NOTE:** Avoid glitches on port B pins by writing to the port B data register before changing DDRB bits from logic 0 to logic 1. #### 7.5.3 Pulldown Register B Programming the SWPDI bit in the mask option register to a logic 0 enables the port A and port B pulldown devices. The port B pulldown devices sink approximately 100 $\mu$ A and are under the control of the PDIB1 and PDIB0 bits in pulldown register B (PDRB). Clearing PDIB1 and PDIB0 turns on the port B pulldown devices if they are configured as inputs. A pulldown device can be turned on only when its pin is an input. When SWPDI is a logic 0, reset initializes both port B pins as inputs with pulldown devices turned on. ### Freescale Semiconductor, Inc. Parallel Input/Output (I/O) Port B Programming the SWPDI bit to a logic 1 disables both of the port B pulldown devices. Reset initializes both port B pins as inputs with pulldown devices disabled when the SWPDI bit is programmed to a logic 1. Figure 7-7. Pulldown Register B (PDRB) PDIB1 and PDIB0 — Port B Pulldown Inhibit Bits 1 and 0 Writing logic 0s to these write-only bits turns on the port B pulldown devices. Reading pulldown register B returns undefined data. Reset clears PDIB1 and PDIB0. - 1 = Corresponding port B pin pulldown device turned off - 0 = Corresponding port B pin pulldown device turned on Bits 7-2 — Not Used Bits 7–2 always read as logic 0s. Programming the SWPDI bit in the mask option register to logic 1 turns off all port A and port B pulldown devices and disables software control of the pulldown devices. Reset has no effect on the pulldown devices when the SWPDI bit is set to a logic 1. NOTE: Avoid a floating port B input by clearing its pulldown register bit before changing its DDRB bit from logic 1 to logic 0. Do not use read-modify-write instructions on pulldown register B. #### 7.5.4 Port B Logic Figure 7-8 shows the port B I/O logic. MC68HC705K1 — Rev. 2.0 # Freescale Semiconductor, Inc. # Parallel Input/Output (I/O) Figure 7-8. Port B I/O Circuit Parallel Input/Output (I/O) Port B When a port B pin is programmed as an output, reading the port bit reads the value of the data latch and not the voltage on the pin itself. When a port B pin is programmed as an input, reading the port bit reads the voltage level on the pin. The data latch can always be written, regardless of the state of its DDR bit. **Table 7-2** summarizes the operation of the PB0 pin. Programming the RC and PIN3 bits to logic 1 disables the PB1/OSC3 output buffer and pulldown device. The PB1/OSC3 bit becomes an output from the 3-pin RC oscillator. The DDRB1 and PB1 bits are available as read/write storage locations; reset clears DDRB1 but does not affect PB1. **Table 7-3** summarizes the operation of the PB1/OSC3 pin. Table 7-2. PB0 Pin Functions | | Control Bits | | PB0<br>Pin Mode | | esses<br>PDRB | Accesses<br>to DDRB | | esses<br>DRTB | |-------|------------------|-------|-----------------------|------------------|---------------|---------------------|------|---------------| | SWPDI | PDIB0 | DDRB0 | 7 FIII WOULE | Read | Write | Read/Write | Read | Write | | 1 | X <sup>(1)</sup> | 0 | Input, hi-z | U <sup>(2)</sup> | PDIB0 | DDRB0 | Pin | PB0 | | 1 | Х | 1 | Output | U | PDIB0 | DDRB0 | PB0 | PB0 | | 0 | 0 | 0 | Input,<br>pulldown on | U | PDIB0 | DDRB0 | Pin | PB0 | | 0 | 0 | 1 | Output | U | PDIB0 | DDRB0 | PB0 | PB0 | | 0 | 1 | 0 | Input, hi-z | U | PDIB0 | DDRB0 | Pin | PB0 | | 0 | 1 | 1 | Output | U | PDIB0 | DDRB0 | PB0 | PB0 | <sup>1.</sup> X = Don't care <sup>2.</sup> U = Undefined # Parallel Input/Output (I/O) Table 7-3. PB1/OSC3 Pin Functions | Control Bits | | PB1/OSC3 Accesses to PDRB Pin Mode | | Accesses Access to DDRB to POR | | | | | | | |--------------|------------------|------------------------------------|-------|--------------------------------|----------------------------------|------------------|-------|------------|------|-------| | RC | PIN3 | SWPDI | PDIB1 | DDRB1 | Fill Wode | Read | Write | Read/Write | Read | Write | | 0 | X <sup>(1)</sup> | 1 | Х | 0 | Input, hi-z | U <sup>(2)</sup> | PDIB1 | DDRB1 | Pin | PB1 | | 0 | Х | 1 | Х | 1 | Output | U | PDIB1 | DDRB1 | PB1 | PB1 | | 0 | X | 0 | 0 | 0 | Input,<br>pulldown on | U | PDIB1 | DDRB1 | Pin | PB1 | | 0 | Х | 0 | 0 | 1 | Output | U | PDIB1 | DDRB1 | PB1 | PB1 | | 0 | Х | 0 | 1 | 0 | Input, hi-z | U | PDIB1 | DDRB1 | Pin | PB1 | | 0 | Х | 0 | 1 | 1 | Output | U | PDIB1 | DDRB1 | PB1 | PB1 | | 1 | 0 | 1 | Х | 0 | Input, hi-z | U | PDIB1 | DDRB1 | Pin | PB1 | | 1 | 0 | 1 | Х | 1 | Output | U | PDIB1 | DDRB1 | PB1 | PB1 | | 1 | 0 | 0 | 0 | 0 | Input,<br>pulldown on | U | PDIB1 | DDRB1 | Pin | PB1 | | 1 | 0 | 0 | 0 | 1 | Output | U | PDIB1 | DDRB1 | PB1 | PB1 | | 1 | 0 | 0 | 1 | 0 | Input, hi-z | U | PDIB1 | DDRB1 | Pin | PB1 | | 1 | 0 | 0 | 1 | 1 | Output | U | PDIB1 | DDRB1 | PB1 | PB1 | | 1 | 1 | х | х | Х | 3-pin<br>RC oscillator<br>output | U | PDIB1 | DDRB1 | PB1 | PB1 | <sup>1.</sup> X = Don't care <sup>2.</sup> U = Undefined ### Technical Data — MC68HC705K1 # **Section 8. Multifunction Timer** #### 8.1 Contents | 8.2 | Introduction | |-----|-----------------------------------| | 8.3 | Timer Status and Control Register | | 8.4 | Timer Counter Register7 | | 8.5 | COP Watchdog | ### 8.2 Introduction This section describes the operation of the multifunction timer and the computer operating properly (COP) watchdog. **Figure 8-1** shows the organization of the timer subsystem. MC68HC705K1 — Rev. 2.0 Technical Data # **Multifunction Timer** Figure 8-1. Multifunction Timer Block Diagram Multifunction Timer Timer Status and Control Register ### 8.3 Timer Status and Control Register The read/write timer status and control register (TSCR) contains these bits: - Timer interrupt enable bits - Timer interrupt flags - Timer interrupt flag reset bits - Timer interrupt rate select bits Figure 8-2. Timer Status and Control Register (TSCR) #### TOF — Timer Overflow Flag This read-only flag becomes set when the first eight stages of the counter roll over from \$FF to \$00. TOF generates a timer overflow interrupt request if TOIE is also set. Clear TOF by writing a logic 1 to the TOFR bit. Writing to TOF has no effect. Reset clears TOF. #### RTIF — Real-Time Interrupt Flag This read-only flag becomes set when the selected real-time interrupt (RTI) output becomes active. RTIF generates a real-time interrupt request if RTIE is also set. Clear RTIF by writing a logic 1 to the RTIFR bit. Writing to RTIF has no effect. Reset clears RTIF. #### TOIE — Timer Overflow Interrupt Enable Bit This read/write bit enables timer overflow interrupts. Reset clears TOIE. 1 = Timer overflow interrupts enabled 0 = Timer overflow interrupts disabled MC68HC705K1 — Rev. 2.0 Technical Data ### **Multifunction Timer** RTIE — Real-Time Interrupt Enable Bit This read/write bit enables real-time interrupts. Reset clears RTIE. 1 = Real-time interrupts enabled 0 = Real-time interrupts disabled TOFR — Timer Overflow Flag Reset Writing a logic 1 to this write-only bit clears the TOF bit. TOFR always reads as a logic 0. Reset does not affect TOFR. RTIFR — Real-Time Interrupt Flag Reset Writing a logic 1 to this write-only bit clears the RTIF bit. RTIFR always reads as a logic 0. Reset does not affect RTIFR. RT1 and RT0 — Real-Time Interrupt Select Bits 1 and 0 These read/write bits select one of four real-time interrupt rates, as shown in **Table 8-1**. Because the selected RTI output drives the COP watchdog, changing the real-time interrupt rate also changes the counting rate of the COP watchdog. Reset sets RT1 and RT0, selecting the longest COP timeout period and RTI period. NOTE: Changing RT1 and RT0 when a COP timeout is imminent or uncertain may cause an RTI request to be missed or an additional RTI request to be generated. Clear the COP timer just before changing RT1 and RT0. Table 8-1. Real-Time Interrupt Rate Selection | RT1:RT0 | Number<br>of Cycles<br>to RTI | RTI<br>Period <sup>(1)</sup> | Number<br>of Cycles<br>to COP Reset | COP Timeout<br>Period <sup>(1)</sup> | |---------|-------------------------------|------------------------------|-------------------------------------|--------------------------------------| | 0 0 | $2^{14} = 16,384$ | 8.2 ms | $2^{17} = 131,072$ | 65.5 ms | | 0 1 | $2^{15} = 32,768$ | 16.4 ms | $2^{18} = 262,144$ | 131.1 ms | | 1 0 | $2^{16} = 65,536$ | 32.8 ms | 2 <sup>19</sup> = 524,288 | 262.1 ms | | 1 1 | 2 <sup>17</sup> = 131,072 | 65.5 ms | $2^{20} = 1,048,576$ | 524.3 ms | <sup>1.</sup> At 2-MHz bus, 4-MHz XTAL, 0.5 µs per cycle **Technical Data** Multifunction Timer Timer Counter Register ## 8.4 Timer Counter Register A 15-stage ripple counter is the core of the timer. The value of the first eight stages is readable at any time from the read-only timer counter register (TCNTR). Figure 8-3. Timer Counter Register (TCNTR) Power-on clears the entire counter chain and begins clocking the counter. After 4064 cycles, the power-on reset circuit is released, clearing the counter again and allowing the MCU to come out of reset. A timer overflow function at the eighth counter stage allows a timer interrupt every 1024 internal clock cycles. Each count of the timer counter register takes eight oscillator cycles or four cycles of the internal clock. ### 8.5 COP Watchdog Four counter stages at the end of the timer make up the mask-optional computer operating properly (COP) watchdog. The COP watchdog is a software error detection system that automatically times out and resets the MCU if not cleared periodically by a program sequence. Writing a logic 0 to bit 0 of the COP register clears the COP watchdog and prevents a COP reset. Figure 8-4. COP Register (COPR) #### COPC — COP Clear Bit This write-only bit resets the COP watchdog. Reading address \$03F0 returns the read-only memory (ROM) data at that address. The COP watchdog is active in the run, wait, and halt modes of operation if the COPEN bit in the mask option register is set. The STOP instruction disables the COP watchdog by clearing the counter and turning off its clock source. In applications that depend on the COP watchdog, the STOP instruction can be disabled by programming the SWAIT bit to a logic 1 in the mask option register. In applications that have wait cycles longer than the COP timeout period, the COP watchdog can be disabled by not programming the COPEN bit to a logic 1 in the mask option register. **NOTE:** If the voltage on the $\overline{IRQ}/V_{PP}$ pin exceeds $2 \times V_{DD}$ , the COP watchdog turns off and remains off until the $\overline{IRQ}/V_{PP}$ voltage falls below $2 \times V_{DD}$ . Multifunction Timer **COP** Watchdog Table 8-2 summarizes recommended conditions for enabling and disabling the COP watchdog. **Table 8-2. COP Watchdog Recommendations** | Voltage on IRQ/V <sub>PP</sub> Pin | SWAIT<br>Bit <sup>(1)</sup> | Wait/Halt Time | Recommended<br>COP Watchdog<br>Condition | |------------------------------------|-----------------------------|---------------------------------|------------------------------------------| | Less than 2 × V <sub>DD</sub> | 1 | Less than COP timeout period | Enabled <sup>(2)</sup> | | Less than 2 × V <sub>DD</sub> | 1 | Greater than COP timeout period | Disabled | | Less than 2 × V <sub>DD</sub> | 0 | X <sup>(3)</sup> | Disabled | | More than 2 × V <sub>DD</sub> | Х | X | Automatically disabled | <sup>1.</sup> The SWAIT bit in the mask option register converts STOP instructions to HALT instruc- <sup>2.</sup> Reset the COP watchdog immediately before executing the WAIT/HALT instruction. <sup>3.</sup> X = Don't care **Multifunction Timer** ### Technical Data — MC68HC705K1 # Section 9. EPROM/OTPROM | <b>Q</b> 1 | C | Λn | tο | nte | |------------|---|------|----|-----| | J. I | • | OI I | LC | HLO | | 9.2 | Introduction | .83 | |-----|----------------------------|-----| | 9.3 | EPROM Programming Register | .84 | | 9.4 | EPROM/OTPROM Programming | .85 | | 9.5 | EPROM Erasing | .87 | | 9.6 | Mask Option Register | .87 | #### 9.2 Introduction This section describes how to program the 504-byte erasable, programmable read-only memory (EPROM)/one-time programmable read-only memory (OTPROM). #### **NOTE:** In packages with no quartz window, the 504 bytes of EPROM function as an OTPROM. MC68HC705K1 — Rev. 2.0 ## 9.3 EPROM Programming Register The EPROM programming register (EPROG) contains the control bits for programming the EPROM/OTPROM. In normal operation, the EPROM programming register is a read-only register that contains all logic 0s. Figure 9-1. EPROM Programming Register (EPROG) #### ELAT — EPROM Bus Latch Bit This read/write bit configures address and data buses for programming the EPROM/OTPROM array. EPROM/OTPROM data cannot be read when ELAT is set. Clearing the ELAT bit also clears the EPGM bit. Reset clears ELAT. - 1 = Address and data buses configured for EPROM/OTPROM programming - 0 = Address and data buses configured for normal operation #### MPGM — Mask Option Register (MOR) Programming Bit This read/write bit applies programming power from the IRQ/V<sub>PP</sub> pin to the MOR. Reset clears MPGM. - 1 = MOR programming power switched on - 0 = MOR programming power switched off #### **EPGM** — **EPROM** Programming Bit This read/write bit applies the voltage from the $\overline{IRQ}/V_{PP}$ pin to the EPROM/OTPROM. To write the EPGM bit, the ELAT bit must already be set. Reset clears EPGM. - 1 = EPROM/OTPROM programming power switched on - 0 = EPROM/OTPROM programming power switched off EPROM/OTPROM EPROM/OTPROM Programming **NOTE:** Writing logic 1s to both the ELAT and EPGM bits with a single instruction sets ELAT and clears EPGM. ELAT must be set first by a separate instruction. Bits 7-3 — Reserved Bits 7–3 are factory test bits that always read as logic 0s. ## 9.4 EPROM/OTPROM Programming The MC68HC705K1 does not contain built-in bootloader ROM code. To program this device, use an external programming system such as the M68HC705KICS evaluation module (EVM) or an M68HC705K1GANG programmer. Factory-provided software for programming the EPROM/OTPROM is available through the Motorola web site at: htt://mcu.motsps.com The programming software copies to the 496-byte space located at EPROM/OTPROM addresses \$0200–\$03EF, to the 8-byte space at addresses \$03F8–\$03FF, and to the mask option register at address \$0017. **Figure 9-2** shows the circuit used to download to the on-chip EPROM/OTPROM using the factory-provided programming software. This sequence shows the steps in programming a byte of EPROM/OTPROM: - 1. Switch S1 powers up the MC68HC705K1. - 2. Software synchronizes the external oscillator to the internal clock. - 3. Switch S2 applies $V_{PP}$ to the IRQ/ $V_{PP}$ pin. - Software sets the ELAT bit. - 5. Software writes to an EPROM/OTPROM address. - 6. Software sets the EPGM bit for a time t<sub>EPGM</sub> to apply the programming voltage. - 7. Software clears the ELAT bit. **NOTE:** To program the EPROM/OTPROM, V<sub>DD</sub> must be greater than 4.5 Vdc. MC68HC705K1 — Rev. 2.0 Technical Data Figure 9-2. Programming Circuit # 9.5 EPROM Erasing MCUs with windowed packages permit EPROM erasure with ultraviolet light. Erase the EPROM by exposing it to 15 Ws/cm<sup>2</sup> of ultraviolet light with a wave length of 2537 angstroms. Position the ultraviolet light source 1 inch from the window. Do not use a shortwave filter. The erased state of an EPROM bit is a logic 0. ### 9.6 Mask Option Register The mask option register (MOR) is an EPROM/OTPROM byte that controls these options: - Port A and port B programmable pulldown devices (enable or disable) - Oscillator connections (2-pin or 3-pin RC oscillator) - Oscillator connections (RC oscillator or crystal/ceramic resonator) - STOP instruction (enable or disable) - Low-voltage reset (enable or disable) - Port A external interrupt function (enable or disable) - IRQ trigger sensitivity (edge-triggered only or both edge- and level-triggered) - COP watchdog (enable or disable) The mask option register is unaffected by reset. The erased state of the mask option register is \$0000. Figure 9-3. Mask Option Register (MOR) MC68HC705K1 — Rev. 2.0 Technical Data ### **EPROM/OTPROM** SWPDI —Software Pulldown Inhibit Bit This EPROM bit inhibits software control of the port A and port B pulldown devices. - 1 = Software pulldown inhibited - 0 = Software pulldown enabled #### PIN3 — 3-Pin RC Oscillator Bit This EPROM bit configures the on-chip oscillator as either a 3-pin oscillator or as a 2-pin oscillator. The PIN3 bit should be cleared when the RC bit is clear. - 1 = 3-pin oscillator configured - 0 = 2-pin oscillator configured #### RC — RC Oscillator Bit This EPROM bit configures the on-chip oscillator for an external RC network. - 1 = Oscillator configured for external RC network - 0 = Oscillator configured for external crystal, ceramic resonator, or clock source #### SWAIT — STOP Conversion to WAIT Bit This EPROM bit disables the STOP instruction and prevents inadvertently turning off the COP watchdog with a STOP instruction. When the SWAIT bit is set, a STOP instruction puts the MCU in halt mode. Halt mode is a low-power state similar to wait mode. The internal oscillator and timer clock continue to run, but the CPU clock stops. When the SWAIT bit is clear, a STOP instruction stops the internal oscillator, the internal clock, the CPU clock, and the timer clock. - 1 = STOP instruction converted to WAIT instruction - 0 = STOP instruction not converted to WAIT instruction #### LVRE — Low-Voltage Reset Enable Bit This EPROM bit enables the low-voltage reset (LVR) circuit. - 1 = LVR circuit enabled - 0 = LVR circuit disabled **Technical Data** EPROM/OTPROM Mask Option Register PIRQ — Port A IRQ Enable Bit This EPROM bit enables the PA3–PA0 pins to function as external interrupt sources. - 1 = PA3–PA0 enabled as external interrupt sources - 0 = PA3-PA0 not enabled as external interrupt sources LEVEL — External Interrupt Sensitivity Bit This EPROM bit makes the external interrupt inputs level-triggered as well as edge-triggered. - 1 = IRQ/V<sub>PP</sub> pin negative-edge triggered and low-level triggered; PA3–PA0 pins positive-edge triggered and high-level triggered - 0 = IRQ/V<sub>PP</sub> pin negative-edge triggered only; PA3–PA0 pins positive-edge triggered only COPEN — COP Watchdog Enable Bit This EPROM bit enables the COP watchdog. - 1 = COP watchdog enabled - 0 = COP watchdog disabled **NOTE:** In 3-pin RC oscillator configurations, the personality EPROM (PEPROM) cannot be programmed by user software. If the voltage on $\overline{IRQ}/V_{PP}$ is raised above $V_{DD}$ , the oscillator will revert to a 2-pin oscillator configuration and device operation will be disrupted. #### Technical Data — MC68HC705K1 # **Section 10. Personality EPROM (PEPROM)** #### 10.1 Contents | 10.2 | Introduction91 | |--------|--------------------| | 10.3.1 | PEPROM Registers | | 10.4 | PEPROM Programming | | 10.5 | PEPROM Reading | | 10.6 | PEPROM Erasing | #### 10.2 Introduction This section describes how to program the 64-bit personality erasable, programmable read-only memory (PEPROM). **Figure 10-1** shows the structure of the PEPROM subsystem. MC68HC705K1 — Rev. 2.0 # **Personality EPROM (PEPROM)** Figure 10-1. Personality EPROM Personality EPROM (PEPROM) PEPROM Registers # 10.3 PEPROM Registers Two input/output (I/O) registers control programming and reading of the PEPROM: - PEPROM bit select register (PEBSR) - PEPROM status and control register (PESCR) #### 10.3.1 PEPROM Bit Select Register The PEPROM bit select register (PEBSR) selects one of 64 bits in the PEPROM array. Reset clears all the bits in the PEPROM bit select register. Figure 10-2. PEPROM Bit Select Register (PEBSR) PEB7 and PEB6 — Not Connected to the PEPROM Array These read/write bits are available as storage locations. Reset clears PEB7 and PEB6. PEB5-PEB0 — PEPROM Bit Select Bits These read/write bits select one of 64 bits in the PEPROM as shown in **Table 10-1**. Bits PEB2–PEB0 select the PEPROM row, and bits PEB5–PEB3 select the PEPROM column. Reset clears PEB5–PEB0, selecting the PEPROM bit in row zero, column zero. # **Personality EPROM (PEPROM)** Table 10-1. PEPROM Bit Selection | PEBSR | PEPROM | Bit Selected | |-------|----------|--------------| | \$00 | Row 0 | Column 0 | | \$01 | Row 1 | Column 0 | | \$02 | Row 2 | Column 0 | | | <b>↓</b> | | | \$07 | Row 7 | Column 0 | | \$08 | Row 0 | Column 1 | | \$09 | Row 1 | Column 1 | | \$0A | Row 2 | Column 1 | | | | | | \$0F | Row 7 | Column 1 | | \$10 | Row 0 | Column 2 | | \$11 | Row 1 | Column 2 | | \$12 | Row 2 | Column 2 | | | | | | \$37 | Row 7 | Column 6 | | \$38 | Row 0 | Column 7 | | \$39 | Row 1 | Column 7 | | \$3A | Row 2 | Column 7 | | \$3B | Row 3 | Column 7 | | \$3C | Row 4 | Column 7 | | \$3D | Row 5 | Column 7 | | \$3E | Row 6 | Column 7 | | \$3F | Row 7 | Column 7 | Personality EPROM (PEPROM) PEPROM Registers #### 10.3.2 PEPROM Status and Control Register The PEPROM status and control register (PESCR) controls the PEPROM programming voltage. This register also transfers the PEPROM bits to the internal data bus and contains a row zero flag. Figure 10-3. PEPROM Status and Control Register (PESCR) #### PEDATA — PEPROM Data Bit This read-only bit is the state of the PEPROM sense amplifier and shows the state of the currently selected bit. Reset does not affect the PEDATA bit. 1 = PEPROM data logic 1 0 = PEPROM data logic 0 #### PEPGM — PEPROM Program Control Bit This read/write bit controls the switches that apply the programming voltage, V<sub>PP</sub>, to the selected PEPROM cell. Reset clears PEPGM. 1 = Programming voltage applied 0 = Programming voltage not applied #### PEPRZF — PEPROM Row Zero Flag This read-only bit is set when the PEPROM bit select register selects the first row (row zero) of the PEPROM array. Selecting any other row clears PEPRZF. Monitoring PEPRZF can reduce the code needed to access one byte of PEPROM. Reset sets PEPRZF. 1 = Row zero selected 0 = Row zero not selected MC68HC705K1 — Rev. 2.0 Technical Data ## **Personality EPROM (PEPROM)** ### 10.4 PEPROM Programming Factory-provided software for programming the PEPROM is available through the Motorola web site at: htt://mcu.motsps.com The circuit shown in **Figure 9-2. Programming Circuit** can be used to program the PEPROM with the factory-provided programming software. **NOTE:** To program the PEPROM, V<sub>DD</sub> must be greater than 4.5 Vdc. The PEPROM can also be programmed by user software with $V_{PP}$ applied to the $\overline{IRQ}/V_{PP}$ pin. This sequence shows how to program each PEPROM bit: - 1. Select a PEPROM bit by writing to PEBSR. - 2. Set the PEPGM bit in PESCR. - 3. Wait 3 ms. - 4. Clear the PEPGM bit. **NOTE:** While the PEPGM bit is set and $V_{PP}$ is applied to the $\overline{IRQ}/V_{PP}$ pin, do not access bits that are to be left unprogrammed (erased). In 3-pin RC oscillator configurations, the PEPROM cannot be programmed by user software. If the voltage on $\overline{IRQ}/V_{PP}$ is raised above $V_{DD}$ , the oscillator will revert to a 2-pin oscillator configuration and device operation will be disrupted. # 10.5 PEPROM Reading This sequence shows how to read the PEPROM: - 1. Select a bit by writing to PEBSR. - 2. Read the PEDATA bit in PESCR. - 3. Store the PEDATA bit in RAM or in a register. - 4. Select another bit by changing PEBSR. - 5. Continue reading and storing the PEDATA bits until the required personality EPROM data is stored. Personality EPROM (PEPROM) PEPROM Erasing Reading the PEPROM is easiest when each PEPROM column contains one byte. Selecting a row 0 bit selects the first bit, and incrementing the PEPROM bit select register (PEBSR) selects the next row 1 bit from the same column. Incrementing PEBSR seven more times selects the remaining bits of the column and selects the row 0 bit of the next column, setting the row 0 flag, PEPRZF. A PEPROM byte that has been read can be transferred to the personality EPROM bit select register (PEBSR) so that subsequent reads of the PEBSR quickly yield that PEPROM byte. ## 10.6 PEPROM Erasing MCUs with windowed packages permit PEPROM erasure with ultraviolet light. Erase the PEPROM by exposing it to 15 Ws/cm<sup>2</sup> of ultraviolet light with a wave length of 2537 angstroms. Position the ultraviolet light source 1 inch from the window. Do not use a shortwave filter. The erased state of a PEPROM bit is a logic 0. MC68HC705K1 — Rev. 2.0 Technical Data **Personality EPROM (PEPROM)** ### Technical Data — MC68HC705K1 # **Section 11. Instruction Set** ### 11.1 Contents | 11.2 Introduction100 | |-----------------------------------------| | 11.3 Addressing Modes | | 11.3.1 Inherent | | 11.3.2 Immediate101 | | 11.3.3 Direct | | 11.3.4 Extended101 | | 11.3.5 Indexed, No Offset | | 11.3.6 Indexed, 8-Bit Offset102 | | 11.3.7 Indexed, 16-Bit Offset102 | | 11.3.8 Relative | | 11.4 Instruction Types | | 11.4.1 Register/Memory Instructions104 | | 11.4.2 Read-Modify-Write Instructions | | 11.4.3 Jump/Branch Instructions106 | | 11.4.4 Bit Manipulation Instructions108 | | 11.4.5 Control Instructions | | 11.5 Instruction Set Summary110 | | 11.6 Opcode Map | MC68HC705K1 — Rev. 2.0 Technical Data #### 11.2 Introduction The microcontroller unit (MCU) instruction set has 62 instructions and uses eight addressing modes. The instructions include all those of the M146805 CMOS Family plus one more: the unsigned multiply (MUL) instruction. The MUL instruction allows unsigned multiplication of the contents of the accumulator (A) and the index register (X). The high-order product is stored in the index register, and the low-order product is stored in the accumulator. ### 11.3 Addressing Modes The central processor unit (CPU) uses eight addressing modes for flexibility in accessing data. The addressing modes provide eight different ways for the CPU to find the data required to execute an instruction. The eight addressing modes are: - Inherent - Immediate - Direct - Extended - Indexed, no offset - Indexed, 8-bit offset - Indexed, 16-bit offset - Relative Instruction Set Addressing Modes #### 11.3.1 Inherent Inherent instructions are those that have no operand, such as return from interrupt (RTI) and stop (STOP). Some of the inherent instructions act on data in the CPU registers, such as set carry flag (SEC) and increment accumulator (INCA). Inherent instructions require no operand address and are one byte long. #### 11.3.2 Immediate Immediate instructions are those that contain a value to be used in an operation with the value in the accumulator or index register. Immediate instructions require no operand address and are two bytes long. The opcode is the first byte, and the immediate data value is the second byte. #### 11.3.3 Direct Direct instructions can access any of the first 256 memory locations with two bytes. The first byte is the opcode, and the second is the low byte of the operand address. In direct addressing, the CPU automatically uses \$00 as the high byte of the operand address. #### 11.3.4 Extended Extended instructions use three bytes and can access any address in memory. The first byte is the opcode; the second and third bytes are the high and low bytes of the operand address. When using the Motorola assembler, the programmer does not need to specify whether an instruction is direct or extended. The assembler automatically selects the shortest form of the instruction. ### **Instruction Set** #### 11.3.5 Indexed, No Offset Indexed instructions with no offset are 1-byte instructions that can access data with variable addresses within the first 256 memory locations. The index register contains the low byte of the effective address of the operand. The CPU automatically uses \$00 as the high byte, so these instructions can address locations \$0000–\$00FF. Indexed, no offset instructions are often used to move a pointer through a table or to hold the address of a frequently used RAM or I/O location. #### 11.3.6 Indexed, 8-Bit Offset Indexed, 8-bit offset instructions are 2-byte instructions that can access data with variable addresses within the first 511 memory locations. The CPU adds the unsigned byte in the index register to the unsigned byte following the opcode. The sum is the effective address of the operand. These instructions can access locations \$0000–\$01FE. Indexed 8-bit offset instructions are useful for selecting the kth element in an n-element table. The table can begin anywhere within the first 256 memory locations and could extend as far as location 510 (\$01FE). The k value is typically in the index register, and the address of the beginning of the table is in the byte following the opcode. #### 11.3.7 Indexed, 16-Bit Offset Indexed, 16-bit offset instructions are 3-byte instructions that can access data with variable addresses at any location in memory. The CPU adds the unsigned byte in the index register to the two unsigned bytes following the opcode. The sum is the effective address of the operand. The first byte after the opcode is the high byte of the 16-bit offset; the second byte is the low byte of the offset. Indexed, 16-bit offset instructions are useful for selecting the kth element in an n-element table anywhere in memory. As with direct and extended addressing, the Motorola assembler determines the shortest form of indexed addressing. Instruction Set Instruction Types #### 11.3.8 Relative Relative addressing is only for branch instructions. If the branch condition is true, the CPU finds the effective branch destination by adding the signed byte following the opcode to the contents of the program counter. If the branch condition is not true, the CPU goes to the next instruction. The offset is a signed, two's complement byte that gives a branching range of –128 to +127 bytes from the address of the next location after the branch instruction. When using the Motorola assembler, the programmer does not need to calculate the offset, because the assembler determines the proper offset and verifies that it is within the span of the branch. ## 11.4 Instruction Types The MCU instructions fall into five categories: - Register/memory instructions - Read-modify-write instructions - Jump/branch instructions - Bit manipulation instructions - Control instructions # **Instruction Set** ### 11.4.1 Register/Memory Instructions These instructions operate on CPU registers and memory locations. Most of them use two operands. One operand is in either the accumulator or the index register. The CPU finds the other operand in memory. Table 11-1. Register/Memory Instructions | Instruction | Mnemonic | |-----------------------------------------------------|----------| | Add memory byte and carry bit to accumulator | ADC | | Add memory byte to accumulator | ADD | | AND memory byte with accumulator | AND | | Bit test accumulator | BIT | | Compare accumulator | CMP | | Compare index register with memory byte | CPX | | Exclusive OR accumulator with memory byte | EOR | | Load accumulator with memory byte | LDA | | Load Index register with memory byte | LDX | | Multiply | MUL | | OR accumulator with memory byte | ORA | | Subtract memory byte and carry bit from accumulator | SBC | | Store accumulator in memory | STA | | Store index register in memory | STX | | Subtract memory byte from accumulator | SUB | **Technical Data** Instruction Set Instruction Types #### 11.4.2 Read-Modify-Write Instructions These instructions read a memory location or a register, modify its contents, and write the modified value back to the memory location or to the register. **NOTE:** Do not use read-modify-write operations on write-only registers. Table 11-2. Read-Modify-Write Instructions | Instruction | Mnemonic | |-------------------------------------|---------------------| | Arithmetic shift left (same as LSL) | ASL | | Arithmetic shift right | ASR | | Bit clear | BCLR <sup>(1)</sup> | | Bit set | BSET <sup>(1)</sup> | | Clear register | CLR | | Complement (one's complement) | COM | | Decrement | DEC | | Increment | INC | | Logical shift left (same as ASL) | LSL | | Logical shift right | LSR | | Negate (two's complement) | NEG | | Rotate left through carry bit | ROL | | Rotate right through carry bit | ROR | | Test for negative or zero | TST <sup>(2)</sup> | Unlike other read-modify-write instructions, BCLR and BSET use only direct addressing. MC68HC705K1 — Rev. 2.0 <sup>2.</sup> TST is an exception to the read-modify-write sequence because it does not write a replacement value. ### **Instruction Set** #### 11.4.3 Jump/Branch Instructions Jump instructions allow the CPU to interrupt the normal sequence of the program counter. The unconditional jump instruction (JMP) and the jump-to-subroutine instruction (JSR) have no register operand. Branch instructions allow the CPU to interrupt the normal sequence of the program counter when a test condition is met. If the test condition is not met, the branch is not performed. The BRCLR and BRSET instructions cause a branch based on the state of any readable bit in the first 256 memory locations. These 3-byte instructions use a combination of direct addressing and relative addressing. The direct address of the byte to be tested is in the byte following the opcode. The third byte is the signed offset byte. The CPU finds the effective branch destination by adding the third byte to the program counter if the specified bit tests true. The bit to be tested and its condition (set or clear) is part of the opcode. The span of branching is from –128 to +127 from the address of the next location after the branch instruction. The CPU also transfers the tested bit to the carry/borrow bit of the condition code register. Instruction Set Instruction Types **Table 11-3. Jump and Branch Instructions** | Instruction | Mnemonic | |--------------------------------|----------| | Branch if carry bit clear | BCC | | Branch if carry bit set | BCS | | Branch if equal | BEQ | | Branch if half-carry bit clear | внсс | | Branch if half-carry bit set | BHCS | | Branch if higher | BHI | | Branch if higher or same | BHS | | Branch if IRQ pin high | BIH | | Branch if IRQ pin low | BIL | | Branch if lower | BLO | | Branch if lower or same | BLS | | Branch if interrupt mask clear | ВМС | | Branch if minus | ВМІ | | Branch if interrupt mask set | BMS | | Branch if not equal | BNE | | Branch if plus | BPL | | Branch always | BRA | | Branch if bit clear | BRCLR | | Branch never | BRN | | Branch if bit set | BRSET | | Branch to subroutine | BSR | | Unconditional jump | JMP | | Jump to subroutine | JSR | # **Instruction Set** #### 11.4.4 Bit Manipulation Instructions The CPU can set or clear any writable bit in the first 256 bytes of memory, which includes I/O registers and on-chip RAM locations. The CPU can also test and branch based on the state of any bit in any of the first 256 memory locations. **Table 11-4. Bit Manipulation Instructions** | Instruction | Mnemonic | |---------------------|----------| | Bit clear | BCLR | | Branch if bit clear | BRCLR | | Branch if bit set | BRSET | | Bit set | BSET | Instruction Set Instruction Types #### 11.4.5 Control Instructions These instructions act on CPU registers and control CPU operation during program execution. **Table 11-5. Control Instructions** | Instruction | Mnemonic | |----------------------------------------|----------| | Clear carry bit | CLC | | Clear interrupt mask | CLI | | No operation | NOP | | Reset stack pointer | RSP | | Return from interrupt | RTI | | Return from subroutine | RTS | | Set carry bit | SEC | | Set interrupt mask | SEI | | Stop oscillator and enable IRQ pin | STOP | | Software interrupt | SWI | | Transfer accumulator to index register | TAX | | Transfer index register to accumulator | TXA | | Stop CPU clock and enable interrupts | WAIT | # 11.5 Instruction Set Summary Table 11-6. Instruction Set Summary (Sheet 1 of 6) | Source | Operation | Description | Effect on CCR | | | | | Address<br>Mode | Opcode | Operand | Cycles | |--------------------------------------------------------------------|---------------------------------------|----------------------------------------------|---------------|---|----------|----------|----------|----------------------------------------------------------------------------------------------|----------------------------------|----------------------------------------------|-------------------------------------------| | Form | Орегиноп | Besonption | Н | I | N | Z | С | Add | obc | Ope | င် | | ADC #opr<br>ADC opr<br>ADC opr<br>ADC opr,X<br>ADC opr,X<br>ADC ,X | Add with Carry | A ← (A) + (M) + (C) | <b>‡</b> | _ | <b>‡</b> | <b>‡</b> | <b>‡</b> | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX | A9<br>B9<br>C9<br>D9<br>E9<br>F9 | ii<br>dd<br>hh II<br>ee ff<br>ff | 2<br>3<br>4<br>5<br>4<br>3 | | ADD #opr<br>ADD opr<br>ADD opr<br>ADD opr,X<br>ADD opr,X<br>ADD ,X | Add without Carry | A ← (A) + (M) | <b>‡</b> | _ | <b>‡</b> | <b>‡</b> | <b>‡</b> | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX | AB<br>BB<br>CB<br>DB<br>EB<br>FB | ii<br>dd<br>hh II<br>ee ff<br>ff | 2<br>3<br>4<br>5<br>4<br>3 | | AND #opr<br>AND opr<br>AND opr<br>AND opr,X<br>AND opr,X<br>AND ,X | Logical AND | $A \leftarrow (A) \land (M)$ | | _ | <b>‡</b> | <b>‡</b> | _ | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX | A4<br>B4<br>C4<br>D4<br>E4<br>F4 | ii<br>dd<br>hh II<br>ee ff<br>ff | 2<br>3<br>4<br>5<br>4<br>3 | | ASL opr<br>ASLA<br>ASLX<br>ASL opr,X<br>ASL ,X | Arithmetic Shift Left (Same as LSL) | © ← 0 b7 b0 | _ | _ | <b>‡</b> | <b>‡</b> | <b>‡</b> | DIR<br>INH<br>INH<br>IX1<br>IX | 38<br>48<br>58<br>68<br>78 | dd<br>ff | 5<br>3<br>6<br>5 | | ASR opr<br>ASRA<br>ASRX<br>ASR opr,X<br>ASR ,X | Arithmetic Shift Right | b7 b0 | | _ | <b>‡</b> | <b>‡</b> | <b>‡</b> | DIR<br>INH<br>INH<br>IX1<br>IX | 37<br>47<br>57<br>67<br>77 | dd<br>ff | 5<br>3<br>6<br>5 | | BCC rel | Branch if Carry Bit Clear | $PC \leftarrow (PC) + 2 + rel? C = 0$ | _ | _ | _ | _ | _ | REL | 24 | rr | 3 | | BCLR n opr | Clear Bit n | Mn ← 0 | | | | | | DIR (b0)<br>DIR (b1)<br>DIR (b2)<br>DIR (b3)<br>DIR (b4)<br>DIR (b5)<br>DIR (b6)<br>DIR (b7) | 15<br>17<br>19<br>1B<br>1D | dd<br>dd<br>dd<br>dd<br>dd<br>dd<br>dd<br>dd | 5<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5 | | BCS rel | Branch if Carry Bit Set (Same as BLO) | PC ← (PC) + 2 + rel ? C = 1 | | | | | | REL | 25 | rr | 3 | | BEQ rel | Branch if Equal | PC ← (PC) + 2 + rel? Z = 1 | | | _ | | | REL | 27 | rr | 3 | | BHCC rel | Branch if Half-Carry Bit Clear | $PC \leftarrow (PC) + 2 + rel? H = 0$ | _ | | | | | REL | 28 | rr | 3 | | BHCS rel | Branch if Half-Carry Bit Set | PC ← (PC) + 2 + rel? H = 1 | _ | _ | _ | | _ | REL | 29 | rr | 3 | | BHI rel | Branch if Higher | $PC \leftarrow (PC) + 2 + rel? C \lor Z = 0$ | _ | | | | | REL | 22 | rr | 3 | | BHS rel | Branch if Higher or Same | $PC \leftarrow (PC) + 2 + rel? C = 0$ | - | | | - | | REL | 24 | rr | 3 | Instruction Set Instruction Set Summary Table 11-6. Instruction Set Summary (Sheet 2 of 6) | Bilt ref Branch if IRQ Pin High PC ← (PC) + 2 + ref ? IRQ = 1 | Source | Operation | Description | | E<br>on | ffe<br>C | ct<br>CR | } | Address<br>Mode | Opcode | Operand | Cycles | |-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------|---------------------------------------|-------------------------------------------------------------------|----------|----------|----------|----------|----------|----------------------------------------------------------------------|----------------------------------|----------------------------------------------------|-------------------------------------------| | Bilt ref Branch if IRQ Pin High PC ← (PC) + 2 + ref ? IRQ = 1 | Form | - Paramen | | Н | I | N | z | С | Add | obc | Ope | څ | | BIT riopr BIT opr | BIH rel | Branch if IRQ Pin High | PC ← (PC) + 2 + rel ? IRQ = 1 | _ | _ | <u> </u> | | _ | <del> </del> | 2F | <u> </u> | 3 | | Bill ropr Bill ropr | BIL rel | Branch if IRQ Pin Low | $PC \leftarrow (PC) + 2 + rel ? IRQ = 0$ | _ | _ | _ | _ | _ | REL | 2E | rr | 3 | | BLS rel | BIT #opr<br>BIT opr<br>BIT opr<br>BIT opr,X<br>BIT opr,X<br>BIT,X | Bit Test Accumulator with Memory Byte | (A) ∧ (M) | _ | _ | <b>‡</b> | \$ | _ | DIR<br>EXT<br>IX2<br>IX1 | B5<br>C5<br>D5<br>E5 | dd<br>hh II<br>ee ff | | | BMC rel Branch if Interrupt Mask Clear PC ← (PC) + 2 + rel? 1 = 0 — — — — REL 2C rr 3 BMI rel Branch if Minus PC ← (PC) + 2 + rel? 1 = 1 — — — REL 2B rr 2 BMS rel Branch if Interrupt Mask Set PC ← (PC) + 2 + rel? 2 = 1 — — — REL 2D rr 3 BNE rel Branch if Not Equal PC ← (PC) + 2 + rel? 2 N = 0 — — — REL 2D rr 3 BRA rel Branch Always PC ← (PC) + 2 + rel? 1 = 1 — — — REL 20 rr 3 BRCLR n opr rel Branch if Bit n Clear PC ← (PC) + 2 + rel? 1 = 1 — — — REL 20 rr 3 BRN rel Branch if Bit n Clear PC ← (PC) + 2 + rel? 1 = 1 — — — REL 20 rr 3 BRN rel Branch Never PC ← (PC) + 2 + rel? 1 = 1 — — — REL 20 rr 3 BRN rel Branch Never PC ← (PC) + 2 + rel? 1 = 0 — — — REL 20 rr 3 BRN rel Branch if Bit n Set PC ← (PC) + 2 + rel? 1 = 0 — — — REL 20 rr 3 BRN rel Branch if Bit n Set PC ← (PC | BLO rel | Branch if Lower (Same as BCS) | PC ← (PC) + 2 + rel ? C = 1 | _ | _ | _ | _ | _ | REL | 25 | rr | 3 | | BMI rel Branch if Minus PC ← (PC) + 2 + rel? N = 1 − − − REL 25 rr 3 BMS rel Branch if Interrupt Mask Set PC ← (PC) + 2 + rel? I = 1 − − − REL 25 rr 3 BME rel Branch if Not Equal PC ← (PC) + 2 + rel? Z = 0 − − − REL 26 rr 3 BPL rel Branch if Plus PC ← (PC) + 2 + rel? N = 0 − − − REL 26 rr 3 BPR rel Branch if Plus PC ← (PC) + 2 + rel? N = 0 − − − REL 26 rr 3 BPR rel Branch Always PC ← (PC) + 2 + rel? N = 0 − − − REL 20 rr 3 BRCLR n opr rel Branch if Bit n Clear PC ← (PC) + 2 + rel? Mn = 0 − − − PREL 20 rr 3 BRCLR n opr rel Branch if Bit n Clear PC ← (PC) + 2 + rel? Mn = 0 − − − PREL 20 rr 3 BRN rel Branch Never PC ← (PC) + 2 + rel? Nm = 0 − − − REL 20 rr 3 BRN rel Branch if Bit n Set PC ← (PC) + 2 + rel? Nm = 1 − − − − REL 21 rr 3 BRSET n opr rel Branch if Bit n Set PC ← (PC) + 2 + rel? Mn = 1 − − − − REL 21 rr 3 BRSET n opr rel Branch if Bit n Set PC ← (PC) + 2 + rel? Mn = 1 − − − − REL 20 rr 3 BRRSET n opr rel Branch if Bit n Set PC ← (PC) + 2 + rel? Mn = 1 − − − − REL 20 rr 3 BRRSET n opr rel Branch if Bit n Set PC ← (PC) + 2 + rel? Mn = 1 − − − − REL 20 rr 3 BRRSET n opr rel Branch if Bit n Set PC ← (PC) + 2 + rel? Mn = 1 − − − − REL 20 rr 3 BRRSET n opr set Branch if Bit n Set PC ← (PC) + 2 + rel? Mn = 1 − − − − REL 20 rr 3 BRRSET n opr set Branch if Bit n Set PC ← (PC) + 2 + rel? Mn = 1 − − − − REL 20 rr 3 BRRSET n opr set Branch if Bit n Set PC ← (PC) + 2 + rel? Mn = 1 − − − − REL 20 rr 3 BRRSET n opr set Branch if Bit n Set PC ← (PC) + 2 + rel? Mn = 1 − − − − REL 20 rr 3 BRRSET n opr set Branch if Bit n Set PC ← (PC) + 2 + rel? Mn = 1 − − − − − − REL 20 rr 3 BRRSET n opr set Branch if Bit n Set PC ← (PC) + 2 + rel? Mn = 1 − − − − − − − | BLS rel | Branch if Lower or Same | $PC \leftarrow (PC) + 2 + rel? C \lor Z = 1$ | <u> </u> | <u> </u> | _ | _ | <u> </u> | REL | 23 | rr | 3 | | BMS rel Branch if Interrupt Mask Set PC ← (PC) + 2 + rel ? I = 1 — — — — REL 2D rr 3 BNE rel Branch if Not Equal PC ← (PC) + 2 + rel ? Z = 0 — — — REL 26 rr 3 BPL rel Branch if Plus PC ← (PC) + 2 + rel ? N = 0 — — — REL 20 rr 3 BRA rel Branch Always PC ← (PC) + 2 + rel ? N = 0 — — — REL 20 rr 3 BRCLR n opr rel Branch if Bit n Clear PC ← (PC) + 2 + rel ? Mn = 0 — — — REL 20 rr 3 BRN rel Branch if Bit n Clear PC ← (PC) + 2 + rel ? Mn = 0 — — — REL 20 rr 3 BRN rel Branch Never PC ← (PC) + 2 + rel ? Mn = 0 — — — REL 20 rr 3 BRN rel Branch Never PC ← (PC) + 2 + rel ? Mn = 1 — — — REL 21 rr 3 BRSET n opr rel Branch if Bit n Set PC ← (PC) + 2 + rel ? Mn = 1 — — — REL 21 rr 3 BRSET n opr rel Branch if Bit n Set PC ← (PC) + 2 + rel ? Mn = 1 — — — REL 21 rr 3 BRSET n opr rel Branch if Bit n Set PC ← (PC) + 2 + rel ? Mn = 1 — — — REL 21 rr 3 BRSET n opr rel Branch if Bit n Set PC ← (PC) + 2 + rel ? Mn = 1 — — — — PREL 21 rr 3 BRSET n opr rel Branch if Bit n | BMC rel | Branch if Interrupt Mask Clear | PC ← (PC) + 2 + rel? I = 0 | _ | _ | _ | _ | _ | REL | 2C | rr | 3 | | BNE rel Branch if Not Equal PC ← (PC) + 2 + rel ? Z = 0 — — — — REL 26 rr 3 BPL rel Branch if Plus PC ← (PC) + 2 + rel ? N = 0 — — — REL 2A rr 3 BRA rel Branch Always PC ← (PC) + 2 + rel ? N = 1 — — — REL 20 rr 3 BRCLR n opr rel Branch if Bit n Clear PC ← (PC) + 2 + rel ? Mn = 0 — — — REL 20 rr 3 BRN rel Branch if Bit n Clear PC ← (PC) + 2 + rel ? Mn = 0 — — — + DIR (bd) 00 dd rr 3 dd rr 3 3 dd rr 3 DIR (bd) 00 dd rr 3 DIR (bd) 00 dd rr 3 DIR (bd) 00 dd rr 3 DIR (bd) 00 dd rr 3 DIR (bd) 00 dd rr 4 DIR (bd) 00 dd rr 3 10 dd rr 3 DIR (bd) 10 dd rr 3 DIR (bd) 10 dd rr 3 DIR (bd) 10 dd rr 3 DIR (bd) 10 dd rr | BMI rel | Branch if Minus | PC ← (PC) + 2 + rel? N = 1 | _ | _ | _ | _ | _ | REL | 2B | rr | 3 | | BPL rel Branch if Plus PC ← (PC) + 2 + rel? N = 0 REL 2A rr 3 BRA rel Branch Always PC ← (PC) + 2 + rel? 1 = 1 REL 20 rr 3 BRCLR n opr rel Branch if Bit n Clear PC ← (PC) + 2 + rel? Mn = 0 REL 20 rr 3 BRN rel Branch Never PC ← (PC) + 2 + rel? Mn = 0 REL 20 rr 3 BRN rel Branch Never PC ← (PC) + 2 + rel? 1 = 0 REL 21 rr 3 BRSET n opr rel Branch if Bit n Set PC ← (PC) + 2 + rel? Mn = 1 REL 21 rr 3 BRSET n opr rel Branch if Bit n Set PC ← (PC) + 2 + rel? Mn = 1 REL 21 rr 3 BRSET n opr rel Branch if Bit n Set PC ← (PC) + 2 + rel? Mn = 1 REL 21 rr 3 BRSET n opr rel Branch if Bit n Set PC ← (PC) + 2 + rel? Mn = 1 REL 21 rr 3 BRSET n opr rel Branch if Bit n Set PC ← (PC) + 2 + rel? Mn = 1 REL 21 rr 3 BRSET n opr Set Bit n Mn ← 1 REL 21 rr 3 < | BMS rel | Branch if Interrupt Mask Set | PC ← (PC) + 2 + rel? I = 1 | - | <u> </u> | <u> </u> | _ | <u> </u> | REL | 2D | rr | 3 | | BRA rel Branch Always PC ← (PC) + 2 + rel? 1 = 1 REL 20 rr 3 BRCLR n opr rel Branch if Bit n Clear PC ← (PC) + 2 + rel? Mn = 0 Din (Rob) 01 dd rr 5 Din (Rob) 01 dd rr 5 Din (Rob) 02 dd rr 5 Din (Rob) 07 dd rr 6 Din (Rob) 07 dd rr 6 Din (Rob) 07 dd rr 6 Din (Rob) 07 dd rr 6 Din (Rob) 07 dd rr 6 Din (Rob) 07 dd rr 6 Din (Rob) 08 dd rr 6 Din (Rob) 00 dr | BNE rel | Branch if Not Equal | $PC \leftarrow (PC) + 2 + rel ? Z = 0$ | _ | _ | _ | _ | _ | REL | 26 | rr | 3 | | BRCLR n opr rel Branch if Bit n Clear PC ← (PC) + 2 + rel? Mn = 0 PC ← (PC) + 2 + rel? Mn = 0 DIR (b0) 01 dd rr E DIR (b2) 05 dd rr E DIR (b2) 05 dd rr E DIR (b3) 07 dd rr E DIR (b5) 0B dd rr E DIR (b5) 0B dd rr E DIR (b5) 0B dd rr E DIR (b5) 0B dd rr E DIR (b5) 0B dd rr E DIR (b6) 0D dd rr E DIR (b7) 0F | BPL rel | Branch if Plus | PC ← (PC) + 2 + rel ? N = 0 | _ | _ | _ | _ | _ | REL | 2A | rr | 3 | | BRCLR n opr rel Branch if Bit n Clear PC ← (PC) + 2 + rel? Mn = 0 PC ← (PC) + 2 + rel? Mn = 0 DIR (b1) 03 dd rr 2 DIR (b3) 05 DIR (b3) 07 DIR (b4) 09 dd rr 2 DIR (b5) 0B dd rr 2 DIR (b5) 0B dd rr 2 DIR (b6) 0D DIR (b7) 0F dd rr 2 | BRA rel | Branch Always | PC ← (PC) + 2 + rel? 1 = 1 | _ | _ | <u> </u> | = | _ | REL | 20 | rr | 3 | | BRSET n opr rel Branch if Bit n Set PC ← (PC) + 2 + rel? Mn = 1 PC ← (PC) + 2 + rel? Mn = 1 DIR (b0) 00 dd rr EDIR (b1) 02 dd rr EDIR (b2) 04 dd rr EDIR (b3) 06 dd rr EDIR (b4) 08 dd rr EDIR (b5) 0A | BRCLR n opr rel | Branch if Bit n Clear | PC ← (PC) + 2 + <i>rel</i> ? Mn = 0 | | _ | _ | | <b>‡</b> | DIR (b1)<br>DIR (b2)<br>DIR (b3)<br>DIR (b4)<br>DIR (b5)<br>DIR (b6) | 03<br>05<br>07<br>09<br>0B<br>0D | dd rr<br>dd rr<br>dd rr<br>dd rr<br>dd rr<br>dd rr | 5<br>5<br>5<br>5<br>5<br>5 | | BRSET n opr rel Branch if Bit n Set PC ← (PC) + 2 + rel? Mn = 1 PC ← (PC) + 2 + rel? Mn = 1 DIR (b1) 02 dd rr 5 DIR (b3) 06 dd rr 5 DIR (b5) 0A dd rr 5 DIR (b6) 0C dd rr 5 DIR (b6) 0C dd rr 5 DIR (b7) 0E dd rr 5 DIR (b7) 0E dd rr 5 DIR (b7) 0E dd rr 5 DIR (b7) 0E dd rr 5 DIR (b7) 0E dd rr 5 DIR (b1) 12 dd 5 DIR (b2) 14 dd 5 DIR (b2) 14 dd 5 DIR (b3) 16 dd 5 DIR (b3) 16 dd 5 DIR (b3) 16 dd 5 DIR (b3) 16 dd 5 DIR (b3) 16 dd 5 DIR (b5) 1A dd 5 DIR (b6) 1C dd 5 DIR (b7) 1E | BRN rel | Branch Never | PC ← (PC) + 2 + rel? 1 = 0 | _ | _ | _ | _ | _ | REL | 21 | rr | 3 | | BSET $n \ opr$ Set Bit n | BRSET n opr rel | Branch if Bit n Set | PC ← (PC) + 2 + <i>rel</i> ? Mn = 1 | | _ | _ | | <b>‡</b> | DIR (b1)<br>DIR (b2)<br>DIR (b3)<br>DIR (b4)<br>DIR (b5)<br>DIR (b6) | 02<br>04<br>06<br>08<br>0A<br>0C | dd rr<br>dd rr<br>dd rr<br>dd rr<br>dd rr<br>dd rr | 5<br>5<br>5<br>5<br>5<br>5 | | BSR $rel$ Branch to Subroutine $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$ | BSET n opr | Set Bit n | Mn ← 1 | | _ | _ | | _ | DIR (b1)<br>DIR (b2)<br>DIR (b3)<br>DIR (b4)<br>DIR (b5)<br>DIR (b6) | 12<br>14<br>16<br>18<br>1A<br>1C | dd<br>dd<br>dd<br>dd<br>dd<br>dd | 5<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5 | | | BSR rel | Branch to Subroutine | $SP \leftarrow (SP) - 1$ ; push (PCH)<br>$SP \leftarrow (SP) - 1$ | | | _ | _ | | REL | AD | rr | 6 | | CLI Clear Interrupt Mask I ← 0 — 0 — — INH 9A 2 | CLC | Clear Carry Bit | C ← 0 | _ | _ | _ | _ | 0 | INH | 98 | | 2 | | | CLI | Clear Interrupt Mask | 1 ← 0 | <u> </u> | 0 | _ | _ | <u> </u> | INH | 9A | | 2 | MC68HC705K1 — Rev. 2.0 Table 11-6. Instruction Set Summary (Sheet 3 of 6) | Source | Operation | Description | Effect on CCR | | | | | Address<br>Mode | Opcode | Operand | Cycles | |--------------------------------------------------------------------|-------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|---|----------|----------|----------|---------------------------------------|----------------------------------|----------------------------------|----------------------------| | Form | operane. | 2 3 3 3 7 1 1 1 | Н | I | N | z | С | Add | odo | Ope | င် | | CLR opr<br>CLRA<br>CLRX<br>CLR opr,X<br>CLR ,X | Clear Byte | M ← \$00<br>A ← \$00<br>X ← \$00<br>M ← \$00<br>M ← \$00 | _ | _ | 0 | 1 | _ | DIR<br>INH<br>INH<br>IX1<br>IX | 3F<br>4F<br>5F<br>6F<br>7F | dd<br>ff | 5<br>3<br>3<br>6<br>5 | | CMP #opr<br>CMP opr<br>CMP opr<br>CMP opr,X<br>CMP opr,X<br>CMP ,X | Compare Accumulator with Memory Byte | (A) – (M) | _ | _ | <b>‡</b> | <b>‡</b> | <b>1</b> | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX | A1<br>B1<br>C1<br>D1<br>E1 | ii<br>dd<br>hh II<br>ee ff<br>ff | 2<br>3<br>4<br>5<br>4<br>3 | | COM opr<br>COMA<br>COMX<br>COM opr,X<br>COM ,X | Complement Byte (One's Complement) | $\begin{aligned} M &\leftarrow (\overline{M}) = \$FF - (M) \\ A &\leftarrow (\overline{A}) = \$FF - (A) \\ X &\leftarrow (\overline{X}) = \$FF - (X) \\ M &\leftarrow (\overline{M}) = \$FF - (M) \\ M &\leftarrow (\overline{M}) = \$FF - (M) \end{aligned}$ | _ | _ | <b>‡</b> | <b>‡</b> | 1 | DIR<br>INH<br>INH<br>IX1<br>IX | 33<br>43<br>53<br>63<br>73 | dd<br>ff | 5<br>3<br>3<br>6<br>5 | | CPX #opr<br>CPX opr<br>CPX opr<br>CPX opr,X<br>CPX opr,X<br>CPX ,X | Compare Index Register with Memory Byte | (X) – (M) | _ | | <b>‡</b> | <b>‡</b> | <b>‡</b> | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX | A3<br>B3<br>C3<br>D3<br>E3<br>F3 | ii<br>dd<br>hh II<br>ee ff<br>ff | 2<br>3<br>4<br>5<br>4<br>3 | | DEC opr<br>DECA<br>DECX<br>DEC opr,X<br>DEC ,X | Decrement Byte | $M \leftarrow (M) - 1$<br>$A \leftarrow (A) - 1$<br>$X \leftarrow (X) - 1$<br>$M \leftarrow (M) - 1$<br>$M \leftarrow (M) - 1$ | _ | _ | <b>‡</b> | <b>‡</b> | _ | DIR<br>INH<br>INH<br>IX1<br>IX | 3A<br>4A<br>5A<br>6A<br>7A | dd<br>ff | 5<br>3<br>6<br>5 | | EOR #opr<br>EOR opr<br>EOR opr,X<br>EOR opr,X<br>EOR ,X | EXCLUSIVE OR Accumulator with Memory Byte | $A \leftarrow (A) \oplus (M)$ | _ | | <b>‡</b> | <b>‡</b> | _ | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX | A8<br>B8<br>C8<br>D8<br>E8<br>F8 | ii<br>dd<br>hh II<br>ee ff<br>ff | 2<br>3<br>4<br>5<br>4<br>3 | | INC opr<br>INCA<br>INCX<br>INC opr,X<br>INC ,X | Increment Byte | $M \leftarrow (M) + 1$ $A \leftarrow (A) + 1$ $X \leftarrow (X) + 1$ $M \leftarrow (M) + 1$ $M \leftarrow (M) + 1$ | _ | | <b>‡</b> | <b>‡</b> | _ | DIR<br>INH<br>INH<br>IX1<br>IX | 3C<br>4C<br>5C<br>6C<br>7C | dd<br>ff | 5<br>3<br>6<br>5 | | JMP opr<br>JMP opr<br>JMP opr,X<br>JMP opr,X<br>JMP ,X | Unconditional Jump | PC ← Jump Address | _ | _ | | | _ | DIR<br>EXT<br>IX2<br>IX1<br>IX | BC<br>CC<br>DC<br>EC<br>FC | dd<br>hh II<br>ee ff<br>ff | | Instruction Set Instruction Set Summary Table 11-6. Instruction Set Summary (Sheet 4 of 6) | Source | Operation | Description | | E<br>on | ffe | | } | Address<br>Mode | Opcode | Operand | Cycles | |----------------------------------------------------------------------|--------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---------|----------|----------|----------|---------------------------------------|----------------------------------|----------------------------------|----------------------------| | Form | operation. | 2000 | Н | I | N | Z | С | Add | odo | Ope | င် | | JSR opr<br>JSR opr<br>JSR opr,X<br>JSR opr,X<br>JSR ,X | Jump to Subroutine | $PC \leftarrow (PC) + n \ (n = 1, 2, \text{ or } 3)$ $Push \ (PCL); SP \leftarrow (SP) - 1$ $Push \ (PCH); SP \leftarrow (SP) - 1$ $PC \leftarrow Effective \ Address$ | _ | | _ | | _ | DIR<br>EXT<br>IX2<br>IX1<br>IX | BD<br>CD<br>DD<br>ED<br>FD | dd<br>hh II<br>ee ff<br>ff | 5<br>6<br>7<br>6<br>5 | | LDA #opr<br>LDA opr<br>LDA opr,X<br>LDA opr,X<br>LDA opr,X<br>LDA ,X | Load Accumulator with Memory Byte | A ← (M) | _ | | <b>‡</b> | <b>‡</b> | _ | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX | A6<br>B6<br>C6<br>D6<br>E6<br>F6 | ii<br>dd<br>hh II<br>ee ff<br>ff | 2<br>3<br>4<br>5<br>4<br>3 | | LDX #opr<br>LDX opr<br>LDX opr<br>LDX opr,X<br>LDX opr,X<br>LDX ,X | Load Index Register with Memory Byte | X ← (M) | _ | | <b>‡</b> | <b>‡</b> | _ | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX | AE<br>BE<br>CE<br>DE<br>EE<br>FE | | 2<br>3<br>4<br>5<br>4<br>3 | | LSL opr<br>LSLA<br>LSLX<br>LSL opr,X<br>LSL ,X | Logical Shift Left (Same as ASL) | C 0 b7 b0 | _ | | <b>‡</b> | <b>‡</b> | <b>‡</b> | DIR<br>INH<br>INH<br>IX1<br>IX | 38<br>48<br>58<br>68<br>78 | dd<br>ff | 5<br>3<br>6<br>5 | | LSR opr<br>LSRA<br>LSRX<br>LSR opr,X<br>LSR ,X | Logical Shift Right | 0 - C b0 b0 | _ | | 0 | <b>‡</b> | <b>‡</b> | DIR<br>INH<br>INH<br>IX1<br>IX | 34<br>44<br>54<br>64<br>74 | dd<br>ff | 5<br>3<br>6<br>5 | | MUL | Unsigned Multiply | $X : A \leftarrow (X) \times (A)$ | 0 | _ | _ | _ | 0 | INH | 42 | | 1 | | NEG opr<br>NEGA<br>NEGX<br>NEG opr,X<br>NEG ,X | Negate Byte (Two's Complement) | $\begin{array}{c} M \leftarrow -(M) = \$00 - (M) \\ A \leftarrow -(A) = \$00 - (A) \\ X \leftarrow -(X) = \$00 - (X) \\ M \leftarrow -(M) = \$00 - (M) \\ M \leftarrow -(M) = \$00 - (M) \end{array}$ | _ | | <b>‡</b> | <b>‡</b> | <b>‡</b> | DIR<br>INH<br>INH<br>IX1<br>IX | 30<br>40<br>50<br>60<br>70 | dd<br>ff | 5<br>3<br>6<br>5 | | NOP | No Operation | | - | _ | _ | _ | _ | INH | 9D | | 2 | | ORA #opr<br>ORA opr<br>ORA opr<br>ORA opr,X<br>ORA opr,X<br>ORA ,X | Logical OR Accumulator with Memory | $A \leftarrow (A) \vee (M)$ | _ | _ | <b>‡</b> | <b>‡</b> | _ | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX | AA<br>BA<br>CA<br>DA<br>EA<br>FA | ii<br>dd<br>hh II<br>ee ff<br>ff | 2<br>3<br>4<br>5<br>4<br>3 | | ROL opr<br>ROLA<br>ROLX<br>ROL opr,X<br>ROL ,X | Rotate Byte Left through Carry Bit | b7 b0 | _ | _ | <b>‡</b> | <b>‡</b> | <b>‡</b> | DIR<br>INH<br>INH<br>IX1<br>IX | 39<br>49<br>59<br>69<br>79 | dd<br>ff | 5<br>3<br>6<br>5 | MC68HC705K1 — Rev. 2.0 Table 11-6. Instruction Set Summary (Sheet 5 of 6) | Source | Operation | Description | | E<br>on | ffe<br>C | ct<br>CR | 2 | Address<br>Mode | Opcode | Operand | Cycles | |--------------------------------------------------------------------|-----------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|----------|----------|----------|----------|---------------------------------------|----------------------------------|----------------------------------|----------------------------| | Form | Сроманон | 2000. | Н | I | N | z | С | Add | odo | Ope | င် | | ROR opr<br>RORA<br>RORX<br>ROR opr,X<br>ROR ,X | Rotate Byte Right through Carry Bit | b7 b0 | _ | _ | <b>‡</b> | <b>‡</b> | <b>‡</b> | DIR<br>INH<br>INH<br>IX1<br>IX | 36<br>46<br>56<br>66<br>76 | dd<br>ff | 5<br>3<br>6<br>5 | | RSP | Reset Stack Pointer | SP ← \$00FF | _ | _ | _ | _ | _ | INH | 9C | | 2 | | RTI | Return from Interrupt | $\begin{array}{c} SP \leftarrow (SP) + 1; Pull (CCR) \\ SP \leftarrow (SP) + 1; Pull (A) \\ SP \leftarrow (SP) + 1; Pull (X) \\ SP \leftarrow (SP) + 1; Pull (PCH) \\ SP \leftarrow (SP) + 1; Pull (PCL) \end{array}$ | <b>‡</b> | <b>‡</b> | <b>‡</b> | <b>‡</b> | <b>‡</b> | INH | 80 | | 9 | | RTS | Return from Subroutine | $SP \leftarrow (SP) + 1$ ; Pull (PCH)<br>$SP \leftarrow (SP) + 1$ ; Pull (PCL) | _ | - | _ | _ | _ | INH | 81 | | 6 | | SBC #opr<br>SBC opr<br>SBC opr<br>SBC opr,X<br>SBC opr,X<br>SBC ,X | Subtract Memory Byte and Carry Bit from Accumulator | $A \leftarrow (A) - (M) - (C)$ | _ | _ | \$ | \$ | <b>‡</b> | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX | A2<br>B2<br>C2<br>D2<br>E2<br>F2 | ii<br>dd<br>hh II<br>ee ff<br>ff | 2<br>3<br>4<br>5<br>4<br>3 | | SEC | Set Carry Bit | C ← 1 | _ | _ | _ | _ | 1 | INH | 99 | | 2 | | SEI | Set Interrupt Mask | I ← 1 | _ | 1 | _ | _ | <u> </u> | INH | 9B | | 2 | | STA opr<br>STA opr<br>STA opr,X<br>STA opr,X<br>STA ,X | Store Accumulator in Memory | M ← (A) | _ | _ | <b>‡</b> | <b>‡</b> | _ | DIR<br>EXT<br>IX2<br>IX1<br>IX | B7<br>C7<br>D7<br>E7<br>F7 | dd<br>hh II<br>ee ff<br>ff | 4<br>5<br>6<br>5<br>4 | | STOP | Stop Oscillator and Enable IRQ Pin | | _ | 0 | _ | _ | _ | INH | 8E | | 2 | | STX opr<br>STX opr<br>STX opr,X<br>STX opr,X<br>STX ,X | Store Index Register In Memory | M ← (X) | | _ | <b>‡</b> | <b>‡</b> | _ | DIR<br>EXT<br>IX2<br>IX1<br>IX | BF<br>CF<br>DF<br>EF<br>FF | dd<br>hh II<br>ee ff<br>ff | 4<br>5<br>6<br>5<br>4 | | SUB #opr<br>SUB opr<br>SUB opr<br>SUB opr,X<br>SUB opr,X<br>SUB ,X | Subtract Memory Byte from Accumulator | A ← (A) − (M) | | _ | <b>‡</b> | <b>‡</b> | <b>‡</b> | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX | A0<br>B0<br>C0<br>D0<br>E0<br>F0 | ii<br>dd<br>hh II<br>ee ff<br>ff | 2<br>3<br>4<br>5<br>4<br>3 | | SWI | Software Interrupt | $\begin{array}{c} \text{PC} \leftarrow (\text{PC}) + 1; \text{Push (PCL)} \\ \text{SP} \leftarrow (\text{SP}) - 1; \text{Push (PCH)} \\ \text{SP} \leftarrow (\text{SP}) - 1; \text{Push (X)} \\ \text{SP} \leftarrow (\text{SP}) - 1; \text{Push (A)} \\ \text{SP} \leftarrow (\text{SP}) - 1; \text{Push (CCR)} \\ \text{SP} \leftarrow (\text{SP}) - 1; \text{I} \leftarrow 1 \\ \text{PCH} \leftarrow \text{Interrupt Vector High Byte} \\ \text{PCL} \leftarrow \text{Interrupt Vector Low Byte} \\ \end{array}$ | | 1 | _ | | _ | INH | 83 | | 1 0 | | TAX | Transfer Accumulator to Index Register | X ← (A) | _ | _ | _ | _ | _ | INH | 97 | | 2 | Instruction Set Opcode Map Table 11-6. Instruction Set Summary (Sheet 6 of 6) | Source<br>Form | Operation | Description | Effect on CCR | | | | | ddress | pcode | Operand | Cycles | |------------------------------------------------|----------------------------------------|--------------------|---------------|---|----------|----------|---|--------------------------------|----------------------------|----------|-----------------------| | Form | · | · | Н | I | N | Z | С | Ado | o | obe | ပ် | | TST opr<br>TSTA<br>TSTX<br>TST opr,X<br>TST ,X | Test Memory Byte for Negative or Zero | (M) – \$00 | _ | | <b>1</b> | <b>1</b> | _ | DIR<br>INH<br>INH<br>IX1<br>IX | 3D<br>4D<br>5D<br>6D<br>7D | dd<br>ff | 4<br>3<br>3<br>5<br>4 | | TXA | Transfer Index Register to Accumulator | $A \leftarrow (X)$ | - | - | - | _ | - | INH | 9F | | 2 | | WAIT | Stop CPU Clock and Enable Interrupts | | | 0 | | - | - | INH | 8F | | 2 | | Α | Accumulator | opr | Operand (one or two bytes) | |-------|---------------------------------------------------------------------|--------------|--------------------------------------| | С | Carry/borrow flag | PC | Program counter | | CCR | Condition code register | PCH | Program counter high byte | | dd | Direct address of operand | PCL | Program counter low byte | | dd rr | Direct address of operand and relative offset of branch instruction | REL | Relative addressing mode | | DIR | Direct addressing mode | rel | Relative program counter offset byte | | ee ff | High and low bytes of offset in indexed, 16-bit offset addressing | rr | Relative program counter offset byte | | EXT | Extended addressing mode | SP | Stack pointer | | ff | Offset byte in indexed, 8-bit offset addressing | Χ | Index register | | Н | Half-carry flag | Z | Zero flag | | hh II | High and low bytes of operand address in extended addressing | # | Immediate value | | 1 | Interrupt mask | ^ | Logical AND | | ii | Immediate operand byte | <b>V</b> | Logical OR | | IMM | Immediate addressing mode | $\oplus$ | Logical EXCLUSIVE OR | | INH | Inherent addressing mode | () | Contents of | | IX | Indexed, no offset addressing mode | -( ) | Negation (two's complement) | | IX1 | Indexed, 8-bit offset addressing mode | $\leftarrow$ | Loaded with | | IX2 | Indexed, 16-bit offset addressing mode | ? | If | | M | Memory location | : | Concatenated with | | N | Negative flag | <b>‡</b> | Set or cleared | | n | Any bit | _ | Not affected | # 11.6 Opcode Map See **Table 11-7**. # **Instruction Set** | Q | |-----------------------| | $\boldsymbol{\sigma}$ | | ⋝ | | _ | | <u> </u> | | Š | | × | | × | | ≍ | | O | | | | <u>`</u> | | $\overline{}$ | | $\overline{}$ | | Φ | | Ť | | 쑱 | | ╩ | | | | | | | MSB | 0 | - | 2 | က | 4 | 5 | 9 | 7 | œ | 6 | ∢ | М | ပ | ۵ | ш | ш | | |------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-----|----------------|-------------------|-------------------|---------------|-------------------|----------------------------|----------------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|--------------------|----------------------------------------------------------------------------------------------------------| | | | IX | ь | 3<br>SUB<br>X | CMP 3 | SBC IX | CPX 3 | 3<br>AND 1 | BIT IX | 3<br>LDA IX | STA IX | BOR IX | ADC IX | ORA IX | 3<br>ADD X | JMP 2 | S<br>JSR<br>1 | 3<br>LDX 1X | STX IX | la e | | | | IX1 | ш | SUB IX1 | CMP IX1 | SBC 4 | | AND X | BIT 4 | LDA X1 | STA IX1 | EOR 1X1 | | | | JMP 1X1 | JSR IX1 | LDX 4 | STX 5 | lexadecim | | | Memory | IX2 | ٥ | SUB 1X2 2 | CMP 5 IX2 2 | SBC 5 | CPX 5 IX2 2 | AND 5 | BIT 5 | LDA IX2 2 | STA 1X2 2 | EOR 5 | ADC 5 | ORA IX2 2 | ADD 5 | JMP 4 | JSR 7 | LDX 5 | STX 6 | MSB of Opcode in Hexadecimal<br>Number of Cycles<br>Opcode Mnemonic<br>Number of Bytes/Addressing Mode | | | Register/Memory | EXT | ပ | | | | | | | LDA EXT 3 | STA EXT 3 | | | ORA<br>EXT 3 | | | l | | | MSB of Opcode in Hexadecims Number of Cycles Opcode Mnemonic Number of Bytes/Addressing Mode | | | | DIR | В | SUB DIR 3 | CMP 3 | SBC 3 | CPX DIR 3 | AND DIR 3 | | LDA<br>DIR 3 | | EOR DIR 3 | ADC DIR 3 | ORA<br>DIR 3 | | JMP DIR 3 | JSR 5<br>DIR 3 | | l | 0<br>BRSETO<br>DIR | | | MM SBC SUB | | | | | | | | | | | 1 | | | | | | | | | | Мар | ō | INH | 6 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | TAX 2 | CLC 2 | SEC 2 INH 2 | CLI 2 INH 2 | SEI 2 INH 2 | RSP 2 | NOP 2<br>INH 2 | 2 | TXA 2 | | | pcode | Control | INH | ∞ | RTI 9 | RTS 6 | | 3WI<br>INH | | | | - | - | - | - | - | - | - | STOP 2 | WAIT 2 | LSB of Opcode in Hexadecimal | | 1-7. 0 | | × | 7 | NEG 1X 1 | 1 | | COM 5 | LSR IX | | ROR IX | ASR IX | ASL/LSL<br>1 | ROL IX | DEC 5 | | INC 55 | 4 TST X | - | CLR 5 | B of Opco | | Table 11-7. Opcode Map | ite | IX1 | 9 | NEG IX1 1 | | | COM IX1 1 | LSR<br>IX1 | | ROR<br>IX1 | ASR<br>IX1 | ASL/LSL / | ROL IX1 1 | DEC IX1 1 | | INC 6 | TST 1 | | CLR 6 | | | • | Read-Modify-Write | INH | 2 | NEGX 3 | | | COMX INH 2 | LSRX INH 2 | | RORX INH 2 | ASRX INH 2 | $\frac{3}{\text{SLX/LSLX}}/4$ | ROLX INH 2 | DECX INH 2 | | INCX 3 | TSTX<br>INH 2 | | CLRX 3 | et<br>set | | | Read-I | INH | 4 | NEGA<br>INH 1 | | MUL<br>INH | COMA<br>INH 1 | LSRA<br>INH 1 | | RORA<br>INH 1 | ASRA INH 1 | $\begin{array}{c c} 3 & 3 \\ ASLA/LSLA & ASLX/LSLX \\ 1 & INH \\ 1 & INH \\ 2 & INH \\ 3 & INH \\ 4 & INH \\ 4 & INH \\ 4 & INH \\ 5 & INH \\ 6 & INH \\ 7 & INH \\ 7 & INH \\ 7 & INH \\ 9 & INH \\ 9 & INH \\ 9 & INH \\ 1 & INH \\ 9 & INH \\ 9 & INH \\ 1 2 & INH \\ 2 & INH \\ 3 & INH \\ 4 & INH \\ 4 & INH \\ 5 & INH \\ 6 & INH \\ 6 & INH \\ 6 & INH \\ 6 & INH \\ 7 & INH \\ 7 & INH \\ 8 & INH \\ 9 I$ | ROLA INH 1 | DECA INH 1 | | INCA INH 1 | TSTA INH 1 | | 3<br>CLRA<br>INH 1 | No Offset<br>8-Bit Offs<br>16-Bit Off | | | | DIR | က | NEG 5 | | - | COM DIR 1 | LSR<br>DIR 1 | | ROR DIR 1 | ASR<br>DIR 1 | ASL/LSL A | ROL<br>DIR 1 | DEC 5 | | INC 5 | TST<br>DIR 1 | | CLR<br>DIR 1 | REL = Relative<br>IX = Indexed, No Offset<br>IX1 = Indexed, 8-Bit Offset<br>IX2 = Indexed, 16-Bit Offset | | | Tands RE RE RE RE RE RE RE R | | | | | | | | | | | | | | | | | | | | | | $\vdash$ | DIR | - | BSET0<br>DIR 2 | BCLR0<br>BCLR0 | BSET1 | BCLR1 | BSET2<br>DIR 2 | BCLR2 BCS/BLO<br>DIR 2 REL | BSET3<br>DIR 2 | BCLR3<br>DIR 2 | SSET4 DIR 2 | 3CLR4<br>DIR 2 | BSET5 | BCLR5 | BSET6<br>DIR 2 | BCLR6<br>2 DIR 2 | BSET7 | BCLR7 | ent<br>ediate<br>:t<br>nded | | | Bit Manipulation | DIR | 0 | RSETO<br>DIR 2 | BRCLR0<br>3 DIR 2 | BRSET1<br>3 DIR 2 | BRCLR1 | BRSET2<br>3 DIR 2 | BRCLR2<br>3 DIR 2 | BRSET3 18 2 3 | BRCLR3<br>3 DIR 2 | BRSET4 E | BRCLR4<br>3 DIR 2 | BRSET5<br>3 DIR 2 | BRCLR5<br>3 DIR 2 | BRSET6<br>3 DIR 2 | BRCLR6<br>3 DIR 2 | BRSET7<br>3 DIR 2 | BRCLR7<br>3 DIR 2 | INH = Inherent IMM = Immediate DIR = Direct EXT = Extended | | | | | MSB | 0 3 B | <b>1</b> | <b>2</b> | <b>8</b> | 4 | <b>5</b> | 9 | 7 B | <b>8</b> | 6 | <b>√</b> | <b>a</b> | ပ | ۵ | ш | ±<br>L | = = U W | | Techni | echnical Data MC68HC705K1 — Rev. 2.0 | | | | | | | | | | | | | | | | | | | | ### Technical Data — MC68HC705K1 # **Section 12. Electrical Specifications** #### 12.1 Contents | 12.2 | Introduction117 | |-------|-------------------------------------------| | 12.3 | Maximum Ratings118 | | 12.4 | Operating Temperature Range118 | | 12.5 | Thermal Characteristics | | 12.6 | Power Considerations | | 12.7 | Equivalent Pin Loading120 | | 12.8 | 5.0-Volt DC Electrical Characteristics121 | | 12.9 | 3.3-Volt DC Electrical Characteristics122 | | 12.10 | 5.0-Volt Control Timing126 | | 12.11 | 3.3-Volt Control Timing | | 12.12 | Typical Oscillator Characteristics | ### 12.2 Introduction This section contains electrical and timing specifications. MC68HC705K1 — Rev. 2.0 ### **Electrical Specifications** ### 12.3 Maximum Ratings Maximum ratings are the extreme limits to which the MCU can be exposed without permanently damaging it. The MCU contains circuitry to protect the inputs against damage from high static voltages; however, do not apply voltages higher than those shown in the table here. Keep $V_{ln}$ and $V_{Out}$ within the range $V_{SS} \leq (V_{ln} \text{ or } V_{Out}) \leq V_{DD}$ . Connect unused inputs to the appropriate voltage level, either $V_{SS}$ or $V_{DD}$ . | Rating <sup>(1)</sup> | Symbol | Value | Unit | |---------------------------------------------------------------------|------------------|-------------------------------------------------|------| | Supply voltage | V <sub>DD</sub> | -0.3 to +7.0 | V | | Input voltage | V <sub>In</sub> | V <sub>SS</sub> -0.3<br>to V <sub>DD</sub> +0.3 | V | | EPROM programming voltage | V <sub>PP</sub> | V <sub>DD</sub> –0.3 to<br>16.0 | | | Current drain per pin excluding V <sub>DD</sub> and V <sub>SS</sub> | I | 25 | mA | | Storage temperature range | T <sub>STG</sub> | -65 to +150 | °C | Voltages referenced to V<sub>SS</sub> #### **NOTE:** This device is not guaranteed to operate properly at the maximum ratings. Refer to 12.8 5.0-Volt DC Electrical Characteristics and 12.9 3.3-Volt DC Electrical Characteristics for guaranteed operating conditions. ### 12.4 Operating Temperature Range | Rating <sup>(1)</sup> | Symbol | Value | Unit | |---------------------------------------------------------------------------------------|----------------|------------------------------------------------|------| | Operating temperature range <sup>(2)</sup> MC68HC705K1P, DW, S MC68HC705K1CP, CDW, CS | T <sub>A</sub> | T <sub>L</sub> to T <sub>H</sub><br>-40 to +85 | °C | - 1. Voltages referenced to V<sub>SS</sub> - 2. P = Plastic dual in-line package (PDIP) - DW = Small outline integrated circuit (SOIC) - S = Ceramic dual in-line package (cerdip) - C = Extended temperature range ( $-40^{\circ}$ C to $+85^{\circ}$ C) Electrical Specifications Thermal Characteristics #### 12.5 Thermal Characteristics | Characteristic | Symbol | Value | Unit | |-----------------------------------------------------------------------------|-----------------------|------------|------| | Maximum junction temperature | TJ | 150 | °C | | Thermal resistance MC68HC705K1P <sup>(1)</sup> MC68HC705K1DW <sup>(2)</sup> | $\theta_{ extsf{JA}}$ | 100<br>140 | °C/W | <sup>1.</sup> P = Plastic dual in-line package (PDIP) ### 12.6 Power Considerations The average chip junction temperature, T<sub>J</sub>, in °C can be obtained from: $$T_{J} = T_{A} + (P_{D} \times \theta_{JA}) \tag{1}$$ Where: $T_A$ = ambient temperature in °C $\theta_{JA}$ = package thermal resistance, junction to ambient in °C/W $$P_D = P_{INT} + P_{I/O}$$ $P_{INT} = I_{CC} \times V_{CC}$ = chip internal power dissipation P<sub>I/O</sub> = power dissipation on input and output pins (user-determined) For most applications, P<sub>I/O</sub> < P<sub>INT</sub> and can be neglected. Ignoring $P_{I/O}$ , the relationship between $P_D$ and $T_J$ is approximately: $$P_{D} = \frac{K}{T_{J} + 273^{\circ}C}$$ (2) Solving equations (1) and (2) for K gives: $$= P_D x (T_A + 273^{\circ}C) + \theta_{JA} x (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 $P_D$ and $P_D$ and by solving equations (1) and (2) iteratively for any value of $P_D$ . MC68HC705K1 — Rev. 2.0 <sup>2.</sup> DW = Small outline integrated circuit (SOIC) # **Electrical Specifications** ### 12.7 Equivalent Pin Loading Figure 12-1 shows the equivalent input/output (I/O) pin loading for test purposes. | PINS | V <sub>DD</sub> | R1 | R2 | С | |------------------|-----------------|----------|---------|-------| | PA3-PA0, PB1-PB0 | 4.5 V | 3.26 kΩ | 2.38 kΩ | 50 pF | | PA7-PA4 | 4.5 V | 470 Ω | 2.38 kΩ | 50 pF | | PA3-PA0, PB1-PB0 | 3.0 V | 10.91 kΩ | 6.32 kΩ | 50 pF | Figure 12-1. Equivalent Test Load **Electrical Specifications** 5.0-Volt DC Electrical Characteristics #### 12.8 5.0-Volt DC Electrical Characteristics | Characteristic <sup>(1)</sup> | Symbol | Min | Typ <sup>(2)</sup> | Max | Unit | |-----------------------------------------------------------|------------------|-----------------------|--------------------|-----------------------|------| | Output voltage | | | | | | | $I_{Load} = 10.0 \mu\text{A}$ | V <sub>OL</sub> | | _ | 0.1 | V | | $I_{Load} = -10.0 \mu\text{A}$ | V <sub>OH</sub> | V <sub>DD</sub> – 0.1 | | | | | Output high voltage, I <sub>Load</sub> = -0.8 mA | V <sub>OH</sub> | V <sub>DD</sub> – 0.8 | | | V | | PA7-PA0, PB1/OSC3, PB0 | - 011 | . 00 0.0 | | | • | | Output low voltage | ., | | | | | | I <sub>Load</sub> = 1.6 mA, PA3–PA0, PB1/OSC3, PB0 | V <sub>OL</sub> | _ | _ | 0.4 | V | | I <sub>Load</sub> = 8.0 mA, PC7–PC4 | | _ | _ | 0.4 | | | Input high voltage | V <sub>IH</sub> | 0.7 x V <sub>DD</sub> | _ | $V_{DD}$ | V | | PA7-PA0, PB1/OSC3, PB0, IRQ/V <sub>PP</sub> , RESET, OSC1 | "" | - 00 | | טט | | | Input low voltage | VII | V <sub>SS</sub> | _ | 0.2 x V <sub>DD</sub> | V | | PA7–PA0, PB1/OSC3, PB0, IRQ/V <sub>PP</sub> , RESET, OSC1 | 15 | 00 | | | - | | Supply current | | | | | | | Run <sup>(3)</sup> | | _ | 2.6 | _ | mA | | Wait <sup>(4)</sup> | , | _ | 0.9 | _ | mA | | Stop <sup>(5)</sup> | I <sub>DD</sub> | | 200 | | nA | | 25°C | | _ | 700 | _ | nA | | 0°C to +70°C (standard)<br>-40°C to +85°C (extended) | | | 1000 | | nA | | I/O ports hi-z leakage current | | | 1000 | | ПА | | PA7–PA0, PB1/OSC3, PB0 (pulldown devices off) | I <sub>OZ</sub> | _ | _ | ±10 | μΑ | | Input pulldown current | | | | | _ | | PA7–PA0, PB1/OSC3, PB0 (pulldown devices on) | I <sub>IL</sub> | 50 | 75 | 200 | μΑ | | Input current | | | | | | | IRQ/V <sub>PP</sub> , OSC1 | I <sub>In</sub> | _ | _ | ±1 | μΑ | | RESET (pulldown devices off) | 'In | <u> </u> | _ | ±1 | μΑ | | RESET (pulldown devices on) | | 1.0 | 4.0 | 8.0 | mA | | Capacitance | | | | | | | Ports (input or output) | C <sub>Out</sub> | | _ | 12 | pF | | RESET, IRQ/V <sub>PP</sub> | C <sub>In</sub> | _ | _ | 8 | | | Low-voltage reset threshold <sup>(6)</sup> | V <sub>LVR</sub> | 2.8 | 3.5 | 4.5 | V | | Oscillator internal resistor (OSC1 to OSC2) | Rosc | 1.0 | 2.0 | 3.0 | MΩ | | Programming voltage <sup>(7)</sup> | V <sub>PP</sub> | 17.0 | 17.5 | 18.0 | V | | Programming current | I <sub>PP</sub> | _ | 5 | 10 | mA | - 1. $V_{DD}$ = 5.0 V ±10%; $V_{SS}$ = 0 Vdc, $T_A$ = $T_L$ to $T_H$ , unless otherwise noted - Typical values reflect average measurements at midpoint of voltage range at 25°C. - 3. Run (operating) I<sub>DD</sub> measured using external square wave clock source (f<sub>OSC</sub> = 4.2 MHz). All inputs 0.2 V from rail. No dc loads. Less than 50 pF on all outputs. $C_L = 20$ pF on OSC2. - 4. Wait $I_{DD}$ measured using external square wave clock source ( $f_{OSC}$ = 4.2 MHz). All inputs 0.2 V from rail. No dc loads. Less than 50 pF on all outputs. $C_L$ = 20 pF on OSC2. $V_{IL}$ = 0.2 V, $V_{IH}$ = $V_{DD}$ 0.2 V. OSC2 capacitance linearly affects wait $I_{DD}$ . Stop $I_{DD}$ measured with OSC1 = $V_{DD}$ . All ports configured as inputs. $V_{IL}$ = 0.2 V, $V_{IH}$ = $V_{DD}$ 0.2 V. With low-voltage reset enabled, stop $I_{DD}$ can be as high as 25 $\mu$ A. - 6. All MCUs guaranteed to operate at $V_{DD}$ = 5 V ±10%. Each MCU guaranteed to operate at its $V_{LVR}$ . - 7. Programming voltage measured at IRQ/V<sub>PP</sub> pin. MC68HC705K1 — Rev. 2.0 ### **Electrical Specifications** ### 12.9 3.3-Volt DC Electrical Characteristics | Characteristic <sup>(1)</sup> | Symbol | Min | Typ <sup>(2)</sup> | Max | Unit | |-------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------|---------------------------|---------------------------------|-----------------------|----------------------| | Output voltage $I_{Load} = 10.0 \ \mu A$ $I_{Load} = -10.0 \ \mu A$ | V <sub>OL</sub><br>V <sub>OH</sub> | <br>V <sub>DD</sub> – 0.1 | | 0.1<br>— | V | | Output high voltage, I <sub>Load</sub> = -0.4 mA<br>PA7-PA0, PB1/OSC3, PB0 | V <sub>OH</sub> | V <sub>DD</sub> – 0.3 | _ | _ | V | | Output low voltage I <sub>Load</sub> = 0.4 mA, PA3–PA0, PB1/OSC3, PB0 I <sub>Load</sub> = 3.0 mA, PC7–PC4 | V <sub>OL</sub> | _ | _ | 0.3<br>0.3 | V | | Input high voltage PA7–PA0, PB1/OSC3, PB0, IRQ/V <sub>PP</sub> , RESET, OSC1 | V <sub>IH</sub> | 0.7 x V <sub>DD</sub> | _ | V <sub>DD</sub> | V | | Input low voltage PA7–PA0, PB1/OSC3, PB0, IRQ/V <sub>PP</sub> , RESET, OSC1 | V <sub>IL</sub> | V <sub>SS</sub> | _ | 0.2 x V <sub>DD</sub> | V | | Supply current Run <sup>(3)</sup> Wait <sup>(4)</sup> Stop <sup>(5)</sup> 25°C 0°C to +70°C (standard) -40°C to +85°C (extended) | I <sub>DD</sub> | _<br>_<br>_<br>_ | 0.7<br>300<br>50<br>500<br>1000 | _<br>_<br>_<br>_ | mA<br>μA<br>nA<br>nA | | I/O ports hi-z leakage current<br>PA7-PA0, PB1/OSC3, PB0 (pulldown devices off) | I <sub>OZ</sub> | _ | _ | ±10 | μΑ | | Input pulldown current PA7-PA0, PB1/OSC3, PB0 (pulldown devices on) | I <sub>IL</sub> | 10 | 20 | 100 | μА | | Input current IRQ/V <sub>PP</sub> , OSC1 RESET (pulldown devices off) RESET (pulldown devices on) | I <sub>In</sub> | <br><br>0.2 | <br><br>2.0 | ±1<br>±1<br>4.0 | μΑ<br>μΑ<br>mA | | Capacitance Ports (input or output) RESET, IRQ/V <sub>PP</sub> | C <sub>Out</sub><br>C <sub>In</sub> | | _ | 12<br>8 | pF | | Oscillator internal resistor (OSC1 to OSC2) | R <sub>OSC</sub> | 1.0 | 2.0 | 3.0 | ΜΩ | <sup>1.</sup> $V_{DD} = 3.3 \text{ V} \pm 10\%$ ; $V_{SS} = 0 \text{ Vdc}$ , $T_A = T_L \text{ to } T_H$ , unless otherwise noted 2. Typical values reflect average measurements at midpoint of voltage range at 25°C. <sup>3.</sup> Run (operating) $I_{DD}$ measured using external square wave clock source ( $f_{OSC} = 2.0$ MHz). All inputs 0.2 V from rail. No dc loads. Less than 50 pF on all outputs. $C_L = 20$ pF on OSC2. <sup>4.</sup> Wait I<sub>DD</sub> measured using external square wave clock source (f<sub>OSC</sub> = 2.0 MHz). All inputs 0.2 V from rail. No dc loads. Less than 50 pF on all outputs. C<sub>L</sub> = 20 pF on OSC2. V<sub>IL</sub> = 0.2 V, V<sub>IH</sub> = V<sub>DD</sub> - 0.2 V. OSC2 capacitance linearly affects wait I<sub>DD</sub>. 5. Stop I<sub>DD</sub> measured with OSC1 = V<sub>DD</sub>. All ports configured as inputs. V<sub>IL</sub> = 0.2 V, V<sub>IH</sub> = V<sub>DD</sub> - 0.2 V. With low-voltage reset combined stop I<sub>C</sub> can be as high as 25 m/s. enabled, stop $I_{DD}$ can be as high as 25 $\mu$ A. Electrical Specifications 3.3-Volt DC Electrical Characteristics #### Notes: - 1. Shaded area indicates variation in driver characteristics due to changes in temperature and for normal processing tolerances. Within the limited range of values shown, V versus I curves are approximately straight lines. - 2. At $V_{DD}$ = 5.0 V, devices are specified and tested for $V_{OL} \le 800$ mV @ $I_{OL}$ = -0.8 mA. - 3. At V<sub>DD</sub> = 3.3 V, devices are specified and tested for V<sub>OL</sub> $\leq$ 300 mV @ I<sub>OL</sub> = -0.2 mA. Figure 12-2. Typical High-Side Driver Characteristics #### Notes: - 1. Shaded area indicates variation in driver characteristics due to changes in temperature and for normal processing tolerances. Within the limited range of values shown, V versus I curves are approximately straight lines. - 2. At $V_{DD}$ = 5.0 V, devices are specified and tested for $V_{OL} \le$ 400 mV @ $I_{OL}$ = 1.6 mA. - 3. At $V_{DD}$ = 3.3 V, devices are specified and tested for $V_{OL} \le$ 300 mV @ $I_{OL}$ = 0.4 mA. Figure 12-3. Typical Low-Side Driver Characteristics MC68HC705K1 — Rev. 2.0 Technical Data # **Electrical Specifications** Figure 12-4. Run I<sub>DD</sub> versus Internal Clock Frequency Figure 12-5. Wait I<sub>DD</sub> versus Internal Clock Frequency Electrical Specifications 3.3-Volt DC Electrical Characteristics Figure 12-6. Stop $I_{DD}$ versus Temperature # **Electrical Specifications** # 12.10 5.0-Volt Control Timing | Characteristic <sup>(1)</sup> | Symbol | Min | Max | Unit | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|---------------------------|--------------------------|------------------| | Oscillator frequency 3-pin RC oscillator 2-pin RC oscillator Crystal/ceramic resonator <sup>(2)</sup> External clock | fosc | (3)<br>(3)<br>0.500<br>dc | 1.2<br>2.4<br>4.0<br>4.0 | MHz | | Internal operating frequency (f <sub>OSC</sub> ÷ 2) 3-pin RC oscillator 2-pin RC oscillator Crystal/ceramic resonator External clock | f <sub>OP</sub> | (3)<br>(3)<br>0.250<br>dc | 0.6<br>1.2<br>2.0<br>2.0 | MHz | | 2-pin RC oscillator frequency combined stability <sup>(4)</sup> $f_{OSC} = 2.0 \text{ MHz}; V_{DD} = 5.0 \text{ Vdc} \pm 10\%; T_A = -40^{\circ}\text{C to} +85^{\circ}\text{C} \\ f_{OSC} = 2.0 \text{ MHz}; V_{DD} = 5.0 \text{ Vdc} \pm 10\%; T_A = 0^{\circ}\text{C to} +40^{\circ}\text{C}$ | Δf <sub>OSC</sub> | _ | ±25<br>±20 | % | | 3-pin RC oscillator frequency combined stability <sup>(4)</sup> $f_{OSC} = 1.0 \text{ MHz}; V_{DD} = 5.0 \text{ Vdc} \pm 10\%; T_A = -40^{\circ}\text{C to} +85^{\circ}\text{C} \\ f_{OSC} = 1.0 \text{ MHz}; V_{DD} = 5.0 \text{ Vdc} \pm 10\%; T_A = 0^{\circ}\text{C to} +40^{\circ}\text{C}$ | $\Delta f_{OSC}$ | _ | ±15<br>±10 | % | | Cycle time (1 ÷ f <sub>OP</sub> ) | t <sub>CYC</sub> | 500 | _ | ns | | RC oscillator stabilization time | t <sub>RCON</sub> | _ | 1 | ms | | Crystal oscillator startup time | t <sub>OXON</sub> | _ | 100 | ms | | Stop recovery startup time | t <sub>ILCH</sub> | _ | 100 | ms | | RESET pulse width low | t <sub>RL</sub> | 1.5 | _ | t <sub>CYC</sub> | | Timer resolution <sup>(5)</sup> | t <sub>RESL</sub> | 4.0 | _ | t <sub>CYC</sub> | | IRQ interrupt pulse width low (edge-triggered) | t <sub>ILIH</sub> | 250 | _ | ns | | IRQ interrupt pulse period | t <sub>ILIL</sub> | (6) | _ | tcyc | | PA3-PA0 interrupt pulse width high (edge-triggered) | t <sub>IHIL</sub> | 250 | _ | ns | | PA3-PA0 interrupt pulse period | t <sub>IHIH</sub> | (6) | _ | t <sub>CYC</sub> | | OSC1 pulse width | t <sub>OH</sub> , t <sub>OL</sub> | 200 | _ | ns | | Programming time per byte <sup>(7)</sup> | t <sub>EPGM</sub> | 10 | 15 | ms | <sup>1.</sup> $V_{DD}$ = 5.0 Vdc ±10%; $V_{SS}$ –0 Vdc; $T_A$ = $T_L$ to $T_H$ <sup>2.</sup> Use only AT-cut crystals. <sup>3.</sup> Minimum oscillator frequency with RC oscillator option is limited only by size of external R and C and leakage of external C. <sup>4.</sup> Including processing tolerances and variations in temperature and supply voltage. Excluding tolerances of external R <sup>5.</sup> The 2-bit timer prescaler is the limiting factor in determining timer resolution. <sup>6.</sup> The minimum period, t<sub>ILIL</sub> or t<sub>IHIH</sub>, should not be less than the number of cycles it takes to execute the interrupt service routine plus 19 t<sub>CYC</sub>. 7. t<sub>EPGM</sub> is programming time per byte and may be accumulated during multiple programming passes. Electrical Specifications 3.3-Volt Control Timing # 12.11 3.3-Volt Control Timing | Characteristic <sup>(1)</sup> | Symbol | Min | Max | Unit | |----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|---------------------------|--------------------------|------------------| | Oscillator frequency 3-pin RC oscillator 2-pin RC oscillator Crystal/ceramic resonator <sup>(2)</sup> External clock | fosc | (3)<br>(3)<br>0.500<br>dc | 1.2<br>2.0<br>2.0<br>2.0 | MHz | | Internal operating frequency (f <sub>OSC</sub> ÷ 2) 3-pin RC oscillator 2-pin RC oscillator Crystal/ceramic resonator External clock | f <sub>OP</sub> | (3)<br>(3)<br>0.250<br>dc | 0.6<br>1.0<br>1.0<br>1.0 | MHz | | 2-pin RC oscillator frequency combined stability <sup>(4)</sup> $f_{OSC} = 2.0 \text{ MHz; } V_{DD} = 3.3 \text{ Vdc} \pm 10\%; T_A = -40^{\circ}\text{C to} +85^{\circ}\text{C} \\ f_{OSC} = 2.0 \text{ MHz; } V_{DD} = 3.3 \text{ Vdc} \pm 10\%; T_A = 0^{\circ}\text{C to} +40^{\circ}\text{C}$ | $\Delta f_{\sf OSC}$ | _ | ±40<br>±30 | % | | 3-pin RC oscillator frequency combined stability <sup>(4)</sup> $f_{OSC} = 1.0 \text{ MHz}; V_{DD} = 3.3 \text{ Vdc} \pm 10\%; T_A = -40^{\circ}\text{C to} +85^{\circ}\text{C} \\ f_{OSC} = 1.0 \text{ MHz}; V_{DD} = 3.3 \text{ Vdc} \pm 10\%; T_A = 0^{\circ}\text{C to} +40^{\circ}\text{C}$ | $\Delta f_{\sf OSC}$ | _ | ±20<br>±15 | % | | Cycle time (1 ÷ f <sub>OP</sub> ) | t <sub>CYC</sub> | 1000 | _ | ns | | RC oscillator stabilization time | t <sub>RCON</sub> | _ | 1 | ms | | Crystal oscillator startup time | t <sub>OXON</sub> | _ | 100 | ms | | Stop recovery startup time | t <sub>ILCH</sub> | _ | 100 | ms | | RESET pulse width low | t <sub>RL</sub> | 1.5 | _ | t <sub>CYC</sub> | | Timer resolution <sup>(5)</sup> | t <sub>RESL</sub> | 4.0 | _ | t <sub>CYC</sub> | | IRQ interrupt pulse width low (edge-triggered) | t <sub>ILIH</sub> | 250 | _ | ns | | IRQ interrupt pulse period | t <sub>ILIL</sub> | (6) | _ | t <sub>CYC</sub> | | PA3-PA0 interrupt pulse width high (edge-triggered) | t <sub>IHIL</sub> | 250 | _ | ns | | PA3-PA0 interrupt pulse period | t <sub>IHIH</sub> | (6) | _ | t <sub>CYC</sub> | | OSC1 pulse width | t <sub>OH</sub> , t <sub>OL</sub> | 200 | _ | ns | <sup>1.</sup> $V_{DD}$ = 3.3 Vdc ±10%; $V_{SS}$ –0 Vdc; $T_A$ = $T_L$ to $T_H$ MC68HC705K1 — Rev. 2.0 <sup>2.</sup> Use only AT-cut crystals. <sup>3.</sup> Minimum oscillator frequency with RC oscillator option is limited only by size of external R and C and leakage of external C. <sup>4.</sup> Including processing tolerances and variations in temperature and supply voltage. Excluding tolerances of external R and C. <sup>5.</sup> The 2-bit timer prescaler is the limiting factor in determining timer resolution. <sup>6.</sup> The minimum period, t<sub>ILIL</sub> or t<sub>IHIH</sub>, should not be less than the number of cycles it takes to execute the interrupt service routine plus 19 t<sub>CYC</sub>. # **Electrical Specifications** Figure 12-7. External Interrupt Timing #### Notes: - 1. Internal clocking from OSC1 pin. - Edge-triggered external interrupt mask option. Edge- and level-triggered external interrupt mask option. - 4. Reset vector shown as example. Figure 12-8. Stop Mode Recovery Timing MC68HC705K1 — Rev. 2.0 **Technical Data** Electrical Specifications 3.3-Volt Control Timing #### Notes: - 1. Power-on reset threshold is typically between 1 V and 2 V. - 2. Internal clock, internal address bus, and internal data bus are not available externally. Figure 12-9. Power-On Reset Timing #### Notes: - 1. Internal clock, internal address bus, and internal data bus are not available externally. - 2. The next rising edge of the internal clock after the rising edge of RESET initiates the reset sequence. Figure 12-10. External Reset Timing # **Electrical Specifications** # **12.12 Typical Oscillator Characteristics** | Para | ameter | V <sub>DD</sub> = 3.0 V | V <sub>DD</sub> = 5.0 V | Units | |---------------------------|-------------------------------------|-------------------------|-------------------------|--------| | Oscillator Type | Nominal Frequency | VDD = 3.0 V | V <sub>DD</sub> = 3.0 V | Offics | | | cy Variation<br>to-Part) | | | | | 2-pin RC oscillator | 2 MHz | ±12 | ±7 | % | | 3-pin RC oscillator 1 MHz | | ±5 | ±4 | /0 | | Eroguone | ny Variation | ] | | | | with Te | cy Variation<br>mperature | | | | | 2-pin RC oscillator | 2 MHz | -2100 | -1600 | nnm/°C | | 3-pin RC oscillator | 1 MHz | -1100 | -1100 | ppm/°C | | | | | | | | | cy Variation<br>ply Voltage | | | | | 2-pin RC oscillator | 2 MHz | ±1.0 | ±0.2 | Δf/ΔV | | 3-pin RC oscillator | 1 MHz | ±0.3 | ±0.1 | ΔΙ/Δν | | | | | | | | | e Frequency<br>tions <sup>(1)</sup> | | | | | 2-pin RC oscillator | 2 MHz | ±36 | ±20 | % | | 3-pin RC oscillator | 1 MHz | ±16 | ±13 | /0 | <sup>1.</sup> $V_{DD} \pm 10\%$ ; $T_A = -40^{\circ}C$ to $+85^{\circ}C$ . Electrical Specifications Typical Oscillator Characteristics Figure 12-11. 2-Pin RC Oscillator R versus Frequency (V<sub>DD</sub> = 5.0 V) Figure 12-12. 3-Pin RC Oscillator R versus Frequency ( $V_{DD} = 5.0 \text{ V}$ ) MC68HC705K1 — Rev. 2.0 Technical Data # **Electrical Specifications** Figure 12-13. 2-Pin Oscillator R versus Frequency (V<sub>DD</sub> = 3.0 V) Figure 12-14. 3-Pin Oscillator R versus Frequency (V<sub>DD</sub> = 3.0 V) #### Technical Data — MC68HC705K1 # Section 13. Mechanical Specifications #### 13.1 Contents | 13.2 | Introduction | |------|---------------------------------------------| | 13.3 | Plastic Dual In-Line Package (Case 648)134 | | 13.4 | Small Outline Integrated Circuit (Case 751) | | 13.5 | Ceramic Dual In-Line Package (Case 620) | #### 13.2 Introduction Package dimensions available at the time of this publication for the MC68HC705K1 are provided in this section. The packages are: - 16-pin plastic dual in-line package (PDIP) - 16-pin small outline integrated circuit package (SOIC) - 16-pin ceramic DIP (cerdip) To make sure that you have the latest case outline specifications, contact one of the following: - Local Motorola Sales Office - Motorola Mfax - Phone 602-244-6609 - EMAIL rmfax0@email.sps.mot.com - Worldwide Web (wwweb) at http://www.mcu.motsps.com Follow Mfax or wwweb on-line instructions to retrieve the current mechanical specifications. MC68HC705K1 — Rev. 2.0 # **Mechanical Specifications** # 13.3 Plastic Dual In-Line Package (Case 648) | | INC | HES | MILLIN | IETERS | |-----|-----------|-------|----------|--------| | DIM | MIN | MAX | MIN | MAX | | Α | 0.740 | 0.770 | 18.80 | 19.55 | | В | 0.250 | 0.270 | 6.35 | 6.85 | | С | 0.145 | 0.175 | 3.69 | 4.44 | | D | 0.015 | 0.021 | 0.39 | 0.53 | | F | 0.040 | 0.70 | 1.02 | 1.77 | | G | 0.100 BSC | | 2.54 BSC | | | Н | 0.050 BSC | | 1.27 I | 3SC | | J | 0.008 | 0.015 | 0.21 | 0.38 | | K | 0.110 | 0.130 | 2.80 | 3.30 | | L | 0.295 | 0.305 | 7.50 | 7.74 | | М | 0° | 10° | 0° | 10° | | S | 0.020 | 0.040 | 0.51 | 1.01 | # 13.4 Small Outline Integrated Circuit (Case 751) | | MILLIM | ETERS | INCHES | | |-----|--------|-------|-----------|-------| | DIM | MIN | MAX | MIN | MAX | | Α | 10.15 | 10.45 | 0.400 | 0.411 | | В | 7.40 | 7.60 | 0.292 | 0.299 | | С | 2.35 | 2.65 | 0.093 | 0.104 | | D | 0.35 | 0.49 | 0.014 | 0.019 | | F | 0.50 | 0.90 | 0.020 | 0.035 | | G | 1.27 | BSC | 0.050 BSC | | | J | 0.25 | 0.32 | 0.010 | 0.012 | | K | 0.10 | 0.25 | 0.004 | 0.009 | | М | 0° | 7° | 0° | 7° | | Р | 10.05 | 10.55 | 0.395 | 0.415 | | R | 0.25 | 0.75 | 0.010 | 0.029 | Mechanical Specifications Ceramic Dual In-Line Package (Case 620) ### 13.5 Ceramic Dual In-Line Package (Case 620) - NOTES: 1. DIMENSIONING AND TOLERANCING PER ASME Y14.5M, 1994. 2. CONTROLLING DIMENSION: INCH. 3. DIMENSION L TO CENTER OF LEAD WHEN - FORMED PARALLEL. DIMENSION F MAY NARROW TO 0.76 (0.030) WHERE THE LEAD ENTERS THE CERAMIC | | INCHES | | MILLIMETERS | | |-----|-----------|-------|-------------|-------| | DIM | MIN | MAX | MIN | MAX | | Α | 0.750 | 0.785 | 19.05 | 19.93 | | В | 0.240 | 0.295 | 6.10 | 7.49 | | С | | 0.200 | | 5.08 | | D | 0.015 | 0.020 | 0.39 | 0.50 | | Ε | 0.050 | BSC | 1.27 BSC | | | F | 0.055 | 0.065 | 1.40 | 1.65 | | G | 0.100 BSC | | 2.54 | BSC | | Н | 0.008 | 0.015 | 0.21 | 0.38 | | K | 0.125 | 0.170 | 3.18 | 4.31 | | L | 0.300 | BSC | 7.62 BSC | | | М | 0° | 15° | 0° | 15° | | N | 0.020 | 0.040 | 0.51 | 1.01 | # STYLE 1: PIN 1. - CATHODE - CATHODE CATHODE - CATHODE - CATHODE CATHODE - CATHODE - CATHODE - ANODE ANODE 10. - 11. - ANODE ANODE ANODE - 12. 13. 14. 15. ANODE - ANODE ANODE **Mechanical Specifications** ### Technical Data — MC68HC705K1 # **Section 13. Ordering Information** ### 13.1 Contents | 13.2 | Introduction | .13 | |------|-------------------|------| | 13.3 | MCU Order Numbers | .137 | ### 13.2 Introduction This section contains ordering information for the available package types. #### 13.3 MCU Order Numbers Table 13-1 lists the MC order numbers. Table 13-1. MC68HC705K1 Order Numbers | Package Type | Temperature Range | Order Number | |------------------------------------------------|-------------------|------------------------------| | 16-pin plastic dual in-line package (PDIP) | 0°C to +70°C | MC68HC705K1P <sup>(1)</sup> | | 16-pin small outline integrated circuit (SOIC) | 0°C to +70°C | MC68HC705K1DW <sup>(2)</sup> | | 16-pin ceramic dual in-line package (cerdip) | 0°C to +70°C | MC68HC705K1S <sup>(3)</sup> | | 16-pin plastic dual in-line package (PDIP) | -40°C to +85°C | MC68HC705K1CP <sup>(4)</sup> | | 16-pin small outline integrated circuit (SOIC) | -40°C to +85°C | MC68HC705K1CDW | | 16-pin ceramic dual in-line package (cerdip) | -40°C to +85°C | MC68HC705K1CS | - 1. P = Plastic dual in-line package (PDIP) - 2. DW = Small outline integrated circuit (SOIC) - 3. S = Ceramic dual in-line package (cerdip) - 4. C = Extended temperature range ( $-40^{\circ}$ C to +85°C) MC68HC705K1 — Rev. 2.0 **Ordering Information** Home Page: www.freescale.com email: support@freescale.com USA/Europe or Locations Not Listed: Freescale Semiconductor Technical Information Center, CH370 1300 N. Alma School Road Chandler, Arizona 85224 (800) 521-6274 480-768-2130 support@freescale.com Europe, Middle East, and Africa: Freescale Halbleiter Deutschland GmbH Technical Information Center Schatzbogen 7 81829 Muenchen, Germany +44 1296 380 456 (English) +46 8 52200080 (English) +49 89 92103 559 (German) +33 1 69 35 48 48 (French) +33 1 09 33 40 40 (FIEIICI support@freescale.com Japan: Freescale Semiconductor Japan Ltd. Headquarters ARCO Tower 15F 1-8-1, Shimo-Meguro, Meguro-ku Tokyo 153-0064, Japan 0120 191014 +81 2666 8080 support.japan@freescale.com Asia/Pacific: Freescale Semiconductor Hong Kong Ltd. **Technical Information Center** 2 Dai King Street Tai Po Industrial Estate, Tai Po, N.T., Hong Kong +800 2666 8080 support.asia@freescale.com For Literature Requests Only: Freescale Semiconductor Literature Distribution Center P.O. Box 5405 Denver, Colorado 80217 (800) 441-2447 303-675-2140 Fax: 303-675-2150 LDCF or Free scale Semiconductor @hibbertgroup.com RoHS-compliant and/or Pb- free versions of Freescale products have the functionality and electrical characteristics of their non-RoHS-compliant and/or non-Pb- free counterparts. For further information, see http://www.freescale.com or contact your Freescale sales representative. For information on Freescale.s Environmental Products program, go to http://www.freescale.com/epp. Information in this document is provided solely to enable system and software implementers to use Freescale Semiconductor products. There are no express or implied copyright licenses granted hereunder to design or fabricate any integrated circuits or integrated circuits based on the information in this document. Freescale Semiconductor reserves the right to make changes without further notice to any products herein. Freescale Semiconductor makes no warranty, representation or guarantee regarding the suitability of its products for any particular purpose, nor does Freescale Semiconductor assume any liability arising out of the application or use of any product or circuit, and specifically disclaims any and all liability, including without limitation consequential or incidental damages. "Typical" parameters which may be provided in Freescale Semiconductor data sheets and/or specifications can and do vary in different applications and actual performance may vary over time. All operating parameters, including "Typicals" must be validated for each customer application by customer's technical experts. Freescale Semiconductor does not convey any license under its patent rights nor the rights of others. Freescale Semiconductor products are not designed, intended, or authorized for use as components in systems intended for surgical implant into the body, or other applications intended to support or sustain life, or for any other application in which the failure of the Freescale Semiconductor product could create a situation where personal injury or death may occur. Should Buyer purchase or use Freescale Semiconductor products for any such unintended or unauthorized application, Buyer shall indemnify and hold Freescale Semiconductor and its officers, employees, subsidiaries, affiliates, and distributors harmless against all claims, costs, damages, and expenses, and reasonable attorney fees arising out of, directly or indirectly, any claim of personal injury or death associated with such unintended or unauthorized use, even if such claim alleges that Freescale Semiconductor was negligent regarding the design or manufacture of the part. MC68HC705J1A/D