# MAGNACHIP SEMICONDUCTOR LTD. 8-BIT SINGLE-CHIP MICROCONTROLLERS # MC80F0208/16/24 MC80C0208/16/24 User's Manual (Ver. 0.2) Preliminary # REVISION HISTORY VERSION 0.2 (MAR. 2005) This book Version 0.2 Published by MCU Application Team ©2005 MagnaChip semiconductor Inc. All right reserved. Additional information of this manual may be served by MagnaChip semiconductor offices in Korea or Distributors and Representatives. MagnaChip semiconductor reserves the right to make changes to any information here in at any time without notice. The information, diagrams and other data in this manual are correct and reliable; however, MagnaChip semiconductor is in no way responsible for any violations of patents or other rights of the third party generated by the use of this manual. | 1. OVERVIEW | | |-------------------------------------------------------|----| | Description | | | Features | | | Ordering Information | | | Development Tools | | | 2. BLOCK DIAGRAM | 4 | | 3. PIN ASSIGNMENT | 5 | | 4. PACKAGE DIAGRAM | 6 | | 5. PIN FUNCTION | 7 | | Pin Description | 8 | | 6. PORT STRUCTURES | 10 | | 7. ELECTRICAL CHARACTERISTICS | 13 | | Absolute Maximum Ratings | | | Recommended Operating Conditions | | | A/D Converter Characteristics | | | DC Electrical Characteristics | | | AC Characteristics | | | Serial Interface Timing Characteristics | | | Typical Characteristic Curves | | | 8. MEMORY ORGANIZATION | _ | | Registers | | | Program Memory | | | Data Memory | | | · · · · · · · · · · · · · · · · · · · | | | 9. I/O PORTS | | | 10. CLOCK GENERATOR | | | 11. BASIC INTERVAL TIMER | | | 12. WATCHDOG TIMER | 42 | | 13. WATCH TIMER | 45 | | 14. TIMER/EVENT COUNTER | 46 | | 8-bit Timer / Counter Mode | 50 | | 16-bit Timer / Counter Mode | 56 | | 8-bit Compare Output (16-bit) | | | 8-bit Capture Mode | | | 16-bit Capture Mode | | | PWM Mode | | | 15. ANALOG TO DIGITAL CONVERTER | 68 | | 16. SERIAL INPUT/OUTPUT (SIO) | | | Transmission/Receiving Timing | | | The method of Serial I/O | | | The Method to Test Correct Transmission | | | 17. UNIVERSAL ASYNCHRONOUS RECEIVER/TRANSMITTER (UART | | | UART Serial Interface Functions | 75 | | Serial Interface Configuration | 11 | |---------------------------------------------------------|-----| | Communication operation | | | Relationship between main clock and baud rate | 82 | | 18. BUZZER FUNCTION | 83 | | 19. INTERRUPTS | 85 | | Interrupt Sequence | 87 | | BRK Interrupt | | | Shared Interrupt Vector | | | Multi Interrupt | | | External Interrupt | 91 | | 20. OPERATION MODE | 93 | | Operation Mode Switching | 93 | | 21. POWER SAVING OPERATION | 94 | | Sleep Mode | 94 | | Stop Mode | 95 | | Stop Mode at Internal RC-Oscillated Watchdog Timer Mode | 98 | | Minimizing Current Consumption | 100 | | 22. OSCILLATOR CIRCUIT | 102 | | 23. RESET | 103 | | 24. POWER FAIL PROCESSOR | 104 | | 25. FLASH PROGRAMMING | 106 | | Device Configuration Area | | | 26. Emulator EVA. Board Setting | 107 | | 27. IN-SYSTEM PROGRAMMING (ISP) | 110 | | Getting Started / Installation | | | Basic ISP S/W Information | 110 | | Hardware Conditions to Enter the ISP Mode | 111 | | Reference ISP Circuit diagram | 113 | | A. INSTRUCTION | | | Terminology List | | | Instruction Map | | | Instruction Set | | | K WASK ORDER SHEET | IV. | # MC80F0208/16/24 MC80C0208/16/24 # CMOS SINGLE-CHIP 8-BIT MICROCONTROLLER WITH 10-BIT A/D CONVERTER AND UART #### 1. OVERVIEW #### 1.1 Description The MC80F0208/16/24 is advanced CMOS 8-bit microcontroller with 8K/16K/24K bytes of FLASH(ROM). This is a powerful microcontroller which provides a highly flexible and cost effective solution to many embedded control applications. This provides the following standard features: 8K/16K/24K bytes of FLASH, 1K bytes of RAM, 8/16-bit timer/counter, watchdog timer, watch timer, 10-bit A/D converter, 8-bit Serial Input/Output, UART, buzzer driving port, 10-bit PWM output and on-chip oscillator and clock circuitry. It also has 8 high current I/O pins with typical 20mA. In addition, the MC80F0208/16/24 supports power saving modes to reduce power consumption. | Device | Device Name | | FLASH(ROM) | | DIAMA | WO DODT | Dankana | | |------------|-------------|-----------|---------------------|-----------|-------------|----------|---------|--| | FLASH | MASK ROM | Size | RAM | ADC | PWM | I/O PORT | Package | | | MC80F0208Q | MC80C0208Q | OICD: #a | 1024<br>Byte 8 chan | 0 1 1 | l 1 channel | 36 port | 44MQFP | | | MC80F0208K | MC80C0208K | 8KByte | | 8 channel | | | 42SDIP | | | MC80F0216Q | MC80C0216Q | 4.OKD: 4- | 1024 | 0 1 1 | 4 1 1 | 00 1 | 44MQFP | | | MC80F0216K | MC80C0216K | 16KByte | Byte | 8 channel | 1 channel | 36 port | 42SDIP | | | MC80F0224Q | MC80C0224Q | 241/D. 4- | 1024 | 0 ahamad | | 20 = === | 44MQFP | | | MC80F0224K | MC80C0224K | 24KByte | Byte | 8 channel | 1 channel | 36 port | 42SDIP | | #### 1.2 Features - 8K/16K/24K Bytes On-chip ROM - FLASH Mermory - Endurance : 100 cyclesData Retention : 10 years - 1024 Bytes On-chip Data RAM (Included stack memory) - Minimum Instruction Execution Time - 333ns at 12MHz (NOP instruction) - 36 I/O Ports - One 8-bit Basic Interval Timer - Four 8-bit and one 16-bit Timer/Event counter (or three 16-bit Timer/Event counter) - · One Watchdog timer - One Watch timer - One 10-bit PWM - 8 channel 10-bit A/D converter - Three 8-bit Serial Communication Interface - One Serial I/O and two UART - One Buzzer Driving port - 488Hz ~ 250kHz@4MHz - Four External Interrupt input ports - Fifteen Interrupt sources - Basic Interval Timer(1) - External input(4) - Timer/Event counter(5) - ADC(1) - Serial Interface(1), UART(2) - WDT and Watch Timer(1) - Built in Noise Immunity Circuit - Noise filter - 3-level Power fail detector [3.0V, 2.7V, 2.4V] - Power Down Mode - Stop, Sleep mode - Operating Voltage Range - 2.7V ~ 5.5V (@ 8MHz) - 4.5V ~ 5.5V (@ 12MHz) - Operating Frequency Range - 0.4 ~ 12MHz - 44MQFP, 42SDIP type - Operating Temperature : -40°C ~ 85°C - Oscillator Type - Crystal, Ceramic resonator, External clock # 1.3 Ordering Information | ROM Type | Device name | ROM Size | RAM size | Package | |---------------|--------------------------|------------------------------------|------------|------------------| | Mask version | MC80C0208Q<br>MC80C0208K | 8K bytes<br>8K bytes | 1024 bytes | 44MQFP<br>42SDIP | | | MC80C0216Q<br>MC80C0216K | 16K bytes<br>16K bytes | 1024 bytes | 44MQFP<br>42SDIP | | | MC80C0224Q<br>MC80C0224K | 24K bytes<br>24K bytes | 1024 bytes | 44MQFP<br>42SDIP | | | MC80F0208Q<br>MC80F0208K | 8K bytes FLASH<br>8K bytes FLASH | 1024 bytes | 44MQFP<br>42SDIP | | FLASH version | MC80F0216Q<br>MC80F0216K | 16K bytes FLASH<br>16K bytes FLASH | 1024 bytes | 44MQFP<br>42SDIP | | | MC80F0224Q<br>MC80F0224K | 24K bytes FLASH<br>24K bytes FLASH | 1024 bytes | 44MQFP<br>42SDIP | Table 1-1 Ordering Information of MC80F0208/16/24 & MC80C0208/16/24 # 1.4 Development Tools The MC80F0208/16/24 is supported by a full-featured macro assembler, an in-circuit emulator CHOICE-Dr. $^{TM}$ and OTP programmers. There are two different type of programmers such as single type and gang type. For mode detail, Macro assembler operates under the MS-Windows 95 and upversioned Windows OS. Please contact sales part of MagnaChip semiconductor. | Software | - MS-Windows based assembler<br>- MS-Windows based Debugger<br>- MC800 C compiler | |------------------------|--------------------------------------------------------------------------------------------------------------| | Hardware<br>(Emulator) | - CHOICE-Dr.<br>- CHOICE-Dr. EVA80C0x B/D | | FLASH Writer | - CHOICE - SIGMA I/II(Single writer) - PGM Plus I/II/III(Single writer) - Standalone GANG4 I/II(Gang writer) | Choice-Dr. (Emulator) PGMplus III (Single Writer) Standalone Gang4 II ( Gang Writer ) # 2. BLOCK DIAGRAM # 3. PIN ASSIGNMENT # 4. PACKAGE DIAGRAM #### 5. PIN FUNCTION V<sub>DD</sub>: Supply voltage. V<sub>SS</sub>: Circuit ground. AVDD: Supply voltage to the ladder resistor of ADC circuit. **RESET**: Reset the MCU. $\mathbf{X_{IN}}$ : Input to the inverting oscillator amplifier and input to the internal main clock operating circuit. $X_{OUT}$ : Output from the inverting oscillator amplifier. **R00~R07**: R0 is an 8-bit CMOS bidirectional I/O port. R0 pins with 1 or 0 written to the R0 Port Direction Register R0IO can be used as outputs or inputs. The internal pull-up resistor can be connected by using the pull-up selection register 0 (PU0). **R10~R13, R15**: R1 is an 5-bit CMOS bidirectional I/O port. R1 pins with 1 or 0 written to the R1 Port Direction Register R1IO can be used as outputs or inputs. The internal pull-up resistor can be connected by using the pull-up selection register 1 (PU1). In addition, R1 serves the functions of the various following special features such as INTO (External interrupt 0), INT1 (External interrupt 1), INT2 (External interrupt 2), BUZO (Buzzer driver output), EC0 (Event counter input 0). **R30~R33**: R3 is an 4-bit CMOS bidirectional I/O port. R3 pins with 1 or 0 written to the R3 Port Direction Register R3IO can be used as outputs or inputs. R3 operates as the high current output port with typical 20mA at low level output. In addition, R3 serves the functions of the following special features such as ACLK1 (UART1 Asynchronous serial clock input), RxD1 (UART1 data input), TxD1 (UART1 data output). **R40~R47**: R4 is an 8-bit CMOS bidirectional I/O port. R4 pins with 1 or 0 written to the R4 Port Direction Register R4IO can be used as outputs or inputs. The internal pull-up resistor can be connected by using the pull-up selection register 4 (PU4). In addition, R4 serves the functions of the various following special features such as SCK (Serial clock), SI (Serial data input), SO (Serial data output), ACLK0 (UART1 Asynchronous serial clock input), RxD0 (UART0 data input), TxD0 (UART0 data output). **R50**, **R51**, **R54**: R5 is an 3-bit CMOS bidirectional I/O port. R5 pins with 1 or 0 written to the R5 Port Direction Register R5IO can be used as outputs or inputs. In addition, R5 serves the functions of the various following special features such as INT3 (External interrupt 3), EC1 (Event counter input 1), PWM3O (PWM output 3)/T3O(Timer3 Compare output). **R60~R67**: R6 is an 8-bit CMOS bidirectional I/O port. R6 pins with 1 or 0 written to the R6 Port Direction Register R6IO can be used as outputs or inputs. In addition, R6 serves the functions of the ADC analog input port AN[7:0]. # 5.1 Pin Description # **5.1.1 Normal Function Pin Description** | PIN NAME | In/Out | Function | Initial<br>state | Alternate<br>Function | |------------------|--------|----------------------------------------------------------------------------------------------------------------------------------|------------------|-----------------------| | R00~R07 | I/O | Port0 8-bit I/O port. Can be set in input or output mode in 1-bit units. Internal pull-up resistor PU0 can be used via software. | Input | - | | R10 | | | | INT0 | | R11 | | Port 1. | | INT1 | | R12 | I/O | 5-bit I/O port. Can be set in input or output mode in 1-bit units. | Input | INT2 | | R13 | | Internal pull-up resistor PU1 can be used via software. | | BUZO | | R15 | | | | EC0 | | R30 | | | | - | | R31 | 1/0 | Port 3. | lanut | ACLK1 | | R32 | I/O | 4-bit I/O port. Can be set in input or output mode in 1-bit units. | Input | RxD1 | | R33 | | our be set in input of output mode in 1 bit arms. | | TxD1 | | R40 | | | | - | | R41 | | | | - | | R42 | | Port 4.<br>8-bit I/O port. | | SCK | | R43 | 1/0 | | | SI | | R44 | I/O | Can be set in input or output mode in 1-bit units. | Input | SO | | R45 | | Internal pull-up resistor PU4 can be used via software. | | ACLK0 | | R46 | | | | RxD0 | | R47 | | | | TxD0 | | R50 | | Port 5. | | INT3 | | R51 | I/O | 3-bit I/O port. | Input | EC1 | | R54 | | Can be set in input or output mode in 1-bit units. | | PWM3O/T3O | | R60~R67 | I/O | Port 6. 8-bit I/O port. Can be set in input or output mode in 1-bit units. | Input | AN0~AN7 | | RESET | ı | System reset input. | Input | - | | X <sub>IN</sub> | 1 | | Input | - | | X <sub>OUT</sub> | 0 | Crystal connection for main system clock oscillation. | Output | - | | AV <sub>DD</sub> | - | Analog power/reference voltage input to A/D converter.<br>Set the same potential as VDD. | - | - | | $V_{DD}$ | - | Positive power supply. | - | - | | V <sub>SS</sub> | - | Ground potential. | - | - | **Table 5-1 Normal Function Pin Description** # **5.1.2 Alternate Function Pin Description** | PIN NAME | In/Out | Function | Initial<br>state | Shared<br>Pin | |----------|--------|----------------------------------------------------------------------------|------------------|---------------| | INT0 | | | | R10 | | INT1 | | Valid edges(rising, falling, or both rising and falling) can be specified. | Input | R11 | | INT2 | ' | External Interrupt request Input. | Input | R12 | | INT3 | | | | R50 | | BUZO | 0 | Buzzer Output | Input | R13 | | EC0 | 1 | Timer0 Event Counter Input | Input | R15 | | EC1 | 1 | Timer2 Event Counter Input | Input | R51 | | SCK | I/O | Serial clock input/output of serial interface. | Input | R42 | | SI | I | Serial data input of serial interface. | Input | R43 | | SO | 0 | Serial data output of serial interface. | Input | R44 | | ACLK0 | I | Asynchronous serial interface serial clock input. | Input | R45 | | RxD0 | I | Asynchronous serial interface serial data input. | Input | R46 | | TxD0 | 0 | Asynchronous serial interface serial data output. | Input | R47 | | ACLK1 | I | Asynchronous serial interface serial clock input2. | Input | R31 | | RxD1 | I | Asynchronous serial interface serial data input2. | Input | R32 | | TxD1 | 0 | Asynchronous serial interface serial data output2. | Input | R33 | | PWM3O | 0 | Timer3 PWM Output | Output | R54 | | T3O | 0 | Timer3 Compare Output | Output | K04 | | AN0~AN7 | I | Analog input Channel 0 ~ 7 for A/D converter. | Input | R60~R67 | **Table 5-2 Alternate Function Pin Description** # **6. PORT STRUCTURES** ### R00~R07, R40, R41 ### R13(BUZO), R47(TxD0) # R10(INT0)~ R12(INT2), R15(EC0), R43(SI), R45(ACLK0), R46(RxD0) #### R30 # R33(TxD1) ### R44(SO, IOSWIN) # R42(SCK) # R31(ACLK1), R32(RxD1), R50(INT3), R51(EC1) # R54(PWM3O/T3O) # $X_{IN}, X_{OUT}$ # R60~R67(AN0~AN7) # RESET ### 7. ELECTRICAL CHARACTERISTICS # 7.1 Absolute Maximum Ratings | Parameter | Symbol | Rating | Unit | Note | |-------------------------|------------------|----------------------------------------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Cumply Voltage | $V_{DD}$ | -0.3 ~ +6.5 | V | - | | Supply Voltage | $AV_DD$ | V <sub>DD</sub> - 0.3 ~ V <sub>DD</sub> +0.3 | V | - | | | VI | -0.3 ~ V <sub>DD</sub> +0.3 | V | Walter and the control of contro | | | Vo | -0.3 ~ V <sub>DD</sub> +0.3 | V | Voltage on any pin with respect to Ground ( $V_{SS}$ ) | | | I <sub>OH</sub> | 10 | mA | Maximum output current sourced by (I <sub>OH</sub> per I/O Pin) | | Normal Votagae Pin | ΣΙΟΗ | 80 | mA | Maximum current (ΣI <sub>OH</sub> ) | | | I <sub>OL</sub> | 20 | mA | Maximum current sunk by (I <sub>OL</sub> per I/O Pin) | | | $\Sigma I_{OL}$ | 160 | mA | Maximum current (ΣI <sub>OL</sub> ) | | Total Power Dissipation | f <sub>XIN</sub> | 600 | mW | - | | Storage Temperature | T <sub>STG</sub> | -65 ~ +150 | °C | °C | **Note:** Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability. # 7.2 Recommended Operating Conditions | Parameter | Symbol | Condition | Specifi | l lmit | | |-----------------------|------------------|--------------------------------|---------|--------|------| | | Symbol | Condition | Min. | Max. | Unit | | Supply Voltage | V <sub>DD</sub> | f <sub>XIN</sub> = 0.4 ~ 12MHz | 4.5 | 5.5 | V | | | | f <sub>XIN</sub> = 0.4 ~ 8MHz | 2.7 | 5.5 | V | | Operating Temperature | T <sub>OPR</sub> | V <sub>DD</sub> = 4.5 ~ 5.5V | -40 | 85 | °C | ### 7.3 A/D Converter Characteristics $(T_a=-40~85^{\circ}C, V_{SS}=0V, V_{DD}=AV_{DD}=2.7~5.5V @f_{XIN}=4MHz)$ | Parameter | Symbol | Conditions | Min. | Тур. | Max. | Unit | |------------------------------|------------------|---------------------------------------------|------|------|------|------| | Resolution | - | - | - | 10 | - | BIT | | Total Accuracy | - | | - | - | ±3 | LSB | | Intergral Linearity Error | ILE | | - | - | ±2 | LSB | | Differential Linearity Error | DLE | $AV_{DD} = V_{DD} = 5.12V$ $f_{XIN} = 4Mhz$ | - | - | ±2 | LSB | | Zero Offset Error | ZOE | TXIN = FIVILIZ | - | - | ±2 | LSB | | Full Scale Error | FSE | | - | - | ±2 | LSB | | Conversion Time | t <sub>CON</sub> | 10bit conversion<br>f <sub>XIN</sub> = 4Mhz | 13* | - | - | μS | | Parameter | Symbol | Conditions | Min. | Тур. | Max. | Unit | |----------------------|-------------------|------------------------------------------|-----------------|------|----------------------|------| | Analog Input Voltage | $V_{AN}$ | - | $V_{SS}$ | - | $AV_{DD}$ | V | | Analog Power Supply | AV <sub>DD</sub> | - | - | - | V <sub>DD</sub> | V | | Analog Ground | V <sub>SS</sub> | - | V <sub>SS</sub> | - | V <sub>SS</sub> +0.3 | V | | Analog Input Current | I <sub>ADIN</sub> | AV <sub>DD</sub> =V <sub>DD</sub> =5.12V | - | - | 10 | μΑ | | Analog Block Current | I <sub>ADC</sub> | AV <sub>DD</sub> =V <sub>DD</sub> =5.12V | - | 200 | 300 | μΑ | Note : $4MHz(f_{XIN}) / 2^2 X 13Cycle = 13uS$ # 7.4 DC Electrical Characteristics $(T_{A}\!\!=\!\!-40{\sim}85^{\circ}C,\,V_{DD}\!\!=\!\!5.0V\!\!\pm\!\!10\%,\,V_{SS}\!\!=\!\!0V,\,f_{XIN}\!\!=\!\!8MHz)$ | Parameter | Symbol | Pin/Condition | Min. | Тур. | Max. | Unit | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|----------------------------------------------------------------------------|----------------------|------|----------------------|------| | Input High Voltage | V <sub>IH1</sub> | INT0, INT1, INT2, INT3, EC0, EC1, SI, SCK, ACLK0, ACLK1, RxD0, RxD1, RESET | 0.8V <sub>DD</sub> | - | V <sub>DD</sub> +0.3 | V | | Parameter Input High Voltage Input Low Voltage Output High Voltage Output Low Voltage High Current Input High Leakage Current Input Low Leakage Current Pull-up Resistor OSC Feedback Resistor Internal RC WDT Period (RCWDT) Hysteresis | V <sub>IH2</sub> | R0, R1, R3, R4, R5, R6 | 0.7V <sub>DD</sub> | - | V <sub>DD</sub> +0.3 | V | | | V <sub>IH3</sub> | X <sub>IN</sub> | 0.8V <sub>DD</sub> | - | V <sub>DD</sub> +0.3 | V | | Input Low Voltage | V <sub>IL1</sub> | INT0, INT1, INT2, INT3, EC0, EC1, SI, SCK, ACLK0, ACLK1, RxD0, RxD1, RESET | -0.3 | - | 0.2V <sub>DD</sub> | V | | | $V_{IL2}$ | R0, R1, R3, R4, R5, R6 | -0.3 | - | 0.3V <sub>DD</sub> | V | | | $V_{IL3}$ | X <sub>IN</sub> | -0.3 | - | 0.2V <sub>DD</sub> | V | | Output High Valtage | V <sub>OH1</sub> | R0, R1, R3, R4, R5, R6 (I <sub>OH</sub> =-0.7mA) | V <sub>DD</sub> -0.4 | - | - | V | | Output High Voltage | V <sub>OH2</sub> | X <sub>OUT</sub> (I <sub>OH</sub> =-50μA) | V <sub>DD</sub> -0.5 | - | - | V | | Output Low Voltage | V <sub>OL1</sub> | R0, R1, R3, R4, R5, R6 (I <sub>OL</sub> =1.6mA) | - | - | 0.4 | V | | | V <sub>OL2</sub> | X <sub>OUT</sub> (I <sub>OL</sub> =50μA) | - | - | 0.5 | V | | High Current | I <sub>OL</sub> | R3 (V <sub>OL</sub> =1V) | - | - | 20 | mA | | | I <sub>IH</sub> | R0, R1, R3, R4, R5, R6 | - | ı | 1 | μΑ | | | I <sub>IL</sub> | R0, R1, R3, R4, R5, R6 | -1 | ı | - | μА | | Pull-up Resistor | RPU | R0, R1, R4 | 10 | - | 100 | kΩ | | OSC Feedback Resistor | R <sub>X</sub> | X <sub>IN</sub> , X <sub>OUT</sub> | 0.45 | - | 4.5 | MΩ | | | I <sub>IL</sub> | V <sub>DD</sub> =4.5V | 33 | - | 100 | μS | | Hysteresis | V <sub>T</sub> | INT0, INT1, INT2, INT3, EC0, EC1, SI, SCK, ACLK0, ACLK1, RxD0,RxD1 | 0.3 | - | 0.8 | V | | Power Fail Detect | | | 2.2 | 2.7 | 3.2 | V | | Voltage | $V_{PFD}$ | | 2.5 | 3.0 | 3.5 | V | | ŭ | | | 1.9 | 2.4 | 2.9 | V | | Parameter | Symbol | Pin/Condition | Min. | Тур. | Max. | Unit | |----------------------|--------------------|---------------------------------------------------|------|------|------|------| | | I <sub>DD1</sub> | Active Mode, X <sub>IN</sub> =8MHz | - | - | 15 | mA | | Power Supply Current | I <sub>SLEEP</sub> | Sleep Mode, X <sub>IN</sub> =8MHz | - | - | 6 | mA | | | I <sub>STOP</sub> | Stop Mode, Oscillator Stop, X <sub>IN</sub> =4MHz | - | - | 5 | μА | | | I <sub>RCWDT</sub> | Stop Mode, Oscillator Stop, X <sub>IN</sub> =8MHz | - | - | 40 | μА | # 7.5 AC Characteristics $(T_A = -40 \sim 85$ °C, $V_{DD} = 5V \pm 10\%$ , $V_{SS} = 0V)$ | Davamatar | Sumbal | Pins | ; | Heit | | | |----------------------------------------|------------------------------------|------------------------------------|------|------|------|------------------| | Parameter | Symbol | rins | Min. | Тур. | Max. | - Unit | | Operating Frequency | f <sub>XIN</sub> | X <sub>IN</sub> | 0.4 | - | 12 | MHz | | Oscillation Stabilizing<br>Time (4MHz) | t <sub>ST</sub> | X <sub>IN</sub> , X <sub>OUT</sub> | - | - | 20 | mS | | External Clock Pulse<br>Width | t <sub>CPW</sub> | X <sub>IN</sub> | 35 | - | - | nS | | External Clock Transition Time | t <sub>RCP</sub> ,t <sub>FCP</sub> | X <sub>IN</sub> | - | - | 20 | nS | | Interrupt Pulse Width | t <sub>IW</sub> | INT0, INT1, INT2, INT3 | 2 | - | - | t <sub>SYS</sub> | | RESET Input Width | t <sub>RST</sub> | RESET | 8 | - | - | t <sub>SYS</sub> | | Event Counter Input<br>Pulse Width | t <sub>ECW</sub> | EC0, EC1 | 2 | - | - | t <sub>SYS</sub> | | Event Counter Transition Time | t <sub>REC</sub> ,t <sub>FEC</sub> | EC0, EC1 | - | - | 20 | nS | Figure 7-1 Timing Chart # 7.6 Serial Interface Timing Characteristics $(T_{A}\!\!=\!\!-40\!\!\sim\!\!+85^{\circ}\!C,\,V_{DD}\!\!=\!\!5V\!\!\pm\!\!10\%,\,V_{SS}\!\!=\!\!0V,\,f_{XIN}\!\!=\!\!8MHz)$ | B | 0 | D: | S | ns | 1111 | | | |-------------------------------------------|----------------------------------------|------|------------------------|------|--------------------|------|--| | Parameter | Symbol | Pins | Min. | Тур. | Max. | Unit | | | Serial Input Clock Pulse | t <sub>SCYC</sub> | SCK | 2t <sub>SYS</sub> +200 | - | - | nS | | | Serial Input Clock Pulse Width | t <sub>SCKW</sub> | SCK | t <sub>SYS</sub> +70 | - | - | nS | | | Serial Input Clock Pulse Transition Time | t <sub>FSCK</sub> | SCK | - | - | 30 | nS | | | Serial Input Pulse Transition Time | t <sub>FSIN</sub><br>t <sub>RSIN</sub> | SI | - | - | 30 | nS | | | Serial Input Setup Time (External SCK) | t <sub>SUS</sub> | SI | 100 | - | - | nS | | | Serial Input Setup Time (Internal SCK) | t <sub>SUS</sub> | SI | 200 | - | | nS | | | Serial Input Hold Time | t <sub>HS</sub> | SI | t <sub>SYS</sub> +70 | - | | nS | | | Serial Output Clock Cycle Time | t <sub>SCYC</sub> | SCK | 4t <sub>SYS</sub> | - | 16t <sub>SYS</sub> | nS | | | Serial Output Clock Pulse Width | t <sub>SCKW</sub> | SCK | t <sub>SYS</sub> -30 | | | nS | | | Serial Output Clock Pulse Transition Time | t <sub>FSCK</sub> | SCK | | | 30 | nS | | | Serial Output Delay Time | s <sub>OUT</sub> | so | | | 100 | nS | | Figure 7-2 Serial I/O Timing Chart # 7.7 Typical Characteristic Curves This graphs and tables provided in this section are for design guidance only and are not tested or guaranteed. In some graphs or tables the data presented are outside specified operating range (e.g. outside specified $V_{DD}$ range). This is for information only and devices are guaranteed to operate properly only within the specified range. The data presented in this section is a statistical summary of data collected on units from different lots over a period of time. "Typical" represents the mean of the distribution while "max" or "min" represents (mean + $3\sigma$ ) and (mean – $3\sigma$ ) respectively where $\sigma$ is standard deviation #### 8. MEMORY ORGANIZATION The MC80F0208/16/24 has separate address spaces for Program memory and Data Memory. Program memory can only be read, not written to. It can be up to 48K bytes of Program memory. Data memory can be read and written to up to 1024 bytes including the stack area. # 8.1 Registers This device has six registers that are the Program Counter (PC), a Accumulator (A), two index registers (X, Y), the Stack Pointer (SP), and the Program Status Word (PSW). The Program Counter consists of 16-bit register. Figure 8-1 Configuration of Registers **Accumulator:** The Accumulator is the 8-bit general purpose register, used for data operation such as transfer, temporary saving, and conditional judgement, etc. The Accumulator can be used as a 16-bit register with Y Register as shown below. Figure 8-2 Configuration of YA 16-bit Register **X, Y Registers**: In the addressing mode which uses these index registers, the register contents are added to the specified address, which becomes the actual address. These modes are extremely effective for referencing subroutine tables and memory tables. The index registers also have increment, decrement, comparison and data transfer functions, and they can be used as simple accumulators. **Stack Pointer:** The Stack Pointer is an 8-bit register used for occurrence interrupts and calling out subroutines. Stack Pointer identifies the location in the stack to be accessed (save or restore). Generally, SP is automatically updated when a subroutine call is executed or an interrupt is accepted. However, if it is used in excess of the stack area permitted by the data memory allocating configuration, the user-processed data may be lost. The stack can be located at any position within $100_{\rm H}$ to $1{\rm FF_H}$ of the internal data memory. The SP is not initialized by hardware, requiring to write the initial value (the location with which the use of the stack starts) by using the initialization routine. Normally, the initial value of "FF<sub>H</sub>" is used. **Note:** The Stack Pointer must be initialized by software because its value is undefined after Reset. Example: To initialize the SP LDX #0FFH TXSP ; SP $\leftarrow$ FFH **Program Counter:** The Program Counter is a 16-bit wide which consists of two 8-bit registers, PCH and PCL. This counter indicates the address of the next instruction to be executed. In reset state, the program counter has reset routine address (PC<sub>H</sub>:0FF<sub>H</sub>, PC<sub>L</sub>:0FE<sub>H</sub>). **Program Status Word**: The Program Status Word (PSW) contains several bits that reflect the current state of the CPU. The PSW is described in Figure 8-3. It contains the Negative flag, the Overflow flag, the Break flag the Half Carry (for BCD operation), the Interrupt enable flag, the Zero flag, and the Carry flag. [Carry flag C] This flag stores any carry or borrow from the ALU of CPU after an arithmetic operation and is also changed by the Shift Instruction or Rotate Instruction. [Zero flag Z] This flag is set when the result of an arithmetic operation or data transfer is "0" and is cleared by any other result. Figure 8-3 PSW (Program Status Word) Register #### [Interrupt disable flag I] This flag enables/disables all interrupts except interrupt caused by Reset or software BRK instruction. All interrupts are disabled when cleared to "0". This flag immediately becomes "0" when an interrupt is served. It is set by the EI instruction and cleared by the DI instruction. #### [Half carry flag H] After operation, this is set when there is a carry from bit 3 of ALU or there is no borrow from bit 4 of ALU. This bit can not be set or cleared except CLRV instruction with Overflow flag (V). ### [Break flag B] This flag is set by software BRK instruction to distinguish BRK from TCALL instruction with the same vector address. #### [Direct page flag G] This flag assigns RAM page for direct addressing mode. In the direct addressing mode, addressing area is from zero page $00_{\rm H}$ to 0FF $_{\rm H}$ when this flag is "0". If it is set to "1", addressing area is assigned $100_{\rm H}$ to 1FF $_{\rm H}$ . It is set by SETG instruction and cleared by CLRG. ### [Overflow flag V] This flag is set to "1" when an overflow occurs as the result of an arithmetic operation involving signs. An overflow occurs when the result of an addition or subtraction exceeds +127(7F $_{\rm H}$ ) or -128(80 $_{\rm H}$ ). The CLRV instruction clears the overflow flag. There is no set instruction. When the BIT instruction is executed, bit 6 of memory is copied to this flag. # [Negative flag N] This flag is set to match the sign bit (bit 7) status of the result of a data or arithmetic operation. When the BIT instruction is executed, bit 7 of memory is copied to this flag. Figure 8-4 Stack Operation ### 8.2 Program Memory A 16-bit program counter is capable of addressing up to 64K bytes, but this device has 32/48K bytes program memory space only physically implemented. Accessing a location above ${\rm FFFF}_H$ will cause a wrap-around to $0000_H$ . Figure 8-5, shows a map of Program Memory. After reset, the CPU begins execution from reset vector which is stored in address ${\rm FFFE}_{\rm H}$ and ${\rm FFFF}_{\rm H}$ as shown in Figure 8-6. As shown in Figure 8-5, each area is assigned a fixed location in Program Memory. Program Memory area contains the user program Figure 8-5 Program Memory Map Page Call (PCALL) area contains subroutine program to reduce program byte length by using 2 bytes PCALL instead of 3 bytes CALL instruction. If it is frequently called, it is more useful to save program byte length. Table Call (TCALL) causes the CPU to jump to each TCALL address, where it commences the execution of the service routine. The Table Call service area spaces 2-byte for every TCALL: $0FFCO_H$ for TCALL15, $0FFCO_H$ for TCALL14, etc., as shown in Figure 8-7. Example: Usage of TCALL The interrupt causes the CPU to jump to specific location, where it commences the execution of the service routine. The External interrupt 0, for example, is assigned to location 0FFFC $_{\rm H}$ . The interrupt service locations spaces 2-byte interval: 0FFFA $_{\rm H}$ and 0FFFB $_{\rm H}$ for External Interrupt 1, 0FFFC $_{\rm H}$ and 0FFFD $_{\rm H}$ for External Interrupt 0, etc. Any area from $0FF00_{\rm H}$ to $0FFFF_{\rm H}$ , if it is not going to be used, its service location is available as general purpose Program Memory. | Address | Vector Area Memory | |--------------------|----------------------------------| | 0FFE0 <sub>H</sub> | Basic Interval Timer | | E2 | Watch / Watchdog Timer Interrupt | | E4 | A/D Converter | | E6 | Timer/Counter 4 Interrupt | | E8 | Timer/Counter 3 Interrupt | | EA | Timer/Counter 2 Interrupt | | EC | Timer/Counter 1 Interrupt | | EE | Timer/Counter 0 Interrupt | | F0 | Serial Input/Output (SIO) | | F2 | UART1 Rx/Tx interrupt | | F4 | UART0 Rx/Tx interrupt | | F6 | External Interrupt 3 | | F8 | External Interrupt 2 | | FA | External Interrupt 1 | | FC | External Interrupt 0 | | FE | RESET | Figure 8-6 Interrupt Vector Area Figure 8-7 PCALL and TCALL Memory Area #### $PCALL \rightarrow rel$ 4F35 PCALL 35H #### $TCALL \rightarrow n$ 4A TCALL 4 Example: The usage software example of Vector address for MC80F0208/16/24 . ``` ;Interrupt Vector Table OFFEOH ORG DW BIT_TIMER ; BIT WATCH_WDT ; WDT & WT DW ; AD Converter DW ADC ; Timer-4 TIMER4 DW ; Timer-3 DW TIMER3 DW TIMER2 ; Timer-2 ; Timer-1 DW TIMER1 ; Timer-0 DW TIMER0 ; Serial Interface DM SIO UART1 DW ; UART1 Rx/Tx DW UART0 ; UARTO Rx/Tx DW INT3 ; Ext Int.3 ; Ext Int.2 ; Ext Int.1 DW INT2 INT1 DM DW INT0 ; Ext Int.0 DW RESET ; Reset MAIN PROGRAM RESET: DI ;Disable All Interrupt RAMCLEAR: #00H LDX ;USER RAM START ADDRESS LOAD ! LDY #0 RAMCLR1: #00H LDA ;Page0 Ram Clear(0000h ~ 00BFh) {X}+ STA #OCOH CMPX BNE RAMCLR1 INC ;Pagel Ram Select STY !RPR SETG ;G-FLAG SET ! LDX #00H RAMCLR2: #00H LDA STA {X}+ CMPX #0ÓH BNE RAMCLR2 INC v CMPY #4 BCS RAMCLR3 ;Page1 ~ Page3 Clear(0100h ~ 03FFh) STY !RPR SETG BRA RAMCLR2 RAMCLR3: STY !RPR ;Page4 Clear(0400h ~ 043Fh) SETG #00H ;A <-- #0 LDA STA {X}+ #40H CMPX BNE RAMCLR3 CLRG ;G-FLAG CLEAR ! #0FFH L'DX TXSP ;Initial Stack Point (01FFh) ``` #### 8.3 Data Memory Figure 8-8 shows the internal Data Memory space available. Data Memory is divided into three groups, a user RAM, control registers, and Stack memory. Figure 8-8 Data Memory Map #### **User Memory** The MC80F0208/16/24 has $1024 \times 8$ bits for the user memory (RAM). RAM pages are selected by RPR (See Figure 8-9). **Note:** After setting RPR(RAM Page Select Register), be sure to execute SETG instruction. When executing CLRG instruction, be selected PAGE0 regardless of RPR. #### **Control Registers** The control registers are used by the CPU and Peripheral function blocks for controlling the desired operation of the device. Therefore these registers contain control and status bits for the interrupt system, the timer/ counters, analog to digital converters and I/O ports. The control registers are in address range of $0\text{CO}_H$ to $0\text{FF}_H$ . Note that unoccupied addresses may not be implemented on the chip. Read accesses to these addresses will in general return random data, and write accesses will have an indeterminate effect. More detailed informations of each register are explained in each peripheral section. **Note:** Write only registers can not be accessed by bit manipulation instruction. Do not use read-modify-write instruction. Use byte manipulation instruction, for example "LDM". Example; To write at CKCTLR LDM CLCTLR, #0AH; Divide ratio(÷32) #### Stack Area The stack provides the area where the return address is saved before a jump is performed during the processing routine at the execution of a subroutine call instruction or the acceptance of an interrupt. When returning from the processing routine, executing the subroutine return instruction [RET] restores the contents of the program counter from the stack; executing the interrupt return instruction [RETI] restores the contents of the program counter and flags. The save/restore locations in the stack are determined by the stack pointed (SP). The SP is automatically decreased after the saving, and increased before the restoring. This means the value of the SP indicates the stack location number for the next save. Refer to Figure 8-4 on page 22. Figure 8-9 RPR(RAM Page Select Register) | Address | Register Name | Symbol | R/W | | | Init | ial | Va | lue | ) | | Addressing | |---------|--------------------------------|--------|-------|---|---|------|-----|----|-----|---|---|-------------------| | Audiess | Register Name | Symbol | 17/44 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Mode | | 00C0 | R0 port data register | R0 | R/W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | byte, bit1 | | 00C1 | R0 port I/O direction register | R0IO | W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | byte <sup>2</sup> | | 00C2 | R1 port data register | R1 | R/W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | byte, bit | | 00C3 | R1 port I/O direction register | R1IO | W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | byte | | 00C4 | Reserved | | | | | | | | | | | | | 00C5 | Reserv | /ed | | | | | | | | | | | | 00C6 | R3 port data register | R3 | R/W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | byte, bit | | 00C7 | R3 port I/O direction register | R3IO | W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | byte | | 00C8 | R4 port data register | R4 | R/W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | byte, bit | | 00C9 | R4 port I/O direction register | R4IO | W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | byte | | 00CA | R5 port data register | R5 | R/W | - | - | - | 0 | 0 | 0 | 0 | 0 | byte, bit | | 00CB | R5 port I/O direction register | R5IO | W | - | - | - | 0 | 0 | 0 | 0 | 0 | byte | | 00CC | R6 port data register | R6 | R/W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | byte, bit | | 00CD | R6 port I/O direction register | R6IO | W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | byte | | 00CE | Reserv | /ed | 1 | | | | | | | | ' | | | 00CF | Reserv | /ed | | | | | | | | | | | | 00D0 | Timer 0 mode control register | TM0 | R/W | - | - | 0 | 0 | 0 | 0 | 0 | 0 | byte, bit | | | Timer 0 register | T0 | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 00D1 | Timer 0 data register | TDR0 | W | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | byte | | | Timer 0 capture data register | CDR0 | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 00D2 | Timer 1 mode control register | TM1 | R/W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | byte, bit | | 00D3 | Timer 1 data register | TDR1 | W | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | byte | | 00D4 | Timer 1 register | T1 | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | byto | | 0004 | Timer 1 capture data register | CDR1 | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | byte | | 00D5 | Reserv | /ed | | | | | | | | | | | | 00D6 | Timer 2 mode control register | TM2 | R/W | - | - | 0 | 0 | 0 | 0 | 0 | 0 | byte, bit | | | Timer 2 register | T2 | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 00D7 | Timer 2 data register | TDR2 | W | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | byte | | | Timer 2 capture data register | CDR2 | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 00D8 | Timer 3 mode control register | TM3 | R/W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | byte, bit | | 00D9 | Timer 3 data register | TDR3 | W | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | byto | | บบบอ | Timer 3 PWM period register | T3PPR | W | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | byte | **Table 8-1 Control Registers** | A alabasas | Dominton Name | Cumb al | R/W | | | Init | tial | Va | lue | ) | | Addressing | |------------|------------------------------------------------|---------|------|-----------------|---|------|-----------|-------|-----|----|------|------------| | Address | Register Name | Symbol | R/VV | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Mode | | | Timer 3 register | Т3 | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 00DA | Timer 3 PWM duty register | T3PDR | R/W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | byte | | ÷ | Timer 3 capture data register | CDR3 | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 00DB | Timer 3 PWM high register | T3PWHR | W | - | - | - | - | 0 | 0 | 0 | 0 | byte | | 00DC | Timer 4 mode control register | TM4 | R/W | - | - | 0 | 0 | 0 | 0 | 0 | 0 | byte, bit | | | Timer 4 low register | T4L | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 00DD | Timer 4 low data register | TDR4L | W | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | byte | | · | Timer 4 capture low data register | CDR4L | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | Timer 4 high register | T4H | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 00DE | Timer 4 high data register | TDR4H | W | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | byte | | · | Timer 4 capture high data register | CDR4H | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | 00DF | Interrupt flag register | IFR | R/W | - | - | 0 | 0 | 0 | 0 | 0 | 0 | byte, bit | | 00E0 | Buzzer driver register | BUZR | W | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | byte | | 00E1 | RAM page selection register | RPR | R/W | - | - | - | - | - | 0 | 0 | 0 | byte, bit | | 00E2 | SIO mode control register | SIOM | R/W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | byte, bit | | 00E3 | SIO data shift register | SIOR | R/W | | | Uı | nde | efine | ed | | | byte, bit | | 00E4 | Reser | ved | | | | | | | | | | | | 00E5 | Reser | ved | | | | | | | | | | | | 00E6 | UART0 mode register | ASIMR0 | R/W | 0 0 0 0 - 0 0 - | | | byte, bit | | | | | | | 00E7 | UART0 status register | ASISR0 | R | - | - | - | - | - | 0 | 0 | 0 | byte | | 00E8 | UART0 Baud rate generator control register | BRGCR0 | R/W | 1 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | byte, bit | | 00E9 | UART0 Receive buffer register | RXR0 | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | byte | | 00L3 | UART0 Transmit shift register | TXR0 | W | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | byte | | 00EA | Interrupt enable register high | IENH | R/W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | byte, bit | | 00EB | Interrupt enable register low | IENL | R/W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | byte, bit | | 00EC | Interrupt request register high | IRQH | R/W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | byte, bit | | 00ED | Interrupt request register low | IRQL | R/W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | byte, bit | | 00EE | Interrupt edge selection register | IEDS | R/W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | byte, bit | | 00EF | A/D converter mode control register | ADCM | R/W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | byte, bit | | 00F0 | A/D converter result high register | ADCRH | R(W) | 0 | 1 | | Uı | nde | fin | ed | | byte | | 00F1 | A/D converter result low register | ADCRL | R | | _ | U | nde | efine | ed | | | byte | | 00F2 | Basic interval timer register BITR R Undefined | | | | | | | | | | byte | | | 001 2 | Clock control register CKCTLR W 0 - 0 1 | | | | | | | | | | 1 | Dyle | | 00F3 | Reser | ved | | | | | | | | | | | **Table 8-1 Control Registers** | Address | Register Name | Symbol | R/W | | | Init | ial | Va | lue | ) | | Addressing | |---------|--------------------------------------------|--------|-------|-----------|-----|------|-----|----|-----|---|------|------------| | Addiess | Register Name | Symbol | 14/11 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Mode | | 00F4 | Watch dog timer register | WDTR | W | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | buto | | UUF4 | Watch dog timer data register | WDTDR | R | Undefined | | | | | | | byte | | | 00F5 | Stop & sleep mode control register | SSCR | W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | byte | | 00F6 | Watch timer mode register | WTMR | R/W | 0 | - | - | 0 | 0 | 0 | 0 | 0 | byte, bit | | 00F7 | PFD control register | PFDR | R/W | - | - | - | - | - | 0 | 0 | 0 | byte, bit | | 00F8 | Port selection register 0 | PSR0 | W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | byte | | 00F9 | Port selection register 1 | PSR1 | W | - | - | - | - | 0 | 0 | 0 | 0 | byte | | 00FA | Reser | | | | | | | | | | | | | 00FB | Reser | ved | | | | | | | | | | | | 00FC | Pull-up selection register 0 | PU0 | W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | byte | | 00FD | Pull-up selection register 1 | PU1 | W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | byte | | 00FE | Pull-up selection register 4 | PU4 | W | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | byte | | 00FF | Reser | ved | | | | | | | | | | | | 0EE6 | UART1 mode register | ASIMR1 | R/W | 0 | 0 | 0 | 0 | - | 0 | 0 | - | byte, bit | | 0EE7 | UART1 status register | ASISR1 | R | - | - | - | - | - | 0 | 0 | 0 | byte | | 0EE8 | UART1 Baud rate generator control register | BRGCR1 | R/W | - | 0 | 0 | 1 | 0 | 0 | 0 | 0 | byte, bit | | 0EE9 | UART1 Receive buffer register | RXR1 | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | buto | | UEE9 | UART1 Transmit shift register | TXR1 | W | 1 | 1 1 | | 1 | 1 | 1 | 1 | 1 | byte | **Table 8-1 Control Registers** - The 'byte, bit' means registers are controlled by both bit and byte manipulation instruction. Caution) The R/W register except T1PDR and T3PDR are both can be byte and bit manipulated. - The 'byte' means registers are controlled by only byte manipulation instruction. Do not use bit manipulation instruction such as SET1, CLR1 etc. If bit manipulation instruction is used on these registers, content of other seven bits are may varied to unwanted value. - 3. The UART1 control register ASIMR1,ASISR1, BRGCR1,RXR1 and TXR1 are located at EE6H ~ EE9H address. These address must be accessed(read and written) by absolute addressing manipulation instruction. <sup>\*</sup>The mark of '-' means this bit location is reserved. | Address | Name | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | | | | | | |---------|-------------------------|-------------|--------------------|--------------|---------------|---------------|--------------|--------------|-------|--|--|--|--|--| | 0C0H | R0 | R0 Port Da | ta Register | | | | | | | | | | | | | 0C1H | R0IO | R0 Port Dir | ection Regis | ter | | | | | | | | | | | | 0C2H | R1 | R1 Port Da | ta Register | | | | | | | | | | | | | 0C3H | R1IO | R1 Port Dir | ection Regis | ter | | | | | | | | | | | | 0C4H | | Reserved | | | | | | | | | | | | | | 0C5H | | Reserved | | | | | | | | | | | | | | 0C6H | R3 | R3 Port Da | ta Register | | | | | | | | | | | | | 0C7H | R3IO | R3 Port Dir | ection Regis | ter | | | | | | | | | | | | 0C8H | R4 | R4 Port Da | Port Data Register | | | | | | | | | | | | | 0C9H | R4IO | R4 Port Dir | ection Regis | ter | | | | | | | | | | | | 0CAH | R5 | - | - | - | R5 Port Dat | ta Register | | | | | | | | | | 0CBH | R5IO | - | - | - | R5 Port Dire | ection Regist | er | | | | | | | | | 0CCH | R6 | R6 Port Da | ta Register | | | | | | | | | | | | | 0CDH | R6IO | R6 Port Dir | ection Regis | ter | | | | | | | | | | | | 0CEH | | Reserved | | | | | | | | | | | | | | 0CFH | | Reserved | Reserved | | | | | | | | | | | | | 0D0H | TM0 | - | - | CAP0 | T0CK2 | T0CK1 | T0CK0 | T0CN | TOST | | | | | | | 0D1H | T0/TDR0/<br>CDR0 | Timer0 Reg | jister / Timer | 0 Data Regis | ster / Timer0 | Capture Dat | a Register | | | | | | | | | 0D2H | TM1 | - | 16BIT | - | CAP1 | T1CK1 | T1CK0 | T1CN | T1ST | | | | | | | 0D3H | TDR1 | Timer1 Dat | a Register | | 1 | " | | | | | | | | | | 0D4H | T1/CDR1 | Timer1 Reg | jister / Timer | 1 Capture Da | ata Register | | | | | | | | | | | 0D5H | PWM1HR | - | - | - | - | Т | imer1 PWM | High Registe | er | | | | | | | 0D6H | TM2 | - | - | CAP2 | T2CK2 | T2CK1 | T2CK0 | T2CN | T2ST | | | | | | | 0D7H | T2/TDR2/<br>CDR2 | Timer2 Reg | jister / Timer | 2 Data Regis | ster / Timer2 | Capture Dat | a Register | | | | | | | | | 0D8H | TM3 | POL | 16BIT | PWM3E | CAP3 | T3CK1 | T3CK0 | T3CN | T3ST | | | | | | | 0D9H | TDR3/<br>T3PPR | Timer3 Dat | a Register / | Γimer3 PWM | Period Regi | ster | | | | | | | | | | 0DAH | T3/CDR3/<br>T3PDR | Timer3 Reg | jister / Timer | 3 Capture Da | ata Register | / Timer3 PW | M Duty Regis | ster | | | | | | | | 0DBH | PWM3HR | - | - | - | - | Timer3 PW | M High Regi | ster | | | | | | | | 0DCH | TM4 | - | - | CAP4 | T4CK2 | T4CK1 | T4CK0 | T4CN | T4ST | | | | | | | 0DDH | T4L/<br>TDR4L/<br>CDR4L | Timer4 Reg | gister Low / T | ïmer4 Data I | Register Low | / Timer4 Ca | pture Data R | egister Low | | | | | | | **Table 8-2 Control Register Function Description** | Address | Name | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | |---------|-------------------------|-----------------------|----------------------------|----------------|---------------|---------------|-------------|---------------|-------------| | 0DEH | T4H/<br>TDR4H/<br>CDR4H | Timer4 Reg | gister High / <sup>-</sup> | Timer4 Data | Register Higl | n / Timer4 Ca | apture Data | Register High | 1 | | 0DFH | IFR | - | - | RX0IOF | TX0IOF | RX1IOF | TX1IOF | WTIOF | WDTIOF | | 0E0H | BUZR | BUCK1 | BUCK0 | BUR5 | BUR4 | BUR3 | BUR2 | BUR1 | BUR0 | | 0E1H | RPR | - | - | - | - | - | RPR2 | RPR1 | RPR0 | | 0E2H | SIOM | POL | IOSW | SM1 | SM0 | SCK1 | SCK0 | SIOST | SIOSF | | 0E3H | SIOR | SIO Data S | hift Register | | | | | | | | 0E4H | | Reserved | | | | | | | | | 0E5H | | Reserved | | | | | | | | | 0E6H | ASIMR0 | TXE0 | RXE0 | PS01 | PS00 | - | SL0 | ISRM0 | - | | 0E7H | ASISR0 | - | - | - | - | - | PE0 | FE0 | OVE0 | | 0E8H | BRGCR0 | - | TPS02 | TPS01 | TPS00 | MLD03 | MLD02 | MLD01 | MLD00 | | 05011 | RXR0 | UART0 Red | ceive Buffer | Register | 1 | 1 | 1 | | 1 | | 0E9H | TXR0 | UART0 Tra | nsmit Shift R | Register | | | | | | | 0EAH | IENH | INT0E | INT1E | INT2E | INT3E | RXE | TXE | SIOE | T0E | | 0EBH | IENL | T1E | T2E | T3E | T4E | ADCE | WDTE | WTE | BITE | | 0ECH | IRQH | INT0IF | INT1IF | INT2IF | INT3IF | RXIF | TXIF | SIOIF | T0IF | | 0EDH | IRQL | T1IF | T2IF | T3IF | T4IF | ADCIF | WDTIF | WTIF | BITIF | | 0EEH | IEDS | IED3H | IED3L | IED2H | IED2L | IED1H | IED1L | IED0H | IED0L | | 0EFH | ADCM | ADEN | ADCK | ADS3 | ADS2 | ADS1 | ADS0 | ADST | ADSF | | 0F0H | ADCRH | PSSEL1 | PSSEL0 | ADC8 | - | - | - | ADC Resul | t Reg. High | | 0F1H | ADCRL | ADC Resul | t Register Lo | )W | 1 | 1 | | 1 | | | | BITR <sup>1</sup> | Basic Interv | /al Timer Dat | ta Register | | | | | | | 0F2H | CKCTLR <sup>1</sup> | ADRST | - | RCWDT | WDTON | BTCL | BTS2 | BTS1 | BTS0 | | 0F3H | | Reserved | | | | | | 1 | | | | WDTR | WDTCL | 7-bit Watch | dog Timer R | egister | | | | | | 0F4H | WDTDR | Watchdog <sup>-</sup> | Timer Data R | Register (Cou | nter Registe | ·) | | | | | 0F5H | SSCR | Stop & Slee | ep Mode Cor | ntrol Register | | | | | | | 0F6H | WTMR | WTEN | - | - | WTIN2 | WTIN1 | WTIN0 | WTCK1 | WTCK0 | | 0F7H | PFDR | - | - | - | - | - | PFDEN | PFDM | PFDS | | 0F8H | PSR0 | PWM3O | - | EC1E | EC0E | INT3E | INT2E | INT1E | INT0E | | 0F9H | PSR1 | - | - | - | - | XTEN | BUZO | - | - | | 0FAH | | Reserved | | | | | | | | | 0FBH | | Reserved | | | | | | | | | 0FCH | PU0 | | Selection Re | gister | | | | | | | 0FDH | PU1 | - | Selection Re | | | | | | | | 0FEH | PU4 | • | Selection Re | | | | | | | **Table 8-2 Control Register Function Description** | Address | Name | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | |-------------------|--------|-----------|----------------|----------|-------|-------|-------|-------|-------| | 0FFH | | Reserved | | | | | | | | | EE6H <sup>2</sup> | ASIMR1 | TXE1 | RXE1 | PS11 | PS10 | - | SL1 | ISRM1 | - | | EE7H <sup>2</sup> | ASISR1 | - | - | - | - | - | PE1 | FE1 | OVE1 | | EE8H <sup>2</sup> | BRGCR1 | - | TPS12 | TPS11 | TPS10 | MLD13 | MLD12 | MLD11 | MLD10 | | ===:12 | RXR1 | UART1 Red | ceive Buffer I | Register | | | | | | | EE9H <sup>2</sup> | TXR1 | UART1 Tra | nsmit Shift R | egister | | | | | | #### **Table 8-2 Control Register Function Description** - The register BITR and CKCTLR are located at same address. Address F2H is read as BITR, written to CKCTLR. Caution) The registers of dark-shaded area can not be accessed by bit manipulation instruction such as "SET1, CLR1", but should be accessed by register operation instruction such as "LDM dp,#imm". - 2. The UART1 control register ASIMR1,ASISR1, BRGCR1,RXR1 and TXR1 are located at EE6H ~ EE9H address. These address must be accessed(read and written) by absolute addressing manipulation instruction. # 8.4 Addressing Mode The MC800 series MCU uses six addressing modes; - Register addressing - Immediate addressing - · Direct page addressing - · Absolute addressing - Indexed addressing - · Register-indirect addressing #### 8.4.1 Register Addressing Register addressing accesses the A, X, Y, C and PSW. #### 8.4.2 Immediate Addressing → #imm In this mode, second byte (operand) is accessed as a data immediately. Example: 0435 ADC #35H When G-flag is 1, then RAM address is defined by 16-bit address which is composed of 8-bit RAM paging register (RPR) and 8-bit immediate data. Example: G=1 E45535 LDM 35H, #55H #### 8.4.3 Direct Page Addressing → dp In this mode, a address is specified within direct page. Example; G=0 C535 LDA 35H $; A \leftarrow RAM[35H]$ # 983501 INC !0135H ;A $\leftarrow ROM[135H]$ # 8.4.4 Absolute Addressing → !abs Absolute addressing sets corresponding memory data to Data, i.e. second byte (Operand I) of command becomes lower level address and third byte (Operand II) becomes upper level address. With 3 bytes command, it is possible to access to whole memory area. ADC, AND, CMP, CMPX, CMPY, EOR, LDA, LDX, LDY, OR, SBC, STA, STX, STY #### Example; 0735F0 ADC !0F035H ;A ←ROM[0F035H] The operation within data memory (RAM) ASL, BIT, DEC, INC, LSR, ROL, ROR Example; Addressing accesses the address $0135_{\mbox{\scriptsize H}}$ regardless of G-flag. # 8.4.5 Indexed Addressing # X indexed direct page (no offset) $\rightarrow$ {X} In this mode, a address is specified by the X register. ADC, AND, CMP, EOR, LDA, OR, SBC, STA, XMA Example; $X=15_H$ , G=1 D4 LDA $\{X\}$ ; ACC $\leftarrow$ RAM[X]. ## X indexed direct page, auto increment $\rightarrow$ {X}+ In this mode, a address is specified within direct page by the X register and the content of X is increased by 1. LDA, STA Example; G=0, $X=35_H$ DB LDA $\{X\}$ + $data \to A$ # X indexed direct page (8 bit offset) → dp+X This address value is the second byte (Operand) of command plus the data of X-register. And it assigns the memory in Direct page. ADC, AND, CMP, EOR, LDA, LDY, OR, SBC, STA STY, XMA, ASL, DEC, INC, LSR, ROL, ROR Example; G=0, $X=0F5_H$ C645 LDA 45H+X # Y indexed direct page (8 bit offset) → dp+Y This address value is the second byte (Operand) of command plus the data of Y-register, which assigns Memory in Direct page. This is same with above (2). Use Y register instead of X. #### Y indexed absolute → !abs+Y Sets the value of 16-bit absolute address plus Y-register data as Memory. This addressing mode can specify memory in whole area. Example; Y=55<sub>H</sub> !0FA00H+Y ## 8.4.6 Indirect Addressing data ## Direct page indirect $\rightarrow$ [dp] Assigns data address to use for accomplishing command which sets memory data (or pair memory) by Operand. Also index can be used with Index register X,Y. JMP, CALL D500FA 0FA55H LDA Example; G=0 3F35 JMP [35H] ## X indexed indirect $\rightarrow$ [dp+X] Processes memory data as Data, assigned by 16-bit pair memory which is determined by pair data [dp+X+1][dp+X] Operand plus X-register data in Direct page. ADC, AND, CMP, EOR, LDA, OR, SBC, STA Example; G=0, $X=10_H$ # Y indexed indirect $\rightarrow$ [dp]+Y Processes memory data as Data, assigned by the data [dp+1][dp] of 16-bit pair memory paired by Operand in Direct page plus Y-register data. ADC, AND, CMP, EOR, LDA, OR, SBC, STA Example; G=0, $Y=10_H$ 1725 ADC [25H]+Y ## Absolute indirect → [!abs] The program jumps to address specified by 16-bit absolute address. JMP Example; G=0 1F25E0 JMP [!OC025H] #### **9. I/O PORTS** The MC80F0208/16/24 has six ports (R0, R1, R3, R4, R5 and R6). These ports pins may be multiplexed with an alternate function for the peripheral features on the device. R3 port can drive maximum 20mA of high current in output low state, so it can directly drive LED device. All pins have data direction registers which can define these ports as output or input. A "1" in the port direction register configure the corresponding port pin as output. Conversely, write "0" to the corresponding bit to specify it as input pin. For example, to use the even numbered bit of R0 as output ports and the odd numbered bits as input ports, write " $55_{\rm H}$ " to address $0C1_{\rm H}$ (R0 port direction register) during initial setting as shown in Figure 9-1. All the port direction registers in the MC80F0208/16/24 have 0 written to them by reset function. On the other hand, its initial status is input. Figure 9-1 Example of port I/O assignment **R0 and R0IO register:** R0 is an 8-bit CMOS bidirectional I/O port (address 0C0<sub>H</sub>). Each I/O pin can independently used as an input or an output through the R0IO register (address 0C1<sub>H</sub>). The on-chip pull-up resistor can be connected to them in 1-bit units with a pull-up selection register 0 (PU0). **R1 and R1IO register:** R1 is an 5-bit CMOS bidirectional I/O port (address 0C2<sub>H</sub>). Each I/O pin can independently used as an input or an output through the R1IO register (address 0C3<sub>H</sub>). The on-chip pull-up resistor can be connected to them in 1-bit units with a pull-up selection register 1 (PU1). In addition, Port R1 is multiplexed with various special features. The control register PSR0 (address $0F8_H$ ) and PSR1 (address $0F9_H$ ) controls the selection of alternate function. After reset, this value is "0", port may be used as normal I/O port. To use alternate function such as external interrupt, event counter input or timer clock output, write "1" in the corresponding bit of PSR0 or PSR1. Regardless of the direction register R1IO, PSR0 or PSR1 is selected to use as alternate functions, port pin can be used as a corresponding alternate features. | Port Pin | Alternate Function | |----------|----------------------------------------| | R10 | INT0 (External Interrupt 0) | | R11 | INT1 (External Interrupt 1) | | R12 | INT2 (External Interrupt 2) | | R13 | BUZO (Square-wave output for buzzer) | | R15 | EC0 (Event counter input to Counter 0) | **Preliminary** R3 and R3IO register: R3 is an 4-bit CMOS bidirectional I/O port (address $0C6_H$ ). Each I/O pin can independently used as an input or an output through the R3IO register (address $0C7_H$ ). In addition, Port R3 is multiplexed with various special features. After reset, this value is "0", port may be used as normal I/O port. | Port Pin | Alternate Function | |----------|---------------------------| | R30 | - | | R31 | ACLK1 (UART1 clock input) | | R32 | RxD1 (UART1 data input) | | R33 | TxD1(UART1 data output) | **R4 and R4IO register:** R4 is an 8-bit CMOS bidirectional I/O port (address 0C8<sub>H</sub>). Each I/O pin can independently used as an input or an output through the R4IO register (address 0C9<sub>H</sub>). The on-chip pull-up resistor can be connected to them in 1-bit units with a pull-up selection register 4 (PU4). In addition, Port R4 is multiplexed with various special features. After reset, this value is "0", port may be used as normal I/O port. | Port P | in | Alternate Function | | | | | |--------|----|------------------------------|--|--|--|--| | R40 | | - | | | | | | R41 | | - | | | | | | R42 | | SCK (SIO clock input/output) | | | | | | R43 | | SI (SIO data input) | | | | | | R44 | | SO (Serial1 data output) | | | | | | R45 | | ACLK0 (UART0 clock input) | | | | | | R46 | | RxD0 (UART0 data input) | | | | | | R47 | | TxD0 (UART0 data output) | | | | | **R5 and R5IO register:** R5 is an 3-bit CMOS bidirectional I/O port (address 0CA<sub>H</sub>). Each I/O pin can independently used as an input or an output through the R5IO register (address 0CB<sub>H</sub>). In addition, Port R5 is multiplexed with various special features. The control register PSR0 (address 0F8<sub>H</sub>) and PSR1 (address 0F9<sub>H</sub>) controls the selection of alternate function. After reset, this value is "0", port may be used as normal I/O port. To use alternate function such as external interrupt, event counter input, timer clock output or PWM output, write "1" in the corresponding bit of PSR0 or PSR1. Regardless of the direction register R5IO, PSR0 or PSR1 is selected to use as alternate functions, port pin can be used as a corresponding alternate features. | Port Pin | Alternate Function | |----------|----------------------------------------| | R50 | INT3 (External Interrupt 3) | | R51 | EC1 (Event counter input to Counter 2) | | R54 | PWM3O (PWM3/T3O output) | **R6 and R6IO register:** R6 is an 8-bit CMOS bidirectional I/O port (address $0CC_H$ ). Each I/O pin can independently used as an input or an output through the R6IO register (address $0CD_H$ ). In addition, Port R6 is multiplexed with AD converter analog input AN0~AN7. | Port Pin | Alternate Function | | | | |----------|---------------------------|--|--|--| | R60 | AN0 (ADC input channel 0) | | | | | R61 | AN1 (ADC input channel 1) | | | | | R62 | AN2 (ADC input channel 2) | | | | | R63 | AN3 (ADC input channel 3) | | | | | R64 | AN4 (ADC input channel 4) | | | | | R65 | AN5 (ADC input channel 5) | | | | | R66 | AN6 (ADC input channel 6) | | | | | R67 | AN7 (ADC input channel 7) | | | | R6IO (address $\mathrm{CD_H}$ ) controls the direction of the R6 pins, except when they are being used as analog input channels. The user don't have to keep the pins configured as inputs when using them as analog input channels, because the analog input mode is activated by the setting of ADC enable bit of ADCM register and ADC channel selection | R6 Dat | ta Register | ADDRESS: 0CC <sub>H</sub><br>RESET VALUE: 00 <sub>H</sub> | |--------|-----------------|-----------------------------------------------------------| | De Dir | ection Register | Input / Output data ADDRESS: 0CD <sub>H</sub> | | R6IO | ection register | RESET VALUE: 00 <sub>H</sub> | | | | Port Direction<br>0: Input<br>1: Output | #### 10. CLOCK GENERATOR As shown in Figure 10-1, the clock generator produces the basic clock pulses which provide the system clock to be supplied to the CPU and the peripheral hardware. It contains main-frequency clock oscillator. The system clock operation can be easily obtained by attaching a crystal or a ceramic resonator between the $X_{\rm IN}$ and $X_{\rm OUT}$ pin, respectively. The system clock can also be obtained from the external oscillator. In this case, it is necessary to input a external clock signal to the $X_{\rm IN}$ pin and open the $X_{\rm OUT}$ pin. There are no requirements on the duty cycle of the external clock signal, since the input to the internal clocking circuitry is through a divide-by-two flip-flop, but minimum and maximum high and low times specified on the data sheet must be observed. To the peripheral block, the clock among the not-divided original clock, clocks divided by 1, 2, 4,..., up to 4096 can be provided. Peripheral clock is enabled or disabled by STOP instruction. The peripheral clock is controlled by clock control register (CKCTLR). See "11. BASIC INTERVAL TIMER" on page 41 for details. Figure 10-1 Block Diagram of Clock Generator ## 11. BASIC INTERVAL TIMER The MC80F0208/16/24 has one 8-bit Basic Interval Timer that is free-run and can not stop. Block diagram is shown in Figure 11-1. In addition, the Basic Interval Timer generates the time base for watchdog timer counting. It also provides a Basic interval timer interrupt (BITIF). The 8-bit Basic interval timer register (BITR) is increased every internal count pulse which is divided by prescaler. Since prescaler has divided ratio by 8 to 1024, the count rate is 1/8 to 1/1024 of the oscillator frequency. As the count overflow from FFH to 00H, this overflow causes the interrupt to be generated. The Basic Interval Timer is controlled by the clock control register (CKCTLR) shown in Figure 10-2. When write "1" to bit BTCL of CKCTLR, BITR register is cleared to "0" and restart to count-up. The bit BTCL becomes "0" after one machine cycle by hardware. If the STOP instruction executed after writing "1" to bit RCWDT of CKCTLR, it goes into the internal RC oscillated watchdog timer mode. In this mode, all of the block is halted except the internal RC oscillator, Basic Interval Timer and Watchdog Timer. More detail informations are explained in Power Saving Function. The bit WDTON decides Watchdog Timer or the normal 7-bit timer. Source clock can be selected by lower 3 bits of CKCTLR. BITR and CKCTLR are located at same address, and address $0F2_H$ is read as a BITR, and written to CKCTLR. Figure 11-1 Block Diagram of Basic Interval Timer | CKCTLR<br>[2:0] | Source clock | Interrupt (overflow) Period (ms)<br>@ f <sub>XIN</sub> = 8MHz | |-----------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------| | 000<br>001<br>010<br>011<br>100<br>101<br>110 | f <sub>XIN</sub> ÷8<br>f <sub>XIN</sub> ÷16<br>f <sub>XIN</sub> ÷32<br>f <sub>XIN</sub> ÷64<br>f <sub>XIN</sub> ÷128<br>f <sub>XIN</sub> ÷256<br>f <sub>XIN</sub> ÷512<br>f <sub>XIN</sub> ÷1024 | 0.256<br>0.512<br>1.024<br>2.048<br>4.096<br>8.192<br>16.384<br>32.768 | **Table 11-1 Basic Interval Timer Interrupt Period** Figure 11-2 BITR: Basic Interval Timer Mode Register ## Example 1: Interrupt request flag is generated every 8.192ms at 4MHz. : LDM CKCTLR,#1BH SET1 BITE EI ## Example 2: Interrupt request flag is generated every 8.192ms at 8MHz. : LDM CKCTLR,#1CH SET1 BITE EI : ## 12. WATCHDOG TIMER The watchdog timer rapidly detects the CPU malfunction such as endless looping caused by noise or the like, and resumes the CPU to the normal state. The watchdog timer signal for detecting malfunction can be selected either a reset CPU or a interrupt request. When the watchdog timer is not being used for malfunction detection, it can be used as a timer to generate an interrupt at fixed intervals. The watchdog timer has two types of clock source. The first type is an on-chip RC oscillator which does not require any external components. This RC oscillator is separate from the external oscillator of the $X_{\rm IN}$ pin. It means that the watchdog timer will run, even if the clock on the $X_{\rm IN}$ pin of the device has been stopped, for example, by entering the STOP mode. The other type is a prescaled system clock. The watchdog timer consists of 7-bit binary counter and the watchdog timer data register. When the value of 7-bit binary counter is equal to the lower 7 bits of WDTR, the interrupt request flag is generated. This can be used as Watchdog timer interrupt or reset the CPU in accordance with the bit WDTON. **Note:** Because the watchdog timer counter is enabled after clearing Basic Interval Timer, after the bit WDTON set to "1", maximum error of timer is depend on prescaler ratio of Basic Interval Timer. The 7-bit binary counter is cleared by setting WDTCL(bit7 of WDTR) and the WDTCL is cleared automatically after 1 machine cycle. The RC oscillated watchdog timer is activated by setting the bit RCWDT as shown below. ``` LDM CKCTLR,#3FH; enable the RC-OSC WDT LDM WDTR,#0FFH; set the WDT period LDM SSCR, #5AH; ready for STOP mode STOP; enter the STOP mode NOP NOP; RC-OSC WDT running ``` The RC-WDT oscillation period is vary with temperature, V<sub>DD</sub> and process variations from part to part (approximately, 33~100uS). The following equation shows the RCWDT oscillated watchdog timer time-out. $$T_{RCWDT}$$ = $CLK_{RCWDT} \times 2^8 \times WDTR + (CLK_{RCWDT} \times 2^8)/2$ where, $CLK_{RCWDT} = 33 \sim 100 uS$ In addition, this watchdog timer can be used as a simple 7-bit timer by interrupt WDTIF. The interval of watchdog timer interrupt is decided by Basic Interval Timer. Interval equation is as below. $$T_{WDT} = (WDTR+1) \times Interval \ of \ BIT$$ Figure 12-1 Block Diagram of Watchdog Timer ## **Watchdog Timer Control** Figure 12-2 shows the watchdog timer control register. The watchdog timer is automatically disabled after reset. The CPU malfunction is detected during setting of the detection time, selecting of output, and clearing of the binary counter. Clearing the binary counter is repeated within the detection time. If the malfunction occurs for any cause, the watchdog timer output will become active at the rising overflow from the binary counters unless the binary counter is cleared. At this time, when WDTON=1, a reset is generated, which drives the RESET pin to low to reset the internal hardware. When WDTON=0, a watchdog timer interrupt (WDTIF) is generated. The WDTON bit is in register CLKCTLR. The watchdog timer temporarily stops counting in the STOP mode, and when the STOP mode is released, it automatically restarts (continues counting). Figure 12-2 WDTR: Watchdog Timer Control Register Example: Sets the watchdog timer detection time to 1 sec. at 4.194304MHz #### **Enable and Disable Watchdog** Watchdog timer is enabled by setting WDTON (bit 4 in CKCTLR) to "1". WDTON is initialized to "0" during reset and it should be set to "1" to operate after reset is released. Example: Enables watchdog timer for Reset : LDM CKCTLR, $$\#xxx1\_xxxxB$$ ; WDTON $\leftarrow$ 1 : . The watchdog timer is disabled by clearing bit 4 (WDTON) of CKCTLR. The watchdog timer is halted in STOP mode and restarts automatically after STOP mode is released. ## **Watchdog Timer Interrupt** The watchdog timer can be also used as a simple 7-bit timer by clearing bit4 of CKCTLR to "0". The interval of watchdog timer interrupt is decided by Basic Interval Timer. Interval equation is shown as below. $$T_{WDT} = (WDTR + 1) \times Interval \ of \ BIT$$ The stack pointer (SP) should be initialized before using the watchdog timer output as an interrupt source. Example: 7-bit timer interrupt set up. ``` LDM CKCTLR,\#xxx0\_xxxxB;WDTON \leftarrow 0 LDM WDTR,\#8FH;WDTCL \leftarrow 1 ``` Figure 12-3 Watchdog timer Timing If the watchdog timer output becomes active, a reset is generated, which drives the $\overline{RESET}$ pin low to reset the internal hardware. The main clock oscillator also turns on when a watchdog timer reset is generated in sub clock mode. The WDTIF bit of IFR register is set when watchdog timer interrupt is generated. (Refer to Figure 12-4) Figure 12-4 IFR(Interrupt Flag Register) #### 13. WATCH TIMER The watch timer generates interrupt for watch operation. The watch timer consists of the clock selector, 15-bit binary counter, interval selector and watch timer mode register. It is a multi-purpose timer. It is generally used for watch design. The bit 0,1 of WTMR select the clock source of watch timer among $f_{XIN} \div 2$ , $f_{XIN} \div 2^7$ and main-clock( $f_{XIN}$ ). The $f_{XIN}$ of main-clock is used usually for watch timer test, so generally it is not used for the clock source of watch timer. The $f_{XIN} \div 2^7$ of main-clock(4.194MHz) is used when the single clock system is orga- nized. In $f_{XIN}$ ÷ $2^7$ clock source, if the CPU enters into stop mode, the main-clock is stopped and then watch timer is also stopped. The watch timer counter can output with period of max 1 seconds at sub-clock. The bit 2, 3, 4 of WTMR select the interrupt interval divide ratio selection of watch timer among 16, 64, 256, 1024, 4096, 8192, 16384 or 32768. The WTIF bit of IFR register is set when watch timer interrupt is generated. (Refer to Figure 12-4) Figure 13-1 Watch Timer Mode Register Figure 13-2 Watch Timer Block Diagram ## 14. TIMER/EVENT COUNTER The MC80F0208/16/24 has five Timer/Counter registers. Each module can generate an interrupt to indicate that an event has occurred (i.e. timer match). Timer 0 and Timer 1 are can be used either two 8-bit Timer/Counter or one 16-bit Timer/Counter with combine them. Also Timer 2 and Timer 3 are same. Timer 4 is 16-bit Timer/Counter. In the "timer" function, the register is increased every internal clock input. Thus, one can think of it as counting internal clock input. Since a least clock consists of 2 and most clock consists of 2048 oscillator periods, the count rate is 1/2 to 1/2048 of the oscillator frequency. In the "counter" function, the register is increased in response to a 0-to-1 (rising edge) transition at its corresponding external input pin, EC0 or EC1. In addition the "capture" function, the register is increased in response external or internal clock sources same with timer or counter function. When external clock edge input, the count register is captured into Timer data register correspondingly. When external clock edge input, the count register is captured into capture data register CDRx. Timer 0 and Timer 1 has four operating modes: "8-bit timer/counter", "16-bit timer/counter", "8-bit capture" and "16-bit capture" which are selected by bit in Timer mode register TM0 and TM1 as shown in Table 14-1, Figure 14-1. Timer 2 and Timer 3 is shared with "PWM" function and "Compare output" function. It has six operating modes: "8-bit timer/counter", "16-bit timer/counter", "8-bit capture", "16-bit capture", "8-bit compare output", and "10-bit PWM" which are selected by bit in Timer mode register TM2 and TM3 as shown in Table 14-2, Figure 14-2. Timer 4 has two operating modes: "16-bit timer/counter" and "16-bit capture" which are selected by bit in Timer mode register TM4 as shown in Table 14-3, and Figure 14-3. | 16BIT | CAP0 | CAP1 | T0CK<br>[2:0] | T1CK<br>[1:0] | TIMER 0 | TIMER 1 | | |-------|------|------|---------------|---------------|--------------------------------------------|-------------|--| | 0 | 0 | 0 | XXX | XX | 8-bit Timer | 8-bit Timer | | | 0 | 0 | 1 | 111 | XX | 8-bit Event counter 8-bit Capture | | | | 0 | 1 | 0 | XXX | XX | 8-bit Capture (internal clock) 8-bit Timer | | | | 1 | 0 | 0 | XXX | 11 | 16-bit Timer | | | | 1 | 0 | 0 | 111 | 11 | 16-bit Event counter | | | | 1 | 1 | 1 | XXX | 11 | 16-bit Capture (internal clock) | | | Table 14-1 Operating Modes of Timer 0, 1 1. X means the value of "0" or "1" corresponds to user operation. | 16BIT | CAP2 | CAP3 | PWM3E | T2CK<br>[2:0] | T3CK<br>[1:0] | PWM3O | TIMER 2 | TIMER 3 | |-------|------|------|-------|---------------|---------------|-------|---------------------------------|----------------------| | 0 | 0 | 0 | 0 | XXX | XX | 0 | 8-bit Timer | 8-bit Timer | | 0 | 0 | 1 | 0 | 111 | XX | 0 | 8-bit Event counter | 8-bit Capture | | 0 | 1 | 0 | 0 | XXX | XX | 1 | 8-bit Capture (internal clock) | 8-bit Compare Output | | 0 | Χ | 0 | 1 | XXX | XX | 1 | 8-bit Timer/Counter | 10-bit PWM | | 1 | 0 | 0 | 0 | XXX | 11 | 0 | 16-bit Timer | | | 1 | 0 | 0 | 0 | 111 | 11 | 0 | 16-bit Event counter | | | 1 | 1 | 1 | 0 | XXX | 11 | 0 | 16-bit Capture (internal clock) | | Table 14-2 Operating Modes of Timer 2, 3 | CAP4 | T4CK[2:0] | TIMER 4 | |-------|-----------|---------------------------------| | 0 | XXX | 16-bit Timer | | 1 XXX | | 16-bit Capture (internal clock) | **Table 14-3 Operating Modes of Timer 4** Figure 14-1 TM0, TM1 Registers **Preliminary** Figure 14-2 TM2, TM3 Registers Figure 14-3 TM4 Register # 14.1 8-bit Timer / Counter Mode The MC80F0208/16/24 has four 8-bit Timer/Counters, Timer 0, Timer 1, Timer 2, Timer 3. The Timer 0, Timer 1 are shown in Figure 14-4 and Timer 2, Timer 3 are shown in Figure 14-5. The "timer" or "counter" function is selected by control registers TM0, TM1, TM2, TM3 as shown in Figure 14-1. To use as an 8-bit timer/counter mode, bit CAP0, CAP1, CAP2, or CAP3 of TMx should be cleared to "0" and 16BIT of TM1 or TM3 should be cleared to "0"(Figure 14-4). These timers have each 8-bit count register and data register. The count register is increased by every internal or external clock input. The internal clock has a prescaler divide ratio option of 1, 2, 4, 8, 16, 32, 64, 128, 256, 512, 1024, 2048 or external clock (selected by control bits TxCK0, TxCK1, TxCK2 of register TMx). Figure 14-4 8-bit Timer/Counter 0, 1 Figure 14-5 8-bit Timer/Counter 2, 3 #### Example 1: Timer0 = 2ms 8-bit timer mode at 4MHz Timer1 = 0.5ms 8-bit timer mode at 4MHz Timer2 = 1ms 8-bit timer mode at 4MHz Timer3 = 1ms 8-bit timer mode at 4MHz ``` T.DM TDR0, #249 LDM TDR1,#249 LDM TDR2, #249 LDM TDR3, #249 LDM TM0, #0000_1111B TM1,#0000_1011B T.DM LDM TM2,#0000_1111B LDM TM3,#0000_1011B SET1 TOE SET1 T1E T2E SET1 SET1 T3E EI ``` #### Example 2: Timer0 = 8-bit event counter mode Timer1 = 0.5ms 8-bit timer mode at 4MHz Timer2 = 8-bit event counter mode Timer3 = 1ms 8-bit timer mode at 4MHz ``` LDM TDR0, #249 LDM TDR1,#249 LDM TDR2, #249 LDM TDR3, #249 LDM TM0,#0001_1111B TM1, #0000_1011B TM2, #0001_1111B LDM LDM LDM TM3,#0000_1011B SET1 T0E T1E SET1 SET1 T<sub>2</sub>E T3E SET1 EΙ ``` These timers have each 8-bit count register and data register. The count register is increased by every internal or external clock input. The internal clock has a prescaler divide ratio option of 2, 4, 8, 32, 128, 512, 2048 selected by control bits T0CK[2:0] of register TM0 or 1, 2, 8 selected by control bits T1CK[1:0] of register TM1, or 2, 4, 8, 16, 64, 256, 1024 selected by control bits T2CK[2:0] of register TM2, or 1, 4, 16 selected by control bits T3CK[1:0] of register TM3. In the Timer 0, timer register T0 increases from $00_{\rm H}$ until it matches TDR0 and then reset to $00_{\rm H}$ . The match output of Timer 0 generates Timer 0 interrupt (latched in T0IF bit). In counter function, the counter is increased every 0-to-1(1-to-0) (rising & falling edge) transition of EC0 pin. In order to use counter function, the bit EC0 of the Port Selection Register(PSR0.4) is set to "1". The Timer 0 can be used as a counter by pin EC0 input, but Timer 1 can not. Likewise, In order to use Timer2 as counter function, the bit EC1 of the Port Selection Register(PSR0.5) is set to "1". The Timer 2 can be used as a counter by pin EC1 input, but Timer 3 can not. #### 14.1.1 8-bit Timer Mode In the timer mode, the internal clock is used for counting up. Thus, you can think of it as counting internal clock input. The contents of TDRn are compared with the contents of up-counter, Tn. If match is found, a timer n interrupt (TnIF) is generated and the up-counter is cleared to 0. Counting up is resumed after the up-counter is cleared. As the value of TDRn is changeable by software, time interval is set as you want. **Figure 14-6 Timer Mode Timing Chart** Figure 14-7 Timer Count Example ## 14.1.2 8-bit Event Counter Mode In this mode, counting up is started by an external trigger. This trigger means rising edge of the EC0 or EC1 pin input. Source clock is used as an internal clock selected with timer mode register TM0 or TM2. The contents of timer data register TDRn (n = 0,1,2,3) are compared with the contents of the up-counter Tn. If a match is found, an timer interrupt request flag TnIF is generated, and the counter is cleared to "0". The counter is restart and count up continuously by every falling edge of the EC0 or EC1 pin input. The maximum frequency applied to the EC0 or EC1 pin is $f_{XIN}/2$ [Hz]. In order to use event counter function, the bit 4, 5 of the Port Selection Register $PSR0(address\ 0F8_H)$ is required to be set to "1". After reset, the value of timer data register TDRn is initialized to "0", The interval period of Timer is calculated as below equation. $$Period(sec) = \frac{1}{f_{XIN}} \times 2 \times Divide(Ratio) \times (TDRn+1)$$ **Figure 14-8 Event Counter Mode Timing Chart** Figure 14-9 Count Operation of Timer / Event counter ## 14.2 16-bit Timer / Counter Mode The Timer register is being run with all 16 bits. A 16-bit timer/counter register T0, T1 are incremented from $0000_{\rm H}$ until it matches TDR0, TDR1 and then resets to $0000_{\rm H}$ . The match output generates Timer 0 interrupt. The clock source of the Timer 0 is selected either internal or external clock by bit T0CK[2:0]. In 16-bit mode, the bits T1CK[1:0] and 16BIT of TM1 should be set to "1" respectively as shown in Figure 14-10. Likewise, A 16-bit timer/counter register T2, T3 are incremented from $0000_{\rm H}$ until it matches TDR2, TDR3 and then resets to $0000_{\rm H}$ . The match output generates Timer 2 interrupt. The clock source of the Timer 2 is selected either internal or external clock by bit T2CK[2:0]. In 16-bit mode, the bits T3CK[1:0] and 16BIT of TM3 should be set to "1" respectively as shown in Figure 14-11. Even if the Timer 0 (including Timer 1) is used as a 16-bit timer, the Timer 2 and Timer 3 can still be used as either two 8-bit timer or one 16-bit timer by setting the TM2. Reversely, even if the Timer 2 (including Timer 3) is used as a 16-bit timer, the Timer 0 and Timer 1 can still be used as 8-bit timer independently. A 16-bit timer/counter 4 register T4H, T4L are increased from $0000_{\rm H}$ until it matches TDR4H, TDR4L and then resets to $0000_{\rm H}$ . The match output generates Timer 4 interrupt. Timer/Counter 4 is 16 bit mode as shown in Figure 14-12. Figure 14-10 16-bit Timer/Counter for Timer 0, 1 Figure 14-11 16-bit Timer/Counter for Timer 2, 3 # 14.3 8-bit Compare Output (16-bit) The MC80F0208/16/24 has a function of Timer Compare Output. To pulse out, the timer match can goes to port pin(T3O) as shown in Figure 14-5 . Thus, pulse out is generated by the timer match. These operation is implemented to pin, PWM3O/T3O. In this mode, the bit PWM3O/T3O of R5 Port Selection register 0 (PSR0.7) should be set to "1", and the bit PWM3E of timer 3 mode register (TM3) should be set to "0". This pin output the signormal signal of the pwm3 is a signal of the pwm3 in the pwm3 is a signal of the pwm3 in the pwm3 is a signal of the pwm3 in the pwm3 is a signal of the pwm3 in the pwm3 is a signal of the pwm3 in the pwm3 is a signal of the pwm3 in the pwm3 is a signal of the pwm3 in the pwm3 is a signal of the pwm3 in nal having a 50 : 50 duty square wave, and output frequency is same as below equation. $$f_{COMP} = \frac{Oscillation\ Frequency}{2 \times Prescaler\ Value \times (TDR + 1)}$$ Figure 14-12 Timer 4 for only 16 bit mode # 14.4 8-bit Capture Mode The Timer 0 capture mode is set by bit CAP0 of timer mode register TM0 (bit CAP1 of timer mode register TM1 for Timer 1) as shown in Figure 14-13. Likewise, the Timer 2 capture mode is set by bit CAP2 of timer mode register TM2 (bit CAP3 of timer mode register TM3 for Timer 3) as shown in Figure 14-14. The Timer/Counter register is increased in response internal or external input. This counting function is same with normal timer mode, and Timer interrupt is generated when timer register T0 (T1, T2, T3) increases and matches TDR0 (TDR1, TDR2, TDR3). This timer interrupt in capture mode is very useful when the pulse width of captured signal is more wider than the maximum period of Timer. For example, in Figure 14-16, the pulse width of captured signal is wider than the timer data value (FF $_{\rm H}$ ) over 2 times. When external interrupt is occurred, the captured value (13 $_{\rm H}$ ) is more little than wanted value. It can be obtained correct value by counting the number of timer overflow occurrence. Timer/Counter still does the above, but with the added feature that a edge transition at external input INTx pin causes the current value in the Timer x register (T0,T1,T2,T3), to be captured into registers CDRx (CDR0, CDR1, CDR2, CDR3), respectively. After captured, Timer x register is cleared and restarts by hardware. It has three transition modes: "falling edge", "rising edge", "both edge" which are selected by interrupt edge selection register IEDS. Refer to "19.5 External Interrupt" on page 92. In addition, the transition at INTn pin generate an interrupt. **Note:** The CDRn and TDRn are in same address.In the capture mode, reading operation is read the CDRn, not TDRn because path is opened to the CDRn. Figure 14-13 8-bit Capture Mode for Timer 0, 1 Figure 14-14 8-bit Capture Mode for Timer 2, 3 Figure 14-15 Input Capture Operation of Timer 0 Capture mode Figure 14-16 Excess Timer Overflow in Capture Mode ## 14.5 16-bit Capture Mode 16-bit capture mode is the same as 8-bit capture, except that the Timer register is being run will 16 bits. The clock source of the Timer 0 is selected either internal or external clock by bit T0CK[2:0]. In 16-bit mode, the bits T1CK1, T1CK0, CAP1 and 16BIT of TM1 should be set to "1" respectively as shown in Figure 14-17. The clock source of the Timer 2 is selected either internal or ex- ternal clock by bit T2CK[2:0]. In 16-bit mode, the bits T3CK1,T3CK0, CAP3 and 16BIT of TM3 should be set to "1" respectively as shown in Figure 14-18. The clock source of the Timer 4 is selected either internal or external clock by bit T4CK[2:0] as shown in Figure 14-18. Figure 14-17 16-bit Capture Mode of Timer 0, 1 Figure 14-18 16-bit Capture Mode of Timer 2, 3 Figure 14-19 16-bit Capture Mode of Timer 4 # Example 1: Timer0 = 16-bit timer mode, 0.5s at 4MHz ``` LDM TM0,#0000_1111B;8uS LDM TM1,#0100_1100B;16bit Mode LDM TDR0,#<62499 ;8uS X 62500 LDM TDR1,#>62499 ;=0.5s SET1 TOE EI : ``` ## Example 2: Timer0 = 16-bit event counter mode # Example 3: Timer0 = 16-bit capture mode ``` LDM PSR0,#0000_0001B;INTO set LDM TM0,#0010_1111B;CaptureMode LDM TM1,#0100_1100B;16bit Mode LDM TDR0,#<0FFH ; LDM TDR1,#>0FFH ; LDM IEDS,#01H;Falling Edge SET1 TOE EI : ``` #### 14.6 PWM Mode The MC80F0208/16/24 has a high speed PWM (Pulse Width Modulation) functions which shared with Timer3. In PWM mode, pin R54/PWM3O outputs up to a 10-bit resolution PWM output. This pin should be configured as a PWM output by setting "1" bit PWM3O in PSR0 register. The period of the PWM3 output is determined by the T3PPR (T3 PWM Period Register) and T3PWHR[3:2] (bit3,2 of T3 PWM High Register) and the duty of the PWM output is determined by the T3PDR (T3 PWM Duty Register) and T3PWHR[1:0] (bit1,0 of T3 PWM High Register). The user writes the lower 8-bit period value to the T3PPR and the higher 2-bit period value to the T3PWHR[3:2]. And writes duty value to the T3PDR and the T3PWHR[1:0] same way. The T3PDR is configured as a double buffering for glitchless PWM output. In Figure 14-20, the duty data is transferred from the master to the slave when the period data matched to the counted value. (i.e. at the beginning of next duty cycle) PWM3 Period = [PWM3HR[3:2]T3PPR] X Source Clock PWM3 Duty = [PWM3HR[1:0]T3PDR] X Source Clock The relation of frequency and resolution is in inverse proportion. Table 14-4 shows the relation of PWM frequency vs. resolution. If it needed more higher frequency of PWM, it should be reduced resolution. | | Frequency | | | | | | | |------------|--------------------------|------------------------|------------------------|--|--|--|--| | Resolution | T3CK[1:0]<br>= 00(250nS) | T3CK[1:0]<br>= 01(1uS) | T3CK[1:0]<br>= 10(4uS) | | | | | | 10-bit | 3.9kHz | 1.95kHz | 0.97kHz | | | | | | 9-bit | 7.8kHz | 3.90kHz | 1.95kHz | | | | | | 8-bit | 15.6kHz | 7.81kHz | 3.90kHz | | | | | | 7-bit | 31.2kHz | 15.6kHz | 7.8kHz | | | | | Table 14-4 PWM Frequency vs. Resolution at 4MHz The bit POL of TM3 decides the polarity of duty cycle. If the duty value is set same to the period value, the PWM output is determined by the bit POL (1: High, 0: Low). And if the duty value is set to " $00_{\rm H}$ ", the PWM output is determined by the bit POL (1: Low, 0: High). It can be changed duty value when the PWM output. However the changed duty value is output after the current period is over. And it can be maintained the duty value at present output when changed only period value shown as Figure 14-22. As it were, the absolute duty time is not changed in varying frequency. But the changed period value must greater than the duty value. **Note:** If changing the Timer3 to PWM function, it should be stop the timer clock firstly, and then set period and duty register value. If user writes register values while timer is in operation, these register could be set with certain values. Ex) Sample Program @4MHz 4uS LDM TM3,#1010\_1000b; Set Clock & PWM3E LDM T3PPR,#199 ; Period :800uS=4uSX(199+1) LDM T3PDR,#99 ; Duty:400uS=4uSX(99+1) LDM PWM3HR,00H LDM TM3,#1010\_1011b ; Start timer3 Figure 14-20 PWM3 Mode Figure 14-21 Example of PWM at 4MHz Figure 14-22 Example of Changing the Period in Absolute Duty Cycle (@8MHz) #### 15. ANALOG TO DIGITAL CONVERTER The analog-to-digital converter (A/D) allows conversion of an analog input signal to a corresponding 10-bit digital value. The A/D module has sixteen analog inputs, which are multiplexed into one sample and hold. The output of the sample and hold is the input into the converter, which generates the result via successive approximation. The analog supply voltage is connected to $AV_{DD}$ of Sample & Hold logic of A/D module. The $AV_{DD}$ was separated with $V_{DD}$ in order to minimize the degradation of operation characteristic by power supply noise. The A/D module has three registers which are the control register ADCM and A/D result register ADCRH and ADCRL. The ADCRH[7:6] is used as ADC clock source selection bits too. The register ADCM, shown in Figure 15-4, controls the operation of the A/D converter module. The port pins can be configured as analog inputs or digital I/O. It is selected for the corresponding channel to be converted by setting ADS[3:0]. The A/D port is set to analog input port by ADEN and ADS[3:0] regardless of port I/O direction register. The port unselected by ADS[3:0] operates as normal port. Figure 15-1 A/D Converter Operation Flow #### How to Use A/D Converter The processing of conversion is start when the start bit ADST is set to "1". After one cycle, it is cleared by hardware. The register ADCRH and ADCRL contains the results of the A/D conversion. When the conversion is completed, the result is loaded into the ADCRH and ADCRL, the A/D conversion status bit ADSF is set to "1", and the A/D interrupt flag ADCIF is set. See Figure 15-1 for operation flow. The block diagram of the A/D module is shown in Figure 15-3. The A/D status bit ADSF is set automatically when A/D conversion is completed, cleared when A/D conversion is in process. The conversion time takes 7 times of conversion source clock. The period of actual A/D conversion clock should be minimally 1µs Figure 15-2 Analog Input Pin Connecting Capacitor #### A/D Converter Cautions # (1) Input range of AN0 to AN7 The input voltage of AN0 to AN7 should be within the specification range. In particular, if a voltage above $AV_{DD}$ or below $AV_{SS}$ is input (even if within the absolute maximum rating range), the conversion value for that channel can not be indeterminate. The conversion values of the other channels may also be affected. #### (2) Noise countermeasures In order to maintain 10-bit resolution, attention must be paid to noise on pins $AV_{DD}$ and AN0 to AN7. Since the effect increases in proportion to the output impedance of the analog input source, it is recommended in some cases that a capacitor be connected externally as shown in Figure 15-2 in order to reduce noise. The capacitance is user-selectable and appropriately determined according to the target system. #### (3) Pins AN0/R60 to AN7/R67 The analog input pins AN0 to AN7 also function as input/output port (PORT R6) pins. When A/D conversion is performed with any of pins AN0 to AN15 selected, be sure not to execute a PORT input instruction while conversion is in progress, as this may reduce the conversion resolution. Also, if digital pulses are applied to a pin adjacent to the pin in the process of A/D conversion, the expected A/D conversion value may not be obtainable due to coupling noise. Therefore, avoid applying pulses to pins adjacent to the pin undergoing A/D conversion. #### (4) AV<sub>DD</sub> pin input impedance A series resistor string of approximately $5K\Omega$ is connected between the $AV_{DD}$ pin and the $AV_{SS}$ pin. Therefore, if the output impedance of the analog power source is high, this will result in parallel connection to the series resistor string between the $AV_{DD}$ pin and the $AV_{SS}$ pin, and there will be a large analog supply voltage error. Figure 15-3 A/D Block Diagram Figure 15-4 A/D Converter Control & Result Register # 16. SERIAL INPUT/OUTPUT (SIO) The serial Input/Output is used to transmit/receive 8-bit data serially. The Serial Input/Output(SIO) module is a serial interface useful for communicating with other peripheral of microcontroller devices. These peripheral devices may be serial EEPROMs, shift registers, display drivers, A/D converters, etc. This SIO is 8-bit clock synchronous type and consists of serial I/O data register, serial I/O mode register, clock selection circuit, octal counter and control circuit as illustrated in Figure 16-1. The SO pin is designed to input and output. So the Serial I/O(SIO) can be operated with minimum two pin. Pin R42/SCK, R43/SI, and R44/SO pins are controlled by the Serial Mode Register. The contents of the Serial I/O data register can be written into or read out by software. The data in the Serial Data Register can be shifted synchronously with the transfer clock signal. Figure 16-1 SIO Block Diagram Serial I/O Mode Register(SIOM) controls serial I/O function. According to SCK1 and SCK0, the internal clock or external clock can be selected. Serial I/O Data Register(SIOR) is an 8-bit shift register. First LSB is send or is received. Figure 16-2 SIO Control Register # 16.1 Transmission/Receiving Timing The serial transmission is started by setting SIOST(bit1 of SIOM) to "1". After one cycle of SCK, SIOST is cleared automatically to "0". At the default state of POL bit clear, the serial output data from 8-bit shift register is output at falling edge of SCLK, and in- put data is latched at rising edge of SCLK pin (Refer to Figure 16-3). When transmission clock is counted 8 times, serial I/O counter is cleared as '0". Transmission clock is halted in "H" state and serial I/O interrupt(SIOIF) occurred. Figure 16-3 Serial I/O Timing Diagram at POL=0 Figure 16-4 Serial I/O Timing Diagram at POL=1 #### 16.2 The method of Serial I/O - 1. Select transmission/receiving mode. - 2. In case of sending mode, write data to be send to SIOR. - 3. Set SIOST to "1" to start serial transmission. - 4. The SIO interrupt is generated at the completion of SIO and SIOIF is set to "1". In SIO interrupt service routine, correct transmission should be tested. - 5. In case of receiving mode, the received data is acquired by reading the SIOR. | LDM | SIOR,#0AAh | ;set tx data | |------------|------------------|---------------| | LDM | SIOM,#0011_1100b | ;set SIO mode | | NOP<br>LDM | SIOM,#0011_1110b | ;SIO Start | **Note:** When external clock is used, the frequency should be less than 1MHz and recommended duty is 50%. If both transmission mode is selected and transmission is performed simultaneously, error will be made. #### 16.3 The Method to Test Correct Transmission Figure 16-5 Serial IO Method to Test Transmission # 17. UNIVERSAL ASYNCHRONOUS RECEIVER/TRANSMITTER (UART) #### 17.1 UART Serial Interface Functions The Universal Asynchronous Receiver/Transmitter(UART) enables full-duplex operation wherein one byte of data after the start bit is transmitted and received. The on-chip baud rate generator dedicated to UART enables communications using a wide range of selectable baud rates. In addition, a baud rate can also be defined by dividing clocks input to the ACLK pin. The UART driver consists of RXR, TXR, ASIMR, ASISR and BRGCR register. Clock asynchronous serial I/O mode (UART) can be selected by ASIMR register. Figure 17-1 shows a block diagram of the UART driver. **Note:** The UART1 control register ASIMR1,ASISR1, BRGCR1, RXR1 and TXR1 are located at EE6H ~ EE9H address. These address must be accessed(read and written) by absolute addressing manipulation instruction. Figure 17-1 UART Block Diagram Figure 17-2 Baud Rate Generator Block Diagram Figure 17-3 IFR: Interrupt Flag Register ## 17.2 Serial Interface Configuration The UART interface consists of the following hardware. | Item | Configuration | |------------------|-----------------------------------------------------------------------------------------------------------------------------------| | Register | Transmit shift register (TXR)<br>Receive buffer register (RXR)<br>Receive shift register | | Control register | Serial interface mode register (ASIMR)<br>Serial interface status register (ASISR)<br>Baudrate generator control register (BRGCR) | **Table 17-1 Serial Interface Configuration** #### Transmit shift register (TXR) This is the register for setting transmit data. Data written to TXR0 is transmitted as serial data. When the data length is set as 7 bit, bit 0 to 6 of the data written to TX0 are transferred as transmit data. Writing data to TXR0 starts the transmit operation. TXR0 can be written by an 8 bit memory manipulation instruction. It cannot be read. The $\overline{RESET}$ input sets TXR0 to 0FF<sub>H</sub>. **Note:** Do not write to TXR during a transmit operation. The same address is assigned to TXR and the receive buffer register (RXR). A read operation reads values from RXR. # Receive buffer register (RXR) This register is used to hold receive data. When one byte of data is received, one byte of new receive data is transferred from the receive shift register (RXSR). When the data length is set as 7 bits, receive data is sent to bits 0 to 6 of RXR0. In this case, the MSB of RXR always becomes 0. RXR can be read by an 8 bit memory manipulation instruction. It cannot be written. The $\overline{RESET}$ input sets RXR0 to $00_H$ . **Note:** The same address is assigned to RXR and the transmit shift register (TXR). During a write operation, values are written to TXR. #### Receive shift register This register converts serial data input via the RxD pin to paralleled data. When one byte of data is received at this register cannot be manipulated directly by a program. # Asynchronous serial interface mode register (ASIMR) This is an 8 bit register that controls UART serial transfer operation. ASIMR is set by a 1 bit or 8 bit memory manipulation intruction. The RESET input sets ASIMR to 0000\_-00-B. Table 17-4 shows the format of ASIMR. **Note:** Do not switch the operation mode until the current serial transmit/receive operation has stopped. Figure 17-4 Asynchronous Serial Interface Mode register (ASIMR0) Format # Asynchronous serial interface status register0 (ASISR) When a receive error occurs during UART mode, this register indicates the type of error. ASISR can be read by an 8 bit memory manipulation instruction. The RESET input sets ASISR0 to ----- 000B. Figure 17-5 shows the format of ASISR. ADDRESS: 0E7<sub>H</sub> ASISR0 PE0 FE0 OVE0 INITIAL VALUE: ---- -000B UART0 Parity Error Flag 0: No parity error 1: Parity error (Transmit data parity not matched) UART0 Frame Error Flag O: No Frame error 1: Framing error Note1 (stop bit not detected) UART0 Overrun Error Flag 0: No overrun error 1: Overrun error Note2 (Next receive operation was completed before data was read from receive buffer register (RXR)) Note 1. Even if a stop bit length is set to 2 bits by setting bit2(SL) in ASIMR, stop bit detection during a recive operation only applies to a stop bit length of 1bit. 2. Be sure to read the contents of the receive buffer register(RXR) when an overrun error has occurred. Until the contents of RXR are read, futher overrun errors will occur when receiving data. Figure 17-5 Asynchronous Serial Interface Status Register (ASISR) Format # Baud rate generator control register (BRGCR) This register sets the serial clock for serial interface. BRGCR is set by an 8 bit memory manipulation instruction. The RESET input sets BRGCR to -001\_0000B. Figure 17-6 shows the format of BRGCR. Figure 17-6 Baud Rate Generator Control Register0(BRGCR) Format # 17.3 Communication operation The transmit operation is enabled when bit 7 (TXE0) of the asynchronous serial interface mode register (ASIMR) is set to 1. The transmit operation is started when transmit data is written to the transmit shift register (TXR). The timing of the transmit completion interrupt request is shown in Figure 17-8. The receive operation is enabled when bit 6 (RXE0) of the asynchronous serial interface mode register (ASIMR) is set to 1, and input via the RxD pin is sampled. The serial clock specified by ASIMR is used to sample the RxD pin. Once reception of one data frame is completed, a receive completion interrupt request (INT\_RX0) occurs. Even if an error has occurred, the receive data in which the error occurred is still transferred to RXR. When ASIMR bit 1 (ISRM0) is cleared to 0 upon occurrence of an error, and INT\_RX0 occurs. When ISRM bit is set to 1, INT\_RX0 does not occur in case of error occurrence. Figure 17-8 shows the timing of the asynchronous serial interface receive completion interrupt request. In case of using interrupts of UART0 Tx and UART0 Rx together, it is necessary to check IFR in interrupt service routine to find out which interrupt is occurred, because the UART0 Tx and UART0 Rx is shared with interrupt vector address. These flag bits must be cleared by software after reading this register. In case of using interrupts of UART1 Tx and UART1 Rx together, it is necessary to check IFR in interrupt service routine to find out which interrupt is occurred, because the UART1 Tx and UART1 Rx is shared with interrupt vector address. These flag bits must be cleared by software after reading this register. Each processing step is determined by IFR as shown in Figure 17-7. Figure 17-7 Shared Interrupt Vector of UART Figure 17-8 UART data format and interrupt timing diagram # 17.4 Relationship between main clock and baud rate The transmit/receive clock that is used to generate the baud rate is obtained by dividing the main system clock. Transmit/Receive clock generation for baud rate is made by using main system clock which is divided. The baud rate generated from the main system clock is determined according to the following formula. | Baud Rate | f <sub>XIN</sub> =11. | f <sub>XIN</sub> =11.0592M | | f <sub>XIN</sub> =10.0M f <sub>XIN</sub> =8.0M | | f <sub>XIN</sub> =10.0M | | f <sub>XIN</sub> =8.0M | | f <sub>XIN</sub> =8.0M | | 6.0M | f <sub>XIN</sub> =4 | 1.0M | f <sub>XIN</sub> =2 | 2.0M | |-----------|-----------------------|----------------------------|-------|------------------------------------------------|-------|-------------------------|-------|------------------------|-------|------------------------|-------|------------|---------------------|------|---------------------|------| | (bps) | BRGCR | ERR<br>(%) | BRGCR | ERR<br>(%) | BRGCR | ERR<br>(%) | BRGCR | ERR<br>(%) | BRGCR | ERR<br>(%) | BRGCR | ERR<br>(%) | | | | | | 600 | - | - | - | - | - | - | - | - | 7AH | 0.16 | 6AH | 0.16 | | | | | | 1200 | - | - | - | - | 7AH | 0.16 | 74H | 2.34 | 6AH | 0.16 | 5AH | 0.16 | | | | | | 2400 | 72H | 0.00 | 70H | 1.73 | 6AH | 0.16 | 64H | 2.34 | 5AH | 0.16 | 4AH | 0.16 | | | | | | 4800 | 62H | 0.00 | 60H | 1.73 | 5AH | 0.16 | 54H | 2.34 | 4AH | 0.16 | зан | 0.16 | | | | | | 9600 | 52H | 0.00 | 50H | 1.73 | 4AH | 0.16 | 44H | 2.34 | зан | 0.16 | 2AH | 0.16 | | | | | | 19200 | 42H | 0.00 | 40H | 1.73 | зан | 0.16 | 34H | 2.34 | 2AH | 0.16 | 1AH | 0.16 | | | | | | 31250 | 36H | 0.53 | 34H | 0.00 | 30H | 0.00 | 28H | 0.00 | 20H | 0.00 | 10H | 0.00 | | | | | | 38400 | 32H | 0.00 | 30H | 1.73 | 2AH | 0.16 | 24H | 2.34 | 1AH | 0.16 | - | - | | | | | | 57600 | 28H | 0.00 | 26H | 1.35 | 21H | 2.11 | 1AH | 0.16 | 11H | 2.12 | - | ı | | | | | | 76800 | 22H | 0.00 | 20H | 1.73 | 1AH | 0.16 | 14H | 2.34 | - | - | - | ı | | | | | | 115200 | 18H | 0.00 | 16H | 1.36 | 11H | 2.12 | - | | - | - | - | - | | | | | Baud Rate = $f_{XIN} / (2^{n+1}(k+16))$ Remarks 1. f<sub>XIN</sub>: Main system clock oscillation frequency When ACLK is selected as the source clock of the 5-bit counter, substitute the input clock frequency to ACLK pin for in the above expression. 2. f<sub>SCK</sub>: Source clock for 5 bit counter 3. n : Value set via TPS00 to TPS02 ( $0 \le n \le 7$ ) 4. k : Source clock for 5 bit counter ( $0 \le k \le 14$ ) Figure 17-9 Relationship between main clock and Baud Rate #### 18. BUZZER FUNCTION The buzzer driver block consists of 6-bit binary counter, buzzer register BUZR, and clock source selector. It generates squarewave which has very wide range frequency (488Hz $\sim$ 250kHz at f<sub>XIN</sub>= 4MHz) by user software. A 50% duty pulse can be output to R13/BUZO pin to use for piezo-electric buzzer drive. Pin R13 is assigned for output port of Buzzer driver by setting the bit 2 of PSR1(address 0F9<sub>H</sub>) to "1". For PSR1 register, refer to Figure 18-2. Example: 5kHz output at 4MHz. LDM BUZR,#0011\_0001B LDM PSR1,#XXXX\_X1XXB X means don't care The bit 0 to 5 of BUZR determines output frequency for buzzer driving. Equation of frequency calculation is shown below. $$f_{BUZ} = \frac{f_{XIN}}{2 \times DivideRatio \times (BUR + I)}$$ f<sub>BUZ</sub>: Buzzer frequency f<sub>XIN</sub>: Oscillator frequency Divide Ratio: Prescaler divide ratio by BUCK[1:0] BUR: Lower 6-bit value of BUZR. Buzzer period value. The frequency of output signal is controlled by the buzzer control register BUZR. The bit 0 to bit 5 of BUZR determine output frequency for buzzer driving. Figure 18-1 Block Diagram of Buzzer Driver Figure 18-2 Buzzer Register & PSR1 The 6-bit counter is cleared and starts the counting by writing signal at BUZR register. It is incremental from $00_{\rm H}$ until it matches 6-bit BUR value. When main-frequency is 4MHz, buzzer frequency is shown as below Table 18-1. | BUR | BUR[7:6] | | | BUR | BUR[7:6] | | | | | |-------|----------|---------|--------|--------|----------|-------|-------|-------|-------| | [5:0] | 00 | 01 | 10 | 11 | [5:0] | 00 | 01 | 10 | 11 | | 00 | 250.000 | 125.000 | 62.500 | 31.250 | 20 | 7.576 | 3.788 | 1.894 | 0.947 | | 01 | 125.000 | 62.500 | 31.250 | 15.625 | 21 | 7.353 | 3.676 | 1.838 | 0.919 | | 02 | 83.333 | 41.667 | 20.833 | 10.417 | 22 | 7.143 | 3.571 | 1.786 | 0.893 | | 03 | 62.500 | 31.250 | 15.625 | 7.813 | 23 | 6.944 | 3.472 | 1.736 | 0.868 | | 04 | 50.000 | 25.000 | 12.500 | 6.250 | 24 | 6.757 | 3.378 | 1.689 | 0.845 | | 05 | 41.667 | 20.833 | 10.417 | 5.208 | 25 | 6.579 | 3.289 | 1.645 | 0.822 | | 06 | 35.714 | 17.857 | 8.929 | 4.464 | 26 | 6.410 | 3.205 | 1.603 | 0.801 | | 07 | 31.250 | 15.625 | 7.813 | 3.906 | 27 | 6.250 | 3.125 | 1.563 | 0.781 | | 08 | 27.778 | 13.889 | 6.944 | 3.472 | 28 | 6.098 | 3.049 | 1.524 | 0.762 | | 09 | 25.000 | 12.500 | 6.250 | 3.125 | 29 | 5.952 | 2.976 | 1.488 | 0.744 | | 0A | 22.727 | 11.364 | 5.682 | 2.841 | 2A | 5.814 | 2.907 | 1.453 | 0.727 | | 0B | 20.833 | 10.417 | 5.208 | 2.604 | 2B | 5.682 | 2.841 | 1.420 | 0.710 | | 0C | 19.231 | 9.615 | 4.808 | 2.404 | 2C | 5.556 | 2.778 | 1.389 | 0.694 | | 0D | 17.857 | 8.929 | 4.464 | 2.232 | 2D | 5.435 | 2.717 | 1.359 | 0.679 | | 0E | 16.667 | 8.333 | 4.167 | 2.083 | 2E | 5.319 | 2.660 | 1.330 | 0.665 | | 0F | 15.625 | 7.813 | 3.906 | 1.953 | 2F | 5.208 | 2.604 | 1.302 | 0.651 | | 10 | 14.706 | 7.353 | 3.676 | 1.838 | 30 | 5.102 | 2.551 | 1.276 | 0.638 | | 11 | 13.889 | 6.944 | 3.472 | 1.736 | 31 | 5.000 | 2.500 | 1.250 | 0.625 | | 12 | 13.158 | 6.579 | 3.289 | 1.645 | 32 | 4.902 | 2.451 | 1.225 | 0.613 | | 13 | 12.500 | 6.250 | 3.125 | 1.563 | 33 | 4.808 | 2.404 | 1.202 | 0.601 | | 14 | 11.905 | 5.952 | 2.976 | 1.488 | 34 | 4.717 | 2.358 | 1.179 | 0.590 | | 15 | 11.364 | 5.682 | 2.841 | 1.420 | 35 | 4.630 | 2.315 | 1.157 | 0.579 | | 16 | 10.870 | 5.435 | 2.717 | 1.359 | 36 | 4.545 | 2.273 | 1.136 | 0.568 | | 17 | 10.417 | 5.208 | 2.604 | 1.302 | 37 | 4.464 | 2.232 | 1.116 | 0.558 | | 18 | 10.000 | 5.000 | 2.500 | 1.250 | 38 | 4.386 | 2.193 | 1.096 | 0.548 | | 19 | 9.615 | 4.808 | 2.404 | 1.202 | 39 | 4.310 | 2.155 | 1.078 | 0.539 | | 1A | 9.259 | 4.630 | 2.315 | 1.157 | 3A | 4.237 | 2.119 | 1.059 | 0.530 | | 1B | 8.929 | 4.464 | 2.232 | 1.116 | 3B | 4.167 | 2.083 | 1.042 | 0.521 | | 1C | 8.621 | 4.310 | 2.155 | 1.078 | 3C | 4.098 | 2.049 | 1.025 | 0.512 | | 1D | 8.333 | 4.167 | 2.083 | 1.042 | 3D | 4.032 | 2.016 | 1.008 | 0.504 | | 1E | 8.065 | 4.032 | 2.016 | 1.008 | 3E | 3.968 | 1.984 | 0.992 | 0.496 | | 1F | 7.813 | 3.906 | 1.953 | 0.977 | 3F | 3.907 | 1.953 | 0.977 | 0.488 | Table 18-1 buzzer frequency (kHz unit) #### 19. INTERRUPTS The MC80F0208/16/24 interrupt circuits consist of Interrupt enable register (IENH, IENL), Interrupt request flags of IRQH, IRQL, Priority circuit, and Master enable flag ("I" flag of PSW). Fifteen interrupt sources are provided. The configuration of interrupt circuit is shown in Figure 19-1 and interrupt priority is shown in Table 19-1. The External Interrupts INT0 ~ INT3 each can be transition-activated (1-to-0 or 0-to-1 transition) by selection IEDS register. The flags that actually generate these interrupts are bit INT0IF, INT1IF, INT2IF and INT3IF in register IRQH. When an external interrupt is generated, the generated flag is cleared by the hardware when the service routine is vectored to only if the interrupt was transition-activated. The Timer $0 \sim \text{Timer 4}$ Interrupts are generated by T0IF, T1IF, T2IF, T3IF and T4IF which is set by a match in their respective timer/counter register. The Basic Interval Timer Interrupt is generated by BITIF which is set by an overflow in the timer register. The AD converter Interrupt is generated by ADCIF which is set by finishing the analog to digital conversion. The Watchdog timer and Watch Timer Interrupt is generated by WDTIF and WTIF which is set by a match in Watchdog timer register or Watch timer register. The IFR(Interrupt Flag Register) is used for discrimination of the interrupt source among these two Watchdog timer and Watch Timer Interrupt. Figure 19-1 Block Diagram of Interrupt The Basic Interval Timer Interrupt is generated by BITIF which is set by a overflow in the timer counter register. The UART0 receive/transmit interrupt is generated by UART0IF is set by completion of UART0 data reception or transmission. The IFR(Interrupt Flag Register) is used for discrimination of the interrupt source among these two UART0 receive and UART0 transmit Interrupt. The SIO interrupt is generated by SIOIF which is set by completion of SIO data reception or transmission. The interrupts are controlled by the interrupt master enable flag I-flag (bit 2 of PSW on Figure 8-3), the interrupt enable register (IENH, IENL), and the interrupt request flags (in IRQH and IRQL) except Power-on reset and software BRK interrupt. The Table 19-1 shows the Interrupt priority. Vector addresses are shown in Figure 8-6. Interrupt enable registers are shown in Figure 19-2. These registers are composed of interrupt enable flags of each interrupt source and these flags determines whether an interrupt will be accepted or not. When enable flag is "0", a corresponding interrupt source is prohibited. Note that PSW contains also a master enable bit, I-flag, which disables all interrupts at once. | Reset/Interrupt | Symbol | Priority | |-----------------------|---------|----------| | Hardware Reset | RESET | 1 | | External Interrupt 0 | INT0 | 2 | | External Interrupt 1 | INT1 | 3 | | External Interrupt 2 | INT2 | 4 | | External Interrupt 3 | INT3 | 5 | | UART0 Rx/Tx Interrupt | UART0 | 6 | | UART1 Rx/Tx Interrupt | UART1 | 7 | | Serial Input/Output | SIO | 8 | | Timer/Counter 0 | Timer 0 | 9 | | Timer/Counter 1 | Timer 1 | 10 | | Timer/Counter 2 | Timer 2 | 11 | | Timer/Counter 3 | Timer 3 | 12 | | Timer/Counter 4 | Timer 4 | 13 | | ADC Interrupt | ADC | 14 | | Watchdog/Watch Timer | WDT_WT | 15 | | Basic Interval Timer | BIT | 16 | **Table 19-1 Interrupt Priority** Figure 19-2 Interrupt Enable Flag Register Figure 19-3 Interrupt Request Flag Register & Interrupt Flag Register # 19.1 Interrupt Sequence An interrupt request is held until the interrupt is accepted or the interrupt latch is cleared to "0" by a reset or an instruction. Interrupt acceptance sequence requires 8 cycles of $f_{XIN}$ (2 $\mu$ s at $f_{XN}$ ) <sub>IN</sub>=4MHz) after the completion of the current instruction execution. The interrupt service task is terminated upon execution of an interrupt return instruction [RETI]. #### 19.1.1 Interrupt acceptance - The interrupt master enable flag (I-flag) is cleared to "0" to temporarily disable the acceptance of any following maskable interrupts. When a non-maskable interrupt is accepted, the acceptance of any following interrupts is temporarily disabled. - Interrupt request flag for the interrupt source accepted is cleared to "0". - 3. The contents of the program counter (return address) - and the program status word are saved (pushed) onto the stack area. The stack pointer decreases 3 times. - 4. The entry address of the interrupt service program is read from the vector table address and the entry address is loaded to the program counter. - 5. The instruction stored at the entry address of the interrupt service program is executed. Figure 19-4 Timing chart of Interrupt Acceptance and Interrupt Return Instruction Correspondence between vector table address for BIT interrupt and the entry address of the interrupt service program. A interrupt request is not accepted until the I-flag is set to "1" even if a requested interrupt has higher priority than that of the current interrupt being serviced. When nested interrupt service is required, the I-flag should be set to "1" by "EI" instruction in the interrupt service program. In this case, acceptable interrupt sources are selectively enabled by the individual interrupt enable flags. #### 19.1.2 Saving/Restoring General-purpose Register During interrupt acceptance processing, the program counter and the program status word are automatically saved on the stack, but accumulator and other registers are not saved itself. These registers are saved by the software if necessary. Also, when multiple interrupt services are nested, it is necessary to avoid using the same data memory area for saving registers. The following method is used to save/restore the general-purpose registers. Example: Register save using push and pop instructions | INTxx: | PUSH | A | ;SAVE | ACC. | |--------|------|---|-------|--------| | | PUSH | X | ;SAVE | X REG. | | | PUSH | Y | ;SAVE | Y REG. | | interrupt p | processing | | | | |-------------|------------|-----------|---|------| | POP | Y | ; RESTORE | Y | REG. | | POP | X | ; RESTORE | Χ | REG. | | POP | A | ; RESTORE | A | CC. | | RETI | | ;RETURN | | | General-purpose register save/restore using push and pop instructions; ## 19.2 BRK Interrupt Software interrupt can be invoked by BRK instruction, which has the lowest priority order. Interrupt vector address of BRK is shared with the vector of TCALL 0 (Refer to Program Memory Section). When BRK interrupt is generated, B-flag of PSW is set to distinguish BRK from TCALL 0. Each processing step is determined by B-flag as shown in Figure 19-5. Figure 19-5 Execution of BRK/TCALL0 # 19.3 Shared Interrupt Vector In case of using interrupts of Watchdog Timer and Watch Timer together, it is necessary to check IFR in interrupt service routine to find out which interrupt is occurred, because the Watchdog timer and Watch timer is shared with interrupt vector address. These flag bits must be cleared by software after reading this register. In case of using interrupts of UART0 Tx and UART0 Rx together, it is necessary to check IFR in interrupt service routine to find out which interrupt is occurred, because the UARTO Tx and UARTO Rx is shared with interrupt vector address. These flag bits must be cleared by software after reading this register. In case of using interrupts of UART1 Tx and UART1 Rx together, it is necessary to check IFR in interrupt service routine to find out which interrupt is occurred, because the UART1 Tx and UART1 Rx is shared with interrupt vector address. These flag bits must be cleared by software after reading this register. Each MC80F0208/16/24 processing step is determined by IFR as shown in Figure 19-6. Figure 19-6 Software Flowchart of Shared Interrupt Vector # 19.4 Multi Interrupt If two requests of different priority levels are received simultaneously, the request of higher priority level is serviced. If requests of the interrupt are received at the same time simultaneously, an internal polling sequence determines by hardware which request is serviced. However, multiple processing through software for special features is possible. Generally when an interrupt is accepted, the I-flag is cleared to disable any further interrupt. But as user sets I-flag in interrupt routine, some further interrupt can be serviced even if certain interrupt is in progress. Figure 19-7 Execution of Multi Interrupt **Example:** During Timer1 interrupt is in progress, INT0 interrupt serviced without any suspend. ``` TIMER1: PUSH A PUSH X PUSH Y LDM IENH,#80H ; Enable INTO only LDM IENL,#0 ; Disable other int. EI ; Enable Interrupt : ``` ``` : : : LDM IENH,#0FFH ;Enable all interrupts LDM IENL,#0FFH POP Y POP X POP A RETI ``` # 19.5 External Interrupt The external interrupt on INT0, INT1, INT2 and INT3 pins are edge triggered depending on the edge selection register IEDS (address $0EE_H$ ) as shown in Figure 19-8. The edge detection of external interrupt has three transition activated mode: rising edge, falling edge, and both edge. Figure 19-8 External Interrupt Block Diagram INT0 ~ INT3 are multiplexed with general I/O ports (R10, R11, R12, R50). To use as an external interrupt pin, the bit of port selection register PSR0 should be set to "1" correspondingly. **Example:** To use as an INTO and INT2 ``` : ;**** Set external interrupt port as pull-up state. LDM PU1,#0000_0101B ; ;**** Set port as an external interrupt port LDM PSR0,#0000_0101B ; ;**** Set Falling-edge Detection LDM IEDS,#0001_0001B ``` ## **Response Time** The INT0 ~ INT3 edge are latched into INT0IF ~ INT3IF at every machine cycle. The values are not actually polled by the circuitry until the next machine cycle. If a request is active and conditions are right for it to be acknowledged, a hardware subroutine call to the requested service routine will be the next instruction to be executed. The DIV itself takes twelve cycles. Thus, a minimum of twelve complete machine cycles elapse between activation of an external interrupt request and the beginning of execution of the first instruction of the service routine. Figure 19-9 shows interrupt response timings. Figure 19-9 Interrupt Response Timing Diagram Figure 19-10 IEDS register and Port Selection Register PSR0 #### 20. OPERATION MODE The system clock controller starts or stops the main-frequency clock oscillator. The operating mode is generally divided into the main active mode. Figure 20-1 shows the operating mode transition diagram. System clock control is performed by the system clock mode register, SCMR. During reset, this register is initialized to "0" so that the main-clock operating mode is selected. #### **Main Active Mode** This mode is fast-frequency operating mode. The CPU and the peripheral hardware are operated on the high-frequency clock. At reset release, this mode is invoked. #### **SLEEP Mode** In this mode, the CPU clock stops while peripherals and the oscillation source continues to operate normally. #### **STOP Mode** In this mode, the system operations are all stopped, holding the internal states valid immediately before the stop at the low power consumption level. The main oscillation source stops, but the sub clock oscillation and watch timer by sub clock and RC-oscillated watchdog timer don't stop. Figure 20-1 Operating Mode ## 20.1 Operation Mode Switching In the Main active mode, only the high-frequency clock oscillator is used. In the Sub active mode, the low-frequency clock oscillation is used, so the low power voltage operation or the low power consumption operation can be enabled. Instruction execution does not stop during the change of operation mode. In this case, some peripheral hardware capabilities may be affected. For de- tails, refer to the description of the relevant operation. The following describes the switching between the Main active mode and the Sub active mode. During reset, the system clock mode register is initialized at the Main active mode. It must be set to the Sub active mode for reducing the power consumption. #### Shifting from the Normal operation to the SLEEP mode If the CPU clock stops and the SLEEP mode is invoked, the CPU stops while other peripherals are operate normally. The ways of release from this mode are by setting the $\overline{\text{RESET}}$ pin to low and all available interrupts. For more detail, See "21. POWER SAVING OPERATION" on page 95. ## Shifting from the Normal operation to the STOP mode If the main-frequency clock oscillation stops and the STOP mode is invoked, the CPU stops and other peripherals are stop too. But sub-frequency clock oscillation operate continuously if enabled previously. After the STOP operation is released by reset, the operation mode is changed to Main active mode. The methods of release from this mode are Reset, Watch Timer, Timer/Event counter, SIO(External clock), UART, and External Interrupt. For more details, see "21. POWER SAVING OPERATION" on page 95. **Note:** In the STOP and SLEEP operating modes, the power consumption by the oscillator and the internal hardware is reduced. However, the power for the pin interface (depending on external circuitry and program) is not directly associated with the low-power consumption operation. This must be considered in system design as well as interface circuit design. #### 21. POWER SAVING OPERATION The MC80F0208/16/24 has two power-down modes. In power-down mode, power consumption is reduced considerably. For applications where power consumption is a critical factor, device provides two kinds of power saving functions, STOP mode and SLEEP mode. Table 21-1 shows the status of each Power Saving Mode. SLEEP mode is entered by the SSCR register to "0Fh"., and STOP mode is entered by STOP instruction after the SSCR register to "5Ah". ## 21.1 Sleep Mode In this mode, the internal oscillation circuits remain active. Oscillation continues and peripherals are operate normally but CPU stops. Movement of all peripherals is shown in Table 21-1. SLEEP mode is entered by setting the SSCR register to "0Fh". It is released by Reset or interrupt. To be released by interrupt, interrupt should be enabled before SLEEP mode. Figure 21-1 STOP and SLEEP Control Register ## Release the SLEEP mode The exit from SLEEP mode is hardware reset or all interrupts. Reset re-defines all the Control registers but does not change the on-chip RAM. Interrupts allow both on-chip RAM and Control registers to retain their values. If I-flag = 1, the normal interrupt response takes place. If I-flag = 0, the chip will resume execution starting with the instruction following the SLEEP instruction. It will not vector to interrupt service routine. (refer to Figure 21-4) When exit from SLEEP mode by reset, enough oscillation stabilization time is required to normal operation. Figure 21-3 shows the timing diagram. When released from the SLEEP mode, the Basic interval timer is activated on wake-up. It is increased from $00_H$ until FF $_H$ . The count overflow is set to start normal operation. Therefore, before SLEEP instruction, user must be set its relevant prescaler divide ratio to have long enough time (more than 20msec). This guarantees that oscillator has started and stabilized. By interrupts, exit from SLEEP mode is shown in Figure 21-2. By reset, exit from SLEEP mode is shown in Figure 21-3. Oscillator (X<sub>IN</sub> pin) Internal Clock External Interrupt SLEEP Instruction Executed Normal Operation Normal Operation Normal Operation Figure 21-2 SLEEP Mode Release Timing by External Interrupt Figure 21-3 Timing of SLEEP Mode Release by Reset ## 21.2 Stop Mode In the Stop mode, the main oscillator, system clock and peripheral clock is stopped, but the sub clock oscillation and Watch Timer by sub clock and RC-oscillated watchdog timer continue to operate. With the clock frozen, all functions are stopped, but the onchip RAM and Control registers are held. The port pins out the values held by their respective port data register, port direction registers. Oscillator stops and the systems internal operations are all held up. - The states of the RAM, registers, and latches valid immediately before the system is put in the STOP state are all held. - The program counter stop the address of the instruction to be executed after the instruction "STOP" which starts the STOP operating mode. **Note:** The Stop mode is activated by execution of STOP instruction after setting the SSCR to " $5A_H$ ". (This register should be written by byte operation. If this register is set by bit manipulation instruction, for example "set1" or "clr1" instruction, it may be undesired operation) In the Stop mode of operation, $V_{DD}$ can be reduced to minimize power consumption. Care must be taken, however, to ensure that $V_{DD}$ is not reduced before the Stop mode is invoked, and that $V_{DD}$ is restored to its normal operating level, before the Stop mode is terminated. The reset should not be activated before $V_{DD}$ is restored to its normal operating level, and must be held active long enough to allow the oscillator to restart and stabilize. **Note:** After STOP instruction, at least two or more NOP instruction should be written. Ex) LDM CKCTLR,#0FH ;more than 20ms LDM SSCR,#5AH STOP NOP ;for stabilization time NOP ;for stabilization time In the STOP operation, the dissipation of the power associated with the oscillator and the internal hardware is lowered; however, the power dissipation associated with the pin interface (depending on the external circuitry and program) is not directly determined by the hardware operation of the STOP feature. This point should be little current flows when the input level is stable at the power voltage level ( $V_{\rm DD}/V_{\rm SS}$ ); however, when the input level gets higher than the power voltage level (by approximately 0.3 to 0.5V), a current begins to flow. Therefore, if cutting off the output transistor at an I/O port puts the pin signal into the high-impedance state, a current flow across the ports input transistor, requiring to fix the level by pull-up or other means. | Peripheral | STOP Mode | SLEEP Mode | |----------------------|----------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------| | CPU | Stop | Stop | | RAM | Retain | Retain | | Basic Interval Timer | Halted | Operates Continuously | | Watchdog Timer | Stop (Only operates in RC-WDT mode) | Stop | | Watch Timer | Stop | Stop | | Timer/Counter | Halted(Only when the event counter mode is enabled, timer operates normally) | Operates Continuously | | Buzzer, ADC | Stop | Stop | | SIO | Only operate with external clock | Only operate with external clock | | UART | Only operate with external clock | Only operate with external clock | | Oscillator | $Stop(X_{IN}=L, X_{OUT}=H)$ | Oscillation | | Sub Oscillator | Oscillation | Oscillation | | I/O Ports | Retain | Retain | | Control Registers | Retain | Retain | | Internal Circuit | Stop mode | Sleep mode | | Prescaler | Retain | Active | | Address Data Bus | Retain | Retain | | Release Source | Reset, Timer(EC0,1), SIO, UART0(using ACLK0), UART1(using ACLK1) Watch Timer( RC-WDT mode), Watchdog Timer( RC-WDT mode), External Interrupt | Reset, All Interrupts | **Table 21-1 Peripheral Operation During Power Saving Mode** #### Release the STOP mode The source for exit from STOP mode is hardware reset, external interrupt, Timer(EC0,1), Watch Timer, WDT, SIO or UART. Reset re-defines all the Control registers but does not change the on-chip RAM. External interrupts allow both on-chip RAM and Control registers to retain their values. If I-flag = 1, the normal interrupt response takes place. If I-flag = 0, the chip will resume execution starting with the instruction following the STOP instruction. It will not vector to interrupt service routine. (refer to Figure 21-4) When exit from Stop mode by external interrupt, enough oscillation stabilization time is required to normal operation. Figure 21-5 shows the timing diagram. When released from the Stop mode, the Basic interval timer is activated on wake-up. It is increased from $00_H$ until FF $_H$ . The count overflow is set to start normal op- eration. Therefore, before STOP instruction, user must be set its relevant prescaler divide ratio to have long enough time (more than 20msec). This guarantees that oscillator has started and stabilized. By reset, exit from Stop mode is shown in Figure 21-6. Figure 21-4 STOP Releasing Flow by Interrupts Figure 21-5 STOP Mode Release Timing by External Interrupt Figure 21-6 Timing of STOP Mode Release by Reset ## 21.3 Stop Mode at Internal RC-Oscillated Watchdog Timer Mode In the Internal RC-Oscillated Watchdog Timer mode, the on-chip oscillator is stopped. But internal RC oscillation circuit is oscillated in this mode. The on-chip RAM and Control registers are held. The port pins out the values held by their respective port data register, port direction registers. The Internal RC-Oscillated Watchdog Timer mode is activated by execution of STOP instruction after setting the bit RCWDT of CKCTLR to "1". (This register should be written by byte operation. If this register is set by bit manipulation instruction, for example "set1" or "clr1" instruction, it may be undesired operation) **Note:** Caution: After STOP instruction, at least two or more NOP instruction should be written Ex) LDM WDTR,#1111\_1111B LDM CKCTLR,#0010\_1110B LDM SSCR,#0101\_1010B STOP NOP ;for stabilization time NOP ;for stabilization time The exit from Internal RC-Oscillated Watchdog Timer mode is hardware reset or external interrupt or watchdog timer interrupt (at RC-watchdog timer mode). Reset re-defines all the Control registers but does not change the on-chip RAM. External interrupts allow both on-chip RAM and Control registers to retain their values. If I-flag = 1, the normal interrupt response takes place. In this case, if the bit WDTON of CKCTLR is set to "0" and the bit WDTE of IENH is set to "1", the device will execute the watchdog timer interrupt service routine(Figure 8-6). However, if the bit WDTON of CKCTLR is set to "1", the device will generate the internal Reset signal and execute the reset processing(Figure 21-8). If I-flag = 0, the chip will resume execution starting with the instruction following the STOP instruction. It will not vector to interrupt service routine.(refer to Figure 21-4) When exit from Stop mode at Internal RC-Oscillated Watchdog Timer mode by external interrupt, the oscillation stabilization time is required to normal operation. Figure 21-7 shows the timing diagram. When release the Internal RC-Oscillated Watchdog Timer mode, the basic interval timer is activated on wake-up. It is increased from $00_{\rm H}$ until FF $_{\rm H}$ . The count overflow is set to start normal operation. Therefore, before STOP instruction, user must be set its relevant prescaler divide ratio to have long enough time (more than 20msec). This guarantees that oscillator has started and stabilized. By reset, exit from internal RC-Oscillated Watchdog Timer mode is shown in Figure 21-8. Figure 21-7 Stop Mode Release at Internal RC-WDT Mode by External Interrupt or WDT Interrupt Figure 21-8 Internal RC-WDT Mode Releasing by Reset # 21.4 Minimizing Current Consumption The Stop mode is designed to reduce power consumption. To minimize current drawn during Stop mode, the user should turn- INPUT PIN VDD internal pull-up VDD VDD OPEN OPEN off output drivers that are sourcing or sinking current, if it is practical. Figure 21-9 Application Example of Unused Input Port Figure 21-10 Application Example of Unused Output Port **Note:** In the STOP operation, the power dissipation associated with the oscillator and the internal hardware is lowered; however, the power dissipation associated with the pin interface (depending on the external circuitry and program) is not directly determined by the hardware operation of the STOP feature. This point should be little current flows when the input level is stable at the power voltage level $(V_{DD}/V_{SS})$ ; however, when the input level becomes higher than the power voltage level (by approximately 0.3V), a current begins to flow. Therefore, if cutting off the output transistor at an I/O port puts the pin signal into the high-impedance state, a current flow across the ports input transistor, requiring it to fix the level by pull-up or other means. It should be set properly in order that current flow through port doesn't exist. First consider the port setting to input mode. Be sure that there is no current flow after considering its relationship with external circuit. In input mode, the pin impedance viewing from external MCU is very high that the current doesn't flow. But input voltage level should be $V_{SS}$ or $V_{DD}$ . Be careful that if unspecified voltage, i.e. if uncertain voltage level (not $V_{SS}$ or $V_{DD}$ ) is applied to input pin, there can be little current (max. 1mA at around 2V) flow. If it is not appropriate to set as an input mode, then set to output mode considering there is no current flow. The port setting to High or Low is decided by considering its relationship with external circuit. For example, if there is external pull-up resistor then it is set to output mode, i.e. to High, and if there is external pull-down register, it is set to low. # 22. OSCILLATOR CIRCUIT The MC80F0208/16/24 have oscillation circuits internally. $X_{\rm IN}$ and $X_{\rm OUT}$ are input and output for frequency. Respectively, in- verting amplifier which can be configured for being used as an on-chip oscillator, as shown in Figure 22-1. Figure 22-1 Oscillation Circuit Oscillation circuit is designed to be used either with a ceramic resonator or crystal oscillator. Since each crystal and ceramic resonator have their own characteristics, the user should consult the crystal manufacturer for appropriate values of external components. In addition, see Figure 22-2 for the layout of the crystal. **Note:** Minimize the wiring length. Do not allow the wiring to intersect with other signal conductors. Do not allow the wiring to come near changing high current. Set the potential of the grounding position of the oscillator capacitor to that of Vss. Do not ground it to any ground pattern where high current is present. Do not fetch signals from the oscillator. Figure 22-2 Layout of Oscillator PCB circuit #### **23. RESET** The MC80F0208/16/24 have four types of reset generation procedures; they are an external reset input, a watch-dog timer reset, | On-chip Hardw | Initial Value | | |-------------------|---------------|---------------------------------------------| | Program counter | (PC) | (FFFF <sub>H</sub> ) - (FFFE <sub>H</sub> ) | | RAM page register | (RPR) | 0 | | G-flag | (G) | 0 | | Operation mode | | Main-frequency clock | power fail processor reset, and address fail reset. Table 23-1 shows on-chip hardware initialization by reset action. | On-chip Hardware | Initial Value | |---------------------|-------------------------------| | Peripheral clock | Off | | Watchdog timer | Disable | | Control registers | Refer to Table 8-1 on page 27 | | Power fail detector | Disable | Table 23-1 Initializing Internal Status by Reset Action #### **External Reset Input** The reset input is the RESET pin, which is the input to a Schmitt Trigger. A reset in accomplished by holding the RESET pin low for at least 8 oscillator periods, within the operating voltage range and oscillation stable, it is applied, and the internal state is initialized. After reset, 65.5ms (at 4 MHz) add with 7 oscillator periods are required to start execution as shown in Figure 23-2. Internal RAM is not affected by reset. When $V_{DD}$ is turned on, the RAM content is indeterminate. Therefore, this RAM should be initialized before read or tested it. When the $\overline{RESET}$ pin input goes to high, the reset operation is released and the program execution starts at the vector address stored at addresses FFFE $_H$ - FFFF $_H$ . A connection for simple power-on-reset is shown in Figure 23-1. Figure 23-1 Simple Power-on-Reset Circuit Figure 23-2 Timing Diagram after Reset #### **Address Fail Reset** The Address Fail Reset is the function to reset the system by checking code access of abnormal and unwished address caused by erroneous program code itself or external noise, which could not be returned to normal operation and would become malfunction state. If the CPU tries to fetch the instruction from ineffective code area or RAM area, the address fail reset is occurred. Please refer to Figure 11-2 for setting address fail option. #### 24. POWER FAIL PROCESSOR The MC80F0208/16/24 has an on-chip power fail detection circuitry to immunize against power noise. A configuration register, PFDR, can enable or disable the power fail detect circuitry. Whenever $V_{DD}$ falls close to or below power fail voltage for 100ns, the power fail situation may reset or freeze MCU according to PFDM bit of PFDR. Refer to "Figure 24-1 Power Fail Voltage Detector Register" on page 105. In the in-circuit emulator, power fail function is not implemented and user can not experiment with it. Therefore, after final development of user program, this function may be experimented or evaluated. **Note:** User can select power fail voltage level according to PFS0, PFS1 bit of CONFIG register(703FH) at the FLASH (MC80F0208/16/24) but must select the power fail voltage level to define PFD option of "Mask Order & Verification Sheet" at the mask chip(MC80C0208/16/24), because the power fail voltage level of mask chip (MC80C0208/16/24) is determined according to mask option. **Note:** If power fail voltage is selected to 2.4V or 2.7V on below 3V operation, MCU is freezed at all the times. | Power Fail Function | FLASH | MASK | |---------------------|----------------------|-------------| | Enable/Disable | PFDEN flag | PFDEN flag | | Level Selection | PFS0 bit<br>PFS1 bit | Mask option | Table 24-1 Power fail processor Figure 24-1 Power Fail Voltage Detector Register Figure 24-2 Example S/W of Reset flow by Power fail Figure 24-3 Power Fail Processor Situations (at 4MHz operation) ## 25. FLASH PROGRAMMING The Device Configuration Area can be programmed or left unprogrammed to select device configuration such as security bit. This area is not accessible during normal execution but is readable and writable during FLASH program / verify mode. The Device Configuration Area register is located at the address 20FF<sub>H</sub>. Figure 25-1 Device Configuration Area ## 25.1 Lock bit The lock bit exists in Device Configuration Area register. If lock bit is programmed and user tries to read FLASH memory cell, the output data from the data port is 5AH that means the normal pro- tection operation of user program data. Once the lock bit is programmed, the user can't modify and read the data of user program area. #### 25.2 Power Fail Detector The power fail detection provides 3 level of detection, 2.4V, 2.7V and 3.0V. The default level of detection is 2.7V and this level is applied if user does not select the specific level in FLASH pro- gramming S/W tools. For more information, Refer to "24. POW-ER FAIL PROCESSOR" on page 105. # 26. Emulator EVA. Board Setting ## **DIP Switch and VR Setting** Before execute the user program, keep in your mind the below configuration | DIP S | s/W | Description | ON/OFF Setting | | | |-----------------|-----|--------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | O | - | This connector is only used for a device over 32 PIN. | For the MC80F0208/16/24. | | | | <b>Q</b> | - | This connector is only used for a device under 32 PIN. | For the MC80F0204. | | | | | 1 | ON Eva. select switch | Must be <b>ON</b> position. <b>ON</b> : For the MC80F0208/16/24. <b>OFF</b> : For the MC80F0204. | | | | <b>③</b> | 2 3 | ON OFF ON Use Eva. V <sub>DD</sub> AV <sub>DD</sub> pin select switch | These switches select the $AV_{DD}$ source.<br><b>ON &amp; OFF</b> : Use Eva. $V_{DD}$ <b>OFF &amp; ON</b> : Use User $AV_{DD}$ | | | | SW2 | 4 | This switch select the /Reset source. | Normally <b>OFF</b> . EVA. chip can be reset by external user target board. <b>ON</b> : Reset is available by either user target system board or Emulator RESET switch. <b>OFF</b> : Reset the MCU by Emulator RESET switch. Does not work from user target board. | | | | | 5 | This switch select the Xout signal on/off. | Normally OFF. MCU XOUT pin is disconnected internally in the Emulator. Some circumstance user may connect this circuit. ON: Output XOUT signal OFF: Disconnect circuit | | | | <b>4</b><br>sw3 | 1 | This switch select Eva. B/D Power supply source. MDS WDS USER USER Use MDS Power Use User's Power | Normally <b>MDS</b> . This switch select Eva. B/D Power supply source. | | | | <b>5</b><br>SW4 | 1 2 | This switch select the R22 or $\mathrm{SX}_{\mathrm{OUT}}$ . This switch select the R21 or $\mathrm{SX}_{\mathrm{IN}}$ . | These switchs select the Normal I/O port(off) or Sub-Clock (on). It is reserved for the MC80F0448. ON: SX <sub>OUT</sub> , SX <sub>IN</sub> OFF: R22, R21 Don't care (MC80F0208/16/24). | | | | DIP S | 6/W | Description | ON/OFF Setting | |-------|--------|----------------------------------------------------|-----------------------------------------------------------------------------------------------------------| | 6 | 1 2 | These switches select the R33 or X <sub>IN</sub> | This switch select the Normal I/O port(on&off) or special function | | SW5 | 3<br>4 | These switches select the R34 or X <sub>OUT</sub> | select(off&on). It is reserved for the MC80F0204. ON & OFF: R33,R34,R35 Port selected. | | | 5<br>6 | These switches select the R35 or /Reset | <b>OFF &amp; ON</b> : X <sub>OUT</sub> , X <sub>IN</sub> , /Reset selected. Don't care (MC80F0208/16/24). | | 7 | - | This is External oscillation socket(CAN Type. OSC) | This is for External Clock(CAN Type. OSC). | ## 27. IN-SYSTEM PROGRAMMING (ISP) #### 27.1 Getting Started / Installation The following section details the procedure for accomplishing the installation procedure. - 1. Connect the serial(RS-232C) cable between a target board and the COM port of your PC. - 2. Configure the COM port of your PC as following. | Baudrate | 115,200 | |--------------|---------| | Data bit | 8 | | Parity | No | | Stop bit | 1 | | Flow control | No | - 3. Turn your target B/D power switch ON. Your target B/D must be configured to enter the ISP mode. - 4. Run the MagnaChip ISP software. - 5. Press the Reset Button in the ISP S/W. If the status windows shows a message as "Connected", all the conditions for ISP are provided. #### 27.2 Basic ISP S/W Information | Function | Description | |-------------------|---------------------------------------------------------------------------------------------------------------------------------| | Load HEX File | Load the data from the selected file storage into the memory buffer. | | Save HEX File | Save the current data in your memory buffer to a disk storage by using the Intel Motorolla HEX format. | | Erase | Erase the data in your target MCU before programming it. | | Blank Check | Verify whether or not a device is in an erased or unprogrammed state. | | Program | This button enables you to place new data from the memory buffer into the target device. | | Read | Read the data in the target MCU into the buffer for examination. The checksum will be displayed on the checksum box. | | Verify | Assures that data in the device matches data in the memory buffer. If your device is secured, a verification error is detected. | | Option Write | Progam the configuration data of target MCU. The security locking is performed with this button. | | Option | Set the configuration data of target MCU. The security locking is set with this button. | | AUTO | Erase & Program & Verify. | | Auto Option Write | If selected with check mark, the option write is performed after erasure and write. | | Edit Buffer | Modify the data in the selected address in your buffer memory | | Fill Buffer | Fill the selected area with a data. | | Goto | Display the selected page. | | OSC MHz | Enter your target system's oscillator value with discarding below point. | | Start | Starting address | | End | End address | | Checksum | Display the checksum(Hexdecimal) after reading the target device. | | Com Port | Select serial port. | | Baud Rate | Select UART baud rate. | | Select Device | Select target device. | | Page Up Key | Display the previous page of your memory buffer. | | Page Down Key | Display the higher page than the current location. | **Table 1. ISP Function Description** #### 27.3 Hardware Conditions to Enter the ISP Mode The In-System Programming (ISP) is performed without removing the microcontroller from the target system. The In-System Programming(ISP) facility consists of a series of internal hardware resources coupled with internal firmware through the serial port. The In-System Programming (ISP) facility has made in-circuit programming in an embedded application possible with a minimum of additional expense in components and circuit board area. The boot loader can be executed by holding ALEB high, RST/ $V_{PP}$ as +9V, and ACLK0 with the OSC. 1.8432MHz. The ISP function uses five pins: TxD0, RxD0, ALEB, ACLK0 and RST/ $V_{PP}$ . Figure 27-1 ISP Configuration **Note:** Considerations to implement ISP function in a user target board - The ACLK0 must be connected to the specifed oscillator. - Connect the +9V to RST/Vpp pin directly. - The ALEB pin must be pulled high. - The main clk must be higher than 2MHz. ## 27.4 Reference ISP Circuit diagram The ISP S/W and H/W circuit diagram are provided at <a href="https://www.magnachipmcu.com">www.magnachipmcu.com</a> . To get a ISP B/D, contact to sales department. The following circuit diagram is for reference use. Figure 27-2 Reference ISP Circuit Diagram Figure 27-3 MagnaChip supplied ISP Board # **APPENDIX** # A. INSTRUCTION # A.1 Terminology List | Terminology | Description | |-------------------|-------------------------------------------------------------------| | A | Accumulator | | X | X - register | | Υ | Y - register | | PSW | Program Status Word | | #imm | 8-bit Immediate data | | dp | Direct Page Offset Address | | !abs | Absolute Address | | [] | Indirect expression | | {} | Register Indirect expression | | {}+ | Register Indirect expression, after that, Register auto-increment | | .bit | Bit Position | | A.bit | Bit Position of Accumulator | | dp.bit | Bit Position of Direct Page Memory | | M.bit | Bit Position of Memory Data (000H~0FFFH) | | rel | Relative Addressing Data | | upage | U-page (0FF00 <sub>H</sub> ~0FFFF <sub>H</sub> ) Offset Address | | n | Table CALL Number (0~15) | | + | Addition | | х | Upper Nibble Expression in Opcode → Bit Position | | у | Upper Nibble Expression in Opcode Bit Position | | - | Subtraction | | × | Multiplication | | 1 | Division | | () | Contents Expression | | ٨ | AND | | V | OR | | • | Exclusive OR | | ~ | NOT | | <b>←</b> | Assignment / Transfer / Shift Left | | $\rightarrow$ | Shift Right | | $\leftrightarrow$ | Exchange | | = | Equal | | <b>≠</b> | Not Equal | MAR. 2005 i # A.2 Instruction Map | LOW<br>HIGH | 00000 | 00001<br>01 | 00010<br>02 | 00011<br>03 | 00100<br>04 | 00101<br>05 | 00110<br>06 | 00111<br>07 | 01000<br>08 | 01001<br>09 | 01010<br>0A | 01011<br>0B | 01100<br>0C | 01101<br>0D | 01110<br>0E | 01111<br>0F | |-------------|-------|----------------|------------------|-------------------|----------------|-------------|-------------|-------------|-------------|-------------|-------------|---------------|-------------|--------------|-------------|----------------| | 000 | - | SET1<br>dp.bit | BBS<br>A.bit,rel | BBS<br>dp.bit,rel | ADC<br>#imm | ADC<br>dp | ADC<br>dp+X | ADC<br>!abs | ASL<br>A | ASL<br>dp | TCALL<br>0 | SETA1<br>.bit | BIT<br>dp | POP<br>A | PUSH<br>A | BRK | | 001 | CLRC | | | | SBC<br>#imm | SBC<br>dp | SBC<br>dp+X | SBC<br>!abs | ROL<br>A | ROL<br>dp | TCALL 2 | CLRA1 | COM<br>dp | POP<br>X | PUSH<br>X | BRA<br>rel | | 010 | CLRG | | | | CMP<br>#imm | CMP<br>dp | CMP<br>dp+X | CMP<br>!abs | LSR<br>A | LSR<br>dp | TCALL<br>4 | NOT1<br>M.bit | TST<br>dp | POP<br>Y | PUSH<br>Y | PCALL<br>Upage | | 011 | DI | | | | OR<br>#imm | OR<br>dp | OR<br>dp+X | OR<br>!abs | ROR<br>A | ROR<br>dp | TCALL<br>6 | OR1<br>OR1B | CMPX<br>dp | POP<br>PSW | PUSH<br>PSW | RET | | 100 | CLRV | | | | AND<br>#imm | AND<br>dp | AND<br>dp+X | AND<br>!abs | INC<br>A | INC<br>dp | TCALL<br>8 | AND1<br>AND1B | CMPY<br>dp | CBNE<br>dp+X | TXSP | INC<br>X | | 101 | SETC | | | | EOR<br>#imm | EOR<br>dp | EOR<br>dp+X | EOR<br>!abs | DEC<br>A | DEC<br>dp | TCALL<br>10 | EOR1<br>EOR1B | DBNE<br>dp | XMA<br>dp+X | TSPX | DEC<br>X | | 110 | SETG | | | | LDA<br>#imm | LDA<br>dp | LDA<br>dp+X | LDA<br>!abs | TXA | LDY<br>dp | TCALL<br>12 | LDC<br>LDCB | LDX<br>dp | LDX<br>dp+Y | XCN | DAS | | 111 | EI | | | | LDM<br>dp,#imm | STA<br>dp | STA<br>dp+X | STA<br>!abs | TAX | STY<br>dp | TCALL<br>14 | STC<br>M.bit | STX<br>dp | STX<br>dp+Y | XAX | STOP | | LOW<br>HIGH | 10000<br>10 | 10001<br>11 | 10010<br>12 | 10011<br>13 | 10100<br>14 | 10101<br>15 | 10110<br>16 | 10111<br>17 | 11000<br>18 | 11001<br>19 | 11010<br>1A | 11011<br>1B | 11100<br>1C | 11101<br>1D | 11110<br>1E | 11111<br>1F | |-------------|-------------|----------------|------------------|-------------------|-------------|---------------|---------------|---------------|-------------|-------------|-------------|--------------|--------------|-------------|--------------|---------------| | 000 | BPL<br>rel | CLR1<br>dp.bit | BBC<br>A.bit,rel | BBC<br>dp.bit,rel | ADC<br>{X} | ADC<br>!abs+Y | ADC<br>[dp+X] | ADC<br>[dp]+Y | ASL<br>!abs | ASL<br>dp+X | TCALL<br>1 | JMP<br>!abs | BIT<br>!abs | ADDW<br>dp | LDX<br>#imm | JMP<br>[!abs] | | 001 | BVC<br>rel | | | | SBC<br>{X} | SBC<br>!abs+Y | SBC<br>[dp+X] | SBC<br>[dp]+Y | ROL<br>!abs | ROL<br>dp+X | TCALL<br>3 | CALL<br>!abs | TEST<br>!abs | SUBW<br>dp | LDY<br>#imm | JMP<br>[dp] | | 010 | BCC<br>rel | | | | CMP<br>{X} | CMP<br>!abs+Y | CMP<br>[dp+X] | CMP<br>[dp]+Y | LSR<br>!abs | LSR<br>dp+X | TCALL<br>5 | MUL | TCLR1 | CMPW<br>dp | CMPX<br>#imm | CALL<br>[dp] | | 011 | BNE<br>rel | | | | OR<br>{X} | OR<br>!abs+Y | OR<br>[dp+X] | OR<br>[dp]+Y | ROR<br>!abs | ROR<br>dp+X | TCALL<br>7 | DBNE<br>Y | CMPX !abs | LDYA<br>dp | CMPY<br>#imm | RETI | | 100 | BMI<br>rel | | | | AND<br>{X} | AND<br>!abs+Y | AND<br>[dp+X] | AND<br>[dp]+Y | INC<br>!abs | INC<br>dp+X | TCALL<br>9 | DIV | CMPY<br>!abs | INCW<br>dp | INC<br>Y | TAY | | 101 | BVS<br>rel | | | | EOR<br>{X} | EOR<br>!abs+Y | EOR<br>[dp+X] | EOR<br>[dp]+Y | DEC<br>!abs | DEC<br>dp+X | TCALL<br>11 | XMA<br>{X} | XMA<br>dp | DECW<br>dp | DEC<br>Y | TYA | | 110 | BCS<br>rel | | | | LDA<br>{X} | LDA<br>!abs+Y | LDA<br>[dp+X] | LDA<br>[dp]+Y | LDY<br>!abs | LDY<br>dp+X | TCALL<br>13 | LDA<br>{X}+ | LDX<br>!abs | STYA<br>dp | XAY | DAA | | 111 | BEQ<br>rel | | | | STA<br>{X} | STA<br>!abs+Y | STA<br>[dp+X] | STA<br>[dp]+Y | STY<br>!abs | STY<br>dp+X | TCALL<br>15 | STA<br>{X}+ | STX<br>!abs | CBNE<br>dp | XYX | NOP | ii MAR. 2005 # A.3 Instruction Set # **Arithmetic / Logic Operation** | No. | Mnemonic | Op<br>Code | Byte<br>No | Cycle<br>No | Operation | Flag<br>NVGBHIZC | |-----|--------------|------------|------------|-------------|---------------------------------------------------|------------------| | 1 | ADC #imm | 04 | 2 | 2 | Add with carry. | | | 2 | ADC dp | 05 | 2 | 3 | A ← ( A ) + ( M ) + C | | | 3 | ADC dp + X | 06 | 2 | 4 | , , , , | | | 4 | ADC !abs | 07 | 3 | 4 | | NVH-ZC | | 5 | ADC !abs + Y | 15 | 3 | 5 | | | | 6 | ADC [dp + X] | 16 | 2 | 6 | | | | 7 | ADC [dp]+Y | 17 | 2 | 6 | | | | 8 | ADC {X} | 14 | 1 | 3 | | | | 9 | AND #imm | 84 | 2 | 2 | Logical AND | | | 10 | AND dp | 85 | 2 | 3 | $A \leftarrow (A) \land (M)$ | | | 11 | AND dp + X | 86 | 2 | 4 | | | | 12 | AND !abs | 87 | 3 | 4 | | NZ- | | 13 | AND !abs + Y | 95 | 3 | 5 | | | | 14 | AND [dp+X] | 96 | 2 | 6 | | | | 15 | AND [dp]+Y | 97 | 2 | 6 | | | | 16 | AND {X} | 94 | 1 | 3 | | | | 17 | ASL A | 08 | 1 | 2 | Arithmetic shift left | | | 18 | ASL dp | 09 | 2 | 4 | | NZC | | 19 | ASL dp + X | 19 | 2 | 5 | C 7 6 5 4 3 2 1 0<br>←←←←←←←← ← ← "0" | | | 20 | ASL !abs | 18 | 3 | 5 | | | | 21 | CMP #imm | 44 | 2 | 2 | | | | 22 | CMP dp | 45 | 2 | 3 | | | | 23 | CMP dp + X | 46 | 2 | 4 | | | | 24 | CMP labs | 47 | 3 | 4 | Compare accumulator contents with memory contents | NZC | | 25 | CMP !abs + Y | 55 | 3 | 5 | (A)-(M) | | | 26 | CMP [dp + X] | 56 | 2 | 6 | | | | 27 | CMP [dp]+Y | 57 | 2 | 6 | | | | 28 | CMP {X} | 54 | 1 | 3 | | | | 29 | CMPX #imm | 5E | 2 | 2 | Compare X contents with memory contents | | | 30 | CMPX dp | 6C | 2 | 3 | (X)-(M) | NZC | | 31 | CMPX !abs | 7C | 3 | 4 | | | | 32 | CMPY #imm | 7E | 2 | 2 | Compare Y contents with memory contents | | | 33 | CMPY dp | 8C | 2 | 3 | (Y)-(M) | NZC | | 34 | CMPY !abs | 9C | 3 | 4 | | | | 35 | COM dp | 2C | 2 | 4 | 1'S Complement : ( dp ) ← ~( dp ) | NZ- | | 36 | DAA | DF | 1 | 3 | Decimal adjust for addition | NZC | | 37 | DAS | CF | 1 | 3 | Decimal adjust for subtraction | NZC | | 38 | DEC A | A8 | 1 | 2 | Decrement | NZ- | | 39 | DEC dp | A9 | 2 | 4 | M ← (M)-1 | NZ- | | 40 | DEC dp + X | В9 | 2 | 5 | | NZ- | | 41 | DEC !abs | B8 | 3 | 5 | | NZ- | | 42 | DEC X | AF | 1 | 2 | | NZ- | | 43 | DEC Y | BE | 1 | 2 | | NZ- | MAR. 2005 iii | No. | Mnemonic | Op<br>Code | Byte<br>No | Cycle<br>No | Operation | Flag<br>NVGBHIZC | |-----|--------------|------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------|------------------| | 44 | DIV | 9B | 1 | 12 | Divide: YA / X Q: A, R: Y | NVH-Z- | | 45 | EOR #imm | A4 | 2 | 2 | Exclusive OR | | | 46 | EOR dp | A5 | 2 | 3 | $A \leftarrow (A) \oplus (M)$ | | | 47 | EOR dp + X | A6 | 2 | 4 | | | | 48 | EOR !abs | A7 | 3 | 4 | | NZ- | | 49 | EOR !abs + Y | B5 | 3 | 5 | | | | 50 | EOR [dp + X] | B6 | 2 | 6 | | | | 51 | EOR [dp]+Y | B7 | 2 | 6 | | | | 52 | EOR {X} | B4 | 1 | 3 | | | | 53 | INC A | 88 | 1 | 2 | Increment | NZC | | 54 | INC dp | 89 | 2 | 4 | M ← (M)+1 | NZ- | | 55 | INC dp + X | 99 | 2 | 5 | | NZ- | | 56 | INC !abs | 98 | 3 | 5 | | NZ- | | 57 | INC X | 8F | 1 | 2 | | NZ- | | 58 | INC Y | 9E | 1 | 2 | | NZ- | | 59 | LSR A | 48 | 1 | 2 | Logical shift right | | | 60 | LSR dp | 49 | 2 | 4 | | NZC | | 61 | LSR dp + X | 59 | 2 | 5 | $ \begin{array}{cccccccccccccccccccccccccccccccccccc$ | | | 62 | LSR !abs | 58 | 3 | 5 | | | | 63 | MUL | 5B | 1 | 9 | Multiply: $YA \leftarrow Y \times A$ | NZ- | | 64 | OR #imm | 64 | 2 | 2 | Logical OR | | | 65 | OR dp | 65 | 2 | 3 | $A \leftarrow (A) \lor (M)$ | | | 66 | OR dp + X | 66 | 2 | 4 | (/.) . () | | | 67 | OR !abs | 67 | 3 | 4 | | NZ- | | 68 | OR !abs + Y | 75 | 3 | 5 | | | | 69 | OR [dp + X] | 76 | 2 | 6 | | | | 70 | OR [dp]+Y | 77 | 2 | 6 | | | | 71 | OR {X} | 74 | 1 | 3 | | | | 72 | ROL A | 28 | 1 | 2 | | | | 73 | ROL dp | 29 | 2 | 4 | Rotate left through Carry | NZC | | 74 | ROL dp + X | 39 | 2 | 5 | C 7 6 5 4 3 2 1 0<br>← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← ← | N2C | | 75 | · | 38 | 3 | | | | | 76 | ROL !abs | 68 | 1 | 5 | | | | | | | | | Rotate right through Carry | N 50 | | 77 | ROR dp | 69 | 2 | 4 | 7 6 5 4 3 2 1 0 C<br>→ → → → → → → → → — | NZC | | 78 | ROR dp + X | 79 | 2 | 5 | | | | 79 | ROR !abs | 78 | 3 | 5 | Culture et with Commi | | | 80 | SBC #imm | 24 | 2 | 2 | Subtract with Carry | | | 81 | SBC dp | 25 | 2 | 3 | A ← (A)-(M)-~(C) | | | 82 | SBC dp + X | 26 | 2 | 4 | | | | 83 | SBC !abs | 27 | 3 | 4 | | NVHZC | | 84 | SBC !abs + Y | 35 | 3 | 5 | | | | 85 | SBC [dp + X] | 36 | 2 | 6 | | | | 86 | SBC [dp]+Y | 37 | 2 | 6 | | | | 87 | SBC {X} | 34 | 1 | 3 | | | | 88 | TST dp | 4C | 2 | 3 | Test memory contents for negative or zero, ( dp ) - 00 <sub>H</sub> | NZ- | | 89 | XCN | CE | 1 | 5 | Exchange nibbles within the accumulator $A_7 \!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!$ | NZ- | iv MAR. 2005 # **Register / Memory Operation** | No. | Mnemonic | Op<br>Code | Byte<br>No | Cycle<br>No | Operation | Flag<br>NVGBHIZC | |-----|--------------|------------|------------|-------------|-----------------------------------------------------------------------|------------------| | 1 | LDA #imm | C4 | 2 | 2 | Load accumulator | | | 2 | LDA dp | C5 | 2 | 3 | $A \leftarrow (M)$ | | | 3 | LDA dp + X | C6 | 2 | 4 | | | | 4 | LDA !abs | C7 | 3 | 4 | | | | 5 | LDA !abs + Y | D5 | 3 | 5 | | NZ- | | 6 | LDA [dp+X] | D6 | 2 | 6 | | | | 7 | LDA [dp]+Y | D7 | 2 | 6 | | | | 8 | LDA {X} | D4 | 1 | 3 | | | | 9 | LDA { X }+ | DB | 1 | 4 | X- register auto-increment : A $\leftarrow$ (M), X $\leftarrow$ X + 1 | ĺ | | 10 | LDM dp,#imm | E4 | 3 | 5 | Load memory with immediate data : ( M ) ← imm | | | 11 | LDX #imm | 1E | 2 | 2 | Load X-register | | | 12 | LDX dp | СС | 2 | 3 | X ← ( M ) | NZ- | | 13 | LDX dp + Y | CD | 2 | 4 | | | | 14 | LDX !abs | DC | 3 | 4 | | | | 15 | LDY #imm | 3E | 2 | 2 | Load Y-register | | | 16 | LDY dp | C9 | 2 | 3 | Y ← ( M ) | NZ- | | 17 | LDY dp + X | D9 | 2 | 4 | | | | 18 | LDY labs | D8 | 3 | 4 | | | | 19 | STA dp | E5 | 2 | 4 | Store accumulator contents in memory | | | 20 | STA dp + X | E6 | 2 | 5 | (M) ← A | | | 21 | STA !abs | E7 | 3 | 5 | () | | | 22 | STA !abs + Y | F5 | 3 | 6 | | | | 23 | STA [dp + X] | F6 | 2 | 7 | | | | 24 | STA [dp]+Y | F7 | 2 | 7 | | | | 25 | STA {X} | F4 | 1 | 4 | | | | 26 | STA { X }+ | FB | 1 | 4 | X- register auto-increment : (M) $\leftarrow$ A, X $\leftarrow$ X + 1 | | | 27 | STX dp | EC | 2 | 4 | Store X-register contents in memory | | | 28 | STX dp + Y | ED | 2 | 5 | (M) ← X | | | 29 | STX labs | FC | 3 | 5 | (W) ~ X | | | 30 | STY dp | E9 | 2 | 4 | Store Y-register contents in memory | | | 31 | STY dp + X | F9 | 2 | 5 | (M) ← Y | | | 32 | STY up + x | F8 | 3 | 5 | ( IVI ) ← 1 | | | | TAX | E8 | _ | | Transfer accumulator contents to X-register : X ← A | NZ- | | 33 | | + | 1 | 2 | | NZ- | | 34 | TAY | 9F | 1 | 2 | Transfer accumulator contents to Y-register : Y ← A | | | 35 | TSPX | AE | 1 | 2 | Transfer stack-pointer contents to X-register : X ← sp | NZ- | | 36 | TXA | C8 | 1 | 2 | Transfer X-register contents to accumulator: A ← X | NZ- | | 37 | TXSP | 8E | 1 | 2 | Transfer X-register contents to stack-pointer: sp $\leftarrow$ X | NZ- | | 38 | TYA | BF | 1 | 2 | Transfer Y-register contents to accumulator: $A \leftarrow Y$ | NZ- | | 39 | XAX | EE | 1 | 4 | Exchange X-register contents with accumulator :X ↔ A | | | 40 | XAY | DE | 1 | 4 | Exchange Y-register contents with accumulator :Y ↔ A | | | 41 | XMA dp | BC | 2 | 5 | Exchange memory contents with accumulator | | | 42 | XMA dp+X | AD | 2 | 6 | $(M) \leftrightarrow A$ | NZ- | | 43 | XMA {X} | BB | 1 | 5 | | | | 44 | XYX | FE | 1 | 4 | Exchange X-register contents with Y-register : $X \leftrightarrow Y$ | | MAR. 2005 ## 16-BIT operation | No. | Mnemonic | Op<br>Code | Byte<br>No | Cycle<br>No | Operation | Flag<br>NVGBHIZC | |-----|----------|------------|------------|-------------|-------------------------------------------------------------------|------------------| | 1 | ADDW dp | 1D | 2 | 5 | 16-Bits add without Carry YA ← ( YA ) + ( dp +1 ) ( dp ) | NVH-ZC | | 2 | CMPW dp | 5D | 2 | 4 | Compare YA contents with memory pair contents : (YA) – (dp+1)(dp) | NZC | | 3 | DECW dp | BD | 2 | 6 | Decrement memory pair $(dp+1)(dp) \leftarrow (dp+1)(dp) - 1$ | NZ- | | 4 | INCW dp | 9D | 2 | 6 | Increment memory pair ( dp+1) ( dp ) ← ( dp+1) ( dp ) + 1 | NZ- | | 5 | LDYA dp | 7D | 2 | 5 | Load YA<br>YA ← ( dp +1 ) ( dp ) | NZ- | | 6 | STYA dp | DD | 2 | 5 | Store YA<br>( dp +1 ) ( dp ) ← YA | | | 7 | SUBW dp | 3D | 2 | 5 | 16-Bits subtract without carry YA ← (YA) - (dp +1) (dp) | NVH-ZC | # **Bit Manipulation** | No. | Mnemonic | Op<br>Code | Byte<br>No | Cycle<br>No | Operation | Flag<br>NVGBHIZC | |-----|-------------|------------|------------|-------------|---------------------------------------------------------------------------|------------------| | 1 | AND1 M.bit | 8B | 3 | 4 | Bit AND C-flag : $C \leftarrow (C) \land (M.bit)$ | C | | 2 | AND1B M.bit | 8B | 3 | 4 | Bit AND C-flag and NOT : $C \leftarrow (C) \land \sim (M.bit)$ | C | | 3 | BIT dp | 0C | 2 | 4 | Bit test A with memory : | MMZ- | | 4 | BIT !abs | 1C | 3 | 5 | $Z \leftarrow (A) \land (M), N \leftarrow (M_7), V \leftarrow (M_6)$ | | | 5 | CLR1 dp.bit | y1 | 2 | 4 | Clear bit : (M.bit) ← "0" | | | 6 | CLRA1 A.bit | 2B | 2 | 2 | Clear A bit : ( A.bit ) ← "0" | | | 7 | CLRC | 20 | 1 | 2 | Clear C-flag : C ← "0" | 0 | | 8 | CLRG | 40 | 1 | 2 | Clear G-flag : G ← "0" | 0 | | 9 | CLRV | 80 | 1 | 2 | Clear V-flag : V ← "0" | -00 | | 10 | EOR1 M.bit | AB | 3 | 5 | Bit exclusive-OR C-flag : $C \leftarrow (C) \oplus (M.bit)$ | C | | 11 | EOR1B M.bit | AB | 3 | 5 | Bit exclusive-OR C-flag and NOT : C $\leftarrow$ ( C ) $\oplus$ ~(M .bit) | C | | 12 | LDC M.bit | СВ | 3 | 4 | Load C-flag : C ← ( M .bit ) | C | | 13 | LDCB M.bit | СВ | 3 | 4 | Load C-flag with NOT : $C \leftarrow \sim (M \cdot bit)$ | C | | 14 | NOT1 M.bit | 4B | 3 | 5 | Bit complement : ( M .bit ) ← ~( M .bit ) | | | 15 | OR1 M.bit | 6B | 3 | 5 | Bit OR C-flag : $C \leftarrow (C) \lor (M .bit)$ | C | | 16 | OR1B M.bit | 6B | 3 | 5 | Bit OR C-flag and NOT : C $\leftarrow$ ( C ) $\vee$ $\sim$ ( M .bit ) | C | | 17 | SET1 dp.bit | x1 | 2 | 4 | Set bit : ( M.bit ) ← "1" | | | 18 | SETA1 A.bit | 0B | 2 | 2 | Set A bit : ( A.bit ) ← "1" | | | 19 | SETC | A0 | 1 | 2 | Set C-flag : C ← "1" | 1 | | 20 | SETG | C0 | 1 | 2 | Set G-flag : G ← "1" | 1 | | 21 | STC M.bit | EB | 3 | 6 | Store C-flag : ( M .bit ) ← C | | | 22 | TCLR1 !abs | 5C | 3 | 6 | Test and clear bits with A : A - (M), (M) $\leftarrow$ (M) $\wedge$ ~(A) | NZ- | | 23 | TSET1 !abs | 3C | 3 | 6 | Test and set bits with A:<br>A-(M), (M) $\leftarrow$ (M) $\vee$ (A) | NZ- | vi MAR. 2005 # **Branch / Jump Operation** | No. | Mnemonic | Op<br>Code | Byte<br>No | Cycle<br>No | Operation | Flag<br>NVGBHIZC | |-----|----------------|------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------| | 1 | BBC A.bit,rel | y2 | 2 | 4/6 | Branch if bit clear : | | | 2 | BBC dp.bit,rel | у3 | 3 | 5/7 | if (bit) = 0, then $pc \leftarrow (pc) + rel$ | | | 3 | BBS A.bit,rel | x2 | 2 | 4/6 | Branch if bit set: | | | 4 | BBS dp.bit,rel | х3 | 3 | 5/7 | if (bit) = 1, then $pc \leftarrow (pc) + rel$ | | | 5 | BCC rel | 50 | 2 | 2/4 | Branch if carry bit clear if (C) = 0, then $pc \leftarrow (pc) + rel$ | | | 6 | BCS rel | D0 | 2 | 2/4 | Branch if carry bit set if (C) = 1, then $pc \leftarrow (pc) + rel$ | | | 7 | BEQ rel | F0 | 2 | 2/4 | Branch if equal if $(Z) = 1$ , then $pc \leftarrow (pc) + rel$ | | | 8 | BMI rel | 90 | 2 | 2/4 | Branch if minus if (N) = 1, then $pc \leftarrow (pc) + rel$ | | | 9 | BNE rel | 70 | 2 | 2/4 | Branch if not equal if $(Z) = 0$ , then $pc \leftarrow (pc) + rel$ | | | 10 | BPL rel | 10 | 2 | 2/4 | Branch if minus if (N) = 0, then $pc \leftarrow (pc) + rel$ | | | 11 | BRA rel | 2F | 2 | 4 | Branch always<br>pc ← ( pc ) + rel | | | 12 | BVC rel | 30 | 2 | 2/4 | Branch if overflow bit clear if $(V) = 0$ , then $pc \leftarrow (pc) + rel$ | | | 13 | BVS rel | В0 | 2 | 2/4 | Branch if overflow bit set if $(V) = 1$ , then $pc \leftarrow (pc) + rel$ | | | 14 | CALL !abs | 3B | 3 | 8 | Subroutine call | | | 15 | CALL [dp] | 5F | 2 | 8 | $ \begin{array}{c} M(\;sp) \leftarrow (\;pc_H\;),\; sp \leftarrow sp \;\text{-}\; 1,\; M(sp) \leftarrow (\;pc_L),\; sp \;\leftarrow sp \;\text{-}\; 1,\\ \text{if !abs},\;\; pc \leftarrow \;abs\;;\;\; \text{if [dp]},\;\; pc_L \leftarrow (\;dp\;),\;\; pc_H \leftarrow (\;dp+1\;)\;. \end{array} $ | | | 16 | CBNE dp,rel | FD | 3 | 5/7 | Compare and branch if not equal : | | | 17 | CBNE dp+X,rel | 8D | 3 | 6/8 | if $(A) \neq (M)$ , then $pc \leftarrow (pc) + rel$ . | | | 18 | DBNE dp,rel | AC | 3 | 5/7 | Decrement and branch if not equal : | | | 19 | DBNE Y,rel | 7B | 2 | 4/6 | if $(M) \neq 0$ , then $pc \leftarrow (pc) + rel$ . | | | 20 | JMP !abs | 1B | 3 | 3 | Unconditional jump | | | 21 | JMP [!abs] | 1F | 3 | 5 | pc ← jump address | | | 22 | JMP [dp] | 3F | 2 | 4 | | | | 23 | PCALL upage | 4F | 2 | 6 | $\label{eq:U-page} \begin{split} & \text{U-page call} \\ & \text{M(sp)} \leftarrow \!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!$ | | | 24 | TCALL n | nA | 1 | 8 | Table call : (sp) $\leftarrow$ ( pc <sub>H</sub> ), sp $\leftarrow$ sp - 1,<br>M(sp) $\leftarrow$ ( pc <sub>L</sub> ),sp $\leftarrow$ sp - 1,<br>pc <sub>L</sub> $\leftarrow$ (Table vector L), pc <sub>H</sub> $\leftarrow$ (Table vector H) | | MAR. 2005 vii ## **Control Operation & Etc.** | No. | Mnemonic | Op<br>Code | Byte<br>No | Cycle<br>No | Operation | Flag<br>NVGBHIZC | |-----|----------|------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------| | 1 | BRK | 0F | 1 | 8 | $\label{eq:software interrupt: B large} \begin{split} & \text{Software interrupt: B} \leftarrow \text{"1", M(sp)} \leftarrow \text{(pc_H)}, \ \text{sp} \leftarrow \text{sp-1}, \\ & \text{M(s)} \leftarrow \text{(pc_L)}, \text{sp} \leftarrow \text{sp} - 1, \text{M(sp)} \leftarrow \text{(PSW)}, \text{sp} \leftarrow \text{sp} - 1, \\ & \text{pc_L} \leftarrow \text{(0FFDE_H)}, \ \text{pc_H} \leftarrow \text{(0FFDF_H)}. \end{split}$ | 1-0 | | 2 | DI | 60 | 1 | 3 | Disable all interrupts : I ← "0" | 0 | | 3 | EI | E0 | 1 | 3 | Enable all interrupt : I ← "1" | 1 | | 4 | NOP | FF | 1 | 2 | No operation | | | 5 | POP A | 0D | 1 | 4 | $sp \leftarrow sp + 1, A \leftarrow M(sp)$ | | | 6 | POP X | 2D | 1 | 4 | $sp \leftarrow sp + 1, X \leftarrow M(sp)$ | | | 7 | POP Y | 4D | 1 | 4 | $sp \leftarrow sp + 1, Y \leftarrow M(sp)$ | | | 8 | POP PSW | 6D | 1 | 4 | $sp \leftarrow sp + 1$ , $PSW \leftarrow M(sp)$ | restored | | 9 | PUSH A | 0E | 1 | 4 | $M(sp) \leftarrow A, sp \leftarrow sp - 1$ | | | 10 | PUSH X | 2E | 1 | 4 | M( sp ) ← X , sp ← sp - 1 | | | 11 | PUSH Y | 4E | 1 | 4 | M( sp ) ← Y , sp ← sp - 1 | | | 12 | PUSH PSW | 6E | 1 | 4 | M( sp ) ← PSW , sp ← sp - 1 | | | 13 | RET | 6F | 1 | 5 | Return from subroutine $sp \leftarrow sp +1, pc_L \leftarrow M(sp), sp \leftarrow sp +1, pc_H \leftarrow M(sp)$ | | | 14 | RETI | 7F | 1 | 6 | Return from interrupt $sp \leftarrow sp +1$ , $PSW \leftarrow M(sp)$ , $sp \leftarrow sp +1$ , $pc_L \leftarrow M(sp)$ , $sp \leftarrow sp +1$ , $pc_H \leftarrow M(sp)$ | restored | | 15 | STOP | EF | 1 | 3 | Stop mode ( halt CPU, stop oscillator ) | | viii MAR. 2005 #### **Mask Order & Verification Sheet** MC80C02 Customer should write inside thick line box. 1. Customer Information 2. Device Information Company Name Package 44MQFP 42SDIP File Name OTP. Application ROM Size (bytes) 8K 16K 24K YYYY ММ DD Order Date Mask Data Check Sum Tel: Fax: Set "00H" in blanked area \* PFD Option (24K) A000 H E-mail address: (16K) C000 H ☐ 3.0V (8K) E000 H .OTP file Name & □ 2.7V □ 2.4V Signature: ■ Not use (Please check mark $\sqrt{into} \square$ ) 3. Marking Specification 08 or 16 or 24 0 MagnaChip\* Customer's logo Customer logo is not required. MC80C02XX-MC MC80C02XX-MC YYWW KOREA YYWW KOREA If the customer logo must be used in the special mark, please submit a clean original of the logo. Customer's part number 4. Delivery Schedule Date Quantity MagnaChip Confirmation MM DD Customer sample pcs YYYY MM DD Risk order pcs 5. ROM Code Verification Please confirm out verification data. MM MM חח Approval date: Verification date: Check sum: I agree with your verification data and confirm you to make mask set. Tel: Fax: Tel: Fax: E-mail address: E-mail address: Name & Name & Signature: Signature: MagnaChip•