# MITSUBISHI 8-BIT SINGLE-CHIP MICROCOMPUTER 740 FAMILY / 740 SERIES 7534 Group User's Manual ## -Keep safety first in your circuit designs!- • Mitsubishi Electric Corporation puts the maximum effort into making semiconductor products better and more reliable, but there is always the possibility that trouble may occur with them. Trouble with semiconductors may lead to personal injury, fire or property damage. Remember to give due consideration to safety when making your circuit designs, with appropriate measures such as (i) placement of substitutive, auxiliary circuits, (ii) use of non-flammable material or (iii) prevention against any malfunction or mishap. ## Notes regarding these materials - These materials are intended as a reference to assist our customers in the selection of the Mitsubishi semiconductor product best suited to the customer's application; they do not convey any license under any intellectual property rights, or any other rights, belonging to Mitsubishi Electric Corporation or a third party. - Mitsubishi Electric Corporation assumes no responsibility for any damage, or infringement of any third-party's rights, originating in the use of any product data, diagrams, charts, programs, algorithms, or circuit application examples contained in these materials. - All information contained in these materials, including product data, diagrams, charts, programs and algorithms represents information on products at the time of publication of these materials, and are subject to change by Mitsubishi Electric Corporation without notice due to product improvements or other reasons. It is therefore recommended that customers contact Mitsubishi Electric Corporation or an authorized Mitsubishi Semiconductor product distributor for the latest product information before purchasing a product listed herein. - The information described here may contain technical inaccuracies or typographical errors. Mitsubishi Electric Corporation assumes no responsibility for any damage, liability, or other loss rising from these inaccuracies or errors. - Please also pay attention to information published by Mitsubishi Electric Corporation by various means, including the Mitsubishi Semiconductor home page (http://www.mitsubishichips.com). - When using any or all of the information contained in these materials, including product data, diagrams, charts, programs, and algorithms, please be sure to evaluate all information as a total system before making a final decision on the applicability of the information and products. Mitsubishi Electric Corporation assumes no responsibility for any damage, liability or other loss resulting from the information contained herein. - Mitsubishi Electric Corporation semiconductors are not designed or manufactured for use in a device or system that is used under circumstances in which human life is potentially at stake. Please contact Mitsubishi Electric Corporation or an authorized Mitsubishi Semiconductor product distributor when considering the use of a product contained herein for any specific purposes, such as apparatus or systems for transportation, vehicular, medical, aerospace, nuclear, or undersea repeater use. - The prior written approval of Mitsubishi Electric Corporation is necessary to reprint or reproduce in whole or in part these materials. - If these products or technologies are subject to the Japanese export control restrictions, they must be exported under a license from the Japanese government and cannot be imported into a country other than the approved destination. - Any diversion or reexport contrary to the export control laws and regulations of Japan and/ or the country of destination is prohibited. - Please contact Mitsubishi Electric Corporation or an authorized Mitsubishi Semiconductor product distributor for further details on these materials or the products contained therein. # REVISION HISTORY 75 # 7534 GROUP USER'S MANUAL | Rev. Date Description | | | Description | |-----------------------|----------|------|---------------| | | | Page | Summary | | 1.0 | 11/24/00 | | First Edition | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | # **Preface** This user's manual describes Mitsubishi's CMOS 8-bit microcomputers 7534 Group. After reading this manual, the user should have a through knowledge of the functions and features of the 7534 Group, and should be able to fully utilize the product. The manual starts with specifications and ends with application examples. For details of software, refer to the "740 FAMILY SOFTWARE MANUAL." For details of development support tools, refer to the "Mitsubishi Microcomputer Development Support Tools" Hompage (http://www.tool-spt.mesc.co.jp/index\_e.htm). # **BEFORE USING THIS MANUAL** This user's manual consists of the following three chapters. Refer to the chapter appropriate to your conditions, such as hardware design or software development. Chapter 3 also includes necessary information for systems development. You must refer to that chapter. ## 1. Organization #### CHAPTER 1 HARDWARE This chapter describes features of the microcomputer and operation of each peripheral function. #### CHAPTER 2 APPLICATION This chapter describes usage and application examples of peripheral functions, based mainly on setting examples of relevant registers. ## CHAPTER 3 APPENDIX This chapter includes necessary information for systems development using the microcomputer, such as the electrical characteristics, the list of registers. As for the Mask ROM confirmation form, the ROM programming confirmation form, and the Mark specification form which are to be submitted when ordering, refer to the "Mitsubishi MCU Technical Information" Hompage (http://www.infomicom.mesc.co.jp/indexe.htm). ## 2. Structure of register The figure of each register structure describes its functions, contents at reset, and attributes as follows: # **Table of contents** | CHAPIER 1 HARDWARE | | |----------------------------------------------------|-----------| | DESCRIPTION | 1-2 | | FEATURES | | | APPLICATION | 1-2 | | PIN CONFIGURATION | 1-2 | | FUNCTIONAL BLOCK | | | PIN DESCRIPTION | | | GROUP EXPANSION | | | FUNCTIONAL DESCRIPTION | 1-10 | | Central Processing Unit (CPU) | 1-10 | | Memory | 1-14 | | I/O Ports | 1-16 | | Interrupts | 1-20 | | Timers | 1-23 | | Serial I/O | 1-25 | | A-D Converter | 1-36 | | Reset Circuit | | | Clock Generating Circuit | | | NOTES ON PROGRAMMING | | | NOTES ON USE | | | DATA REQUIRED FOR MASK ORDERS | | | FUNCTIONAL DESCRIPTION SUPPLEMENT | | | Interrupt | | | Timing After Interrupt | | | A-D Converter | | | Stop mode | | | Wait mode | | | DESCRIPTION OF IMPROVED USB FUNCTION FOR 7534 GROU | | | DIFFERENCES AMONG 32-PIN, 36-PIN AND 42-PIN | | | DESCRIPTION SUPPLEMENT FOR USE OF USB FUNCTION ST | ABLY 1-52 | | | | | CHAPTER 2 APPLICATION | | | | | | 2.1 I/O port | | | 2.1.1 Memory map | | | 2.1.2 Relevant registers | | | 2.1.3 Application example of key-on wake up | | | 2.1.4 Handling of unused pins | | | 2.1.5 Notes on input and output pins | | | 2.1.6 Termination of unused pins | | | 2.2 Timer | | | 2.2.1 Memory map | | | 2.2.2 Relevant registers | | | 2.2.3 Timer application examples | | | 2.3 Serial I/O | | | 2.3.1 Memory map | | | 2.3.2 Relevant registers | | | 2.3.3 Serial I/O connection examples | 2-35 | ## Table of contents | 2.3.4 Serial I/O transfer data format | | |----------------------------------------------------------------------------|------| | 2.3.5 Serial I/O application examples | 2-38 | | 2.3.6 Notes on serial I/O | 2-49 | | 2.4 USB | 2-50 | | 2.4.1 Outline of USB | 2-50 | | 2.4.2 Memory map | 2-56 | | 2.4.3 Relevant registers | 2-57 | | 2.4.4 USB application example | | | 2.4.5 Notes concerning USB | | | 2.5 A-D converter | | | 2.5.1 Memory map | 2-70 | | 2.5.2 Relevant registers | 2-70 | | 2.5.3 A-D converter application examples | | | 2.5.4 Notes on A-D converter | | | 2.6 Reset | 2-77 | | 2.6.1 Connection example of reset IC | 2-77 | | 2.6.2 Notes on RESET pin | | | · | | | | | | CHAPTER 3 APPENDIX | | | 3.1 Electrical characteristics | 2.0 | | | | | 3.1.1 Absolute Maximum Ratings | | | 3.1.2 Recommended Operating Conditions | | | 3.1.3 Electrical Characteristics | | | 3.1.4 A-D Converter Characteristics | | | 3.1.5 Timing Requirements | | | 3.1.6 Switching Characteristics | | | 3.2 Typical characteristics | | | 3.2.1 Power source current characteristic example (Icc-Vcc characteristic) | | | 3.2.2 VoH-loh characteristic example | | | 3.2.3 A-D conversion typical characteristics example | | | 3.3 Notes on use | | | 3.3.1 Notes on interrupts | | | 3.3.2 Notes on serial I/O | | | 3.3.3 Notes on A-D converter | | | 3.3.4 Notes on RESET pin | | | 3.3.5 Notes on input and output pins | | | 3.3.6 Notes on programming | | | 3.3.7 Programming and test of built-in PROM version | | | 3.3.8 Notes on built-in PROM version | | | 3.3.9 Termination of unused pins | | | 3.3.10 Notes on CPU mode register | | | 3.3.11 Notes on using 32-pin version | | | 3.4 Countermeasures against noise | | | 3.4.1 Shortest wiring length | | | 3.4.2 Connection of bypass capacitor across Vss line and Vcc line | | | 3.4.3 Wiring to analog input pins | | | 3.4.4 Oscillator concerns | | | 3.4.5 Setup for I/O ports | | | 3.4.6 Providing of watchdog timer function by software | 3-33 | | | | | 3.5 List of registers | | |------------------------------|------| | 3.6 Package outline | 3-53 | | 3.7 List of instruction code | 3-55 | | 3.8 Machine instructions | 3-56 | | 3.9 SFR memory map | 3-67 | | 3.10 Pin configurations | 3-68 | # List of figures | $\sim$ 11 | A D- | | 4 | | <b>D D</b> | | | |-----------|------|-----|---|----|------------|------|-----| | СH | AΡ | ΓER | 1 | HA | Kυ | VV A | ЯKЕ | | Fig. 1 Pin configuration of M37534M4-XXXFP, M37534E8FP | | |-------------------------------------------------------------------------------------|--------| | Fig. 2 Pin configuration of M37534M4-XXXGP, M37534E4GP | 1-3 | | Fig. 3 Pin configuration of M37534RSS, M37534M4-XXXSP, M37534E8SP | 1-4 | | Fig. 4 Functional block diagram (36P2R-A package type) | 1-5 | | Fig. 5 Functional block diagram (32P6U-A package type) | 1-6 | | Fig. 6 Functional block diagram (42P4B package type) | 1-7 | | Fig. 7 Memory expansion plan | 1-9 | | Fig. 8 740 Family CPU register structure | . 1-10 | | Fig. 9 Register push and pop at interrupt generation and subroutine call | . 1-11 | | Fig. 10 Structure of CPU mode register | . 1-13 | | Fig. 11 Switching method of CPU mode register | | | Fig. 12 Memory map diagram | . 1-14 | | Fig. 13 Memory map of special function register (SFR) | | | Fig. 14 Structure of pull-up control register | | | Fig. 15 Structure of port P1P3 control register | | | Fig. 16 Block diagram of ports (1) | | | Fig. 17 Block diagram of ports (2) | | | Fig. 18 Interrupt control | | | Fig. 19 Structure of Interrupt-related registers | | | Fig. 20 Connection example when using key input interrupt and port P0 block diagram | | | Fig. 21 Structure of timer X mode register | | | Fig. 22 Timer count source set register | | | Fig. 23 Block diagram of timer X, timer 1 and timer 2 | | | Fig. 24 Block diagram of UART serial I/O1 | | | Fig. 25 Operation of UART serial I/O1 function | | | Fig. 26 Continuous transmission operation of UART serial I/O | | | Fig. 27 USB mode block diagram | | | Fig. 28 USB transceiver block diagram | | | Fig. 29 Structure of serial I/O1-related registers (1) | | | Fig. 30 Structure of serial I/O1-related registers (2) | | | Fig. 31 Structure of serial I/O1-related registers (3) | | | Fig. 32 Structure of serial I/O1 related registers (4) | | | Fig. 33 Structure of serial I/O1-related registers (5) | | | Fig. 35 Block diagram of serial I/O2 | | | Fig. 36 Serial I/O2 timing (LSB first) | | | Fig. 37 Structure of A-D control register | | | Fig. 38 Structure of A-D conversion register | | | Fig. 39 Block diagram of A-D converter | | | Fig. 40 Block diagram of watchdog timer | | | Fig. 41 Structure of watchdog timer control register | | | Fig. 42 Example of reset circuit | | | Fig. 43 Timing diagram at reset | | | Fig. 44 Internal status of microcomputer at reset | | | Fig. 45 External circuit of ceramic resonator | | | Fig. 46 External clock input circuit | | | Fig. 47 Structure of MISRG | | | U | | | Fig. 48 Block diagram of system clock generating circuit (for ceramic resonator) | | |-----------------------------------------------------------------------------------------------|--------| | Fig. 49 Programming and testing of One Time PROM version | | | Fig. 50 Timing chart after an interrupt occurs | | | Fig. 51 Time up to execution of the interrupt processing routine | | | Fig. 52 A-D conversion equivalent circuit | | | Fig. 53 A-D conversion timing chart | | | Fig. 54 Handling of Vcc, USBV <sub>REFOUT</sub> pins of M37534M4-XXXFP, M37534E8FP | | | Fig. 55 Handling of Vcc, USBV <sub>REFOUT</sub> pins of M37534M4-XXXGP, M37534E4GP | | | Fig. 56 Handling of Vcc, USBV <sub>REFOUT</sub> pins of M37534E8SP, M37534M4-XXXSP, M37534RSS | 5 1-54 | | | | | CHAPTER 2 APPLICATION | | | Fig. 2.1.1 Memory map of registers relevant to I/O port | | | Fig. 2.1.2 Structure of Port Pi (i = 0 to 4) | | | Fig. 2.1.3 Structure of Port Pi direction register (i = 0 to 4) | | | Fig. 2.1.4 Structure of Pull-up control register | | | Fig. 2.1.5 Structure of P1P3 control register | | | Fig. 2.1.6 Structure of Interrupt edge selection register | | | Fig. 2.1.7 Structure of Interrupt request register 1 | | | Fig. 2.1.8 Structure of Interrupt control register 1 | | | Fig. 2.1.9 Relevant registers setting | | | Fig. 2.1.10 Application circuit example | | | Fig. 2.1.11 Control procedure | | | Fig. 2.2.1 Memory map of registers relevant to timers | | | Fig. 2.2.2 Structure of Prescaler 12, Prescaler X | | | Fig. 2.2.3 Structure of Timer 1 | | | Fig. 2.2.4 Structure of Timer 2 Fig. 2.2.5 Structure of Timer X | | | Fig. 2.2.6 Structure of Timer X mode register | | | Fig. 2.2.7 Structure of Timer A mode register | | | Fig. 2.2.8 Structure of Interrupt edge selection register | | | Fig. 2.2.9 Structure of Interrupt request register 1 | | | Fig. 2.2.10 Structure of Interrupt control register 1 | | | Fig. 2.2.11 Timers connection and setting of division ratios | | | Fig. 2.2.12 Relevant registers setting | | | Fig. 2.2.13 Control procedure | | | Fig. 2.2.14 Peripheral circuit example | | | Fig. 2.2.15 Timers connection and setting of division ratios | | | Fig. 2.2.16 Relevant registers setting | | | Fig. 2.2.17 Control procedure | | | Fig. 2.2.18 Judgment method of valid/invalid of input pulses | | | Fig. 2.2.19 Relevant registers setting | 2-24 | | Fig. 2.2.20 Control procedure | 2-25 | | Fig. 2.2.21 Timers connection and setting of division ratios | 2-26 | | Fig. 2.2.22 Relevant registers setting | 2-27 | | Fig. 2.2.23 Control procedure | 2-28 | | Fig. 2.3.1 Memory map of registers relevant to serial I/O | 2-29 | | Fig. 2.3.2 Structure of Transmit/Receive buffer register | | | Fig. 2.3.3 Structure of UART status register | | | Fig. 2.3.4 Structure of Serial I/O1 control register | | | Fig. 2.3.5 Structure of UART control register | | # List of figures | _ | 2.3.6 Structure of Baud rate generator | | |------|----------------------------------------------------------------------------------|--------| | Fig. | 2.3.7 Structure of Serial I/O2 control register | . 2-32 | | Fig. | 2.3.8 Structure of Serial I/O2 register | . 2-32 | | Fig. | 2.3.9 Structure of Interrupt edge selection register | . 2-33 | | Fig. | 2.3.10 Structure of Interrupt request register 1 | . 2-33 | | | 2.3.11 Structure of Interrupt control register 1 | | | Fig. | 2.3.12 Serial I/O connection examples (1) | . 2-35 | | _ | 2.3.13 Serial I/O connection examples (2) | | | _ | 2.3.14 Serial I/O transfer data format | | | _ | 2.3.15 Connection diagram | | | _ | 2.3.16 Timing chart | | | | 2.3.17 Registers setting relevant to transmission side | | | | 2.3.18 Transmission data setting of serial I/O2 | | | | 2.3.19 Registers setting relevant to reception side | | | _ | 2.3.20 Control procedure of transmission side | | | _ | 2.3.21 Control procedure of reception side | | | | 2.3.22 Connection diagram | | | | 2.3.23 Timing chart | | | _ | 2.3.24 Registers setting relevant to transmission side | | | _ | | | | | 2.3.25 Registers setting relevant to reception side | | | _ | 2.3.26 Control procedure of transmission side | | | _ | 2.3.27 Control procedure of reception side | | | | 2.3.28 Sequence of clearing serial I/O | | | | 2.4.1 Communication sequence of USB | | | _ | 2.4.2 Data structure of USB packet | | | _ | 2.4.3 USB (L.S.) interface | | | | 2.4.4 USB (L.S.) connection example | | | | 2.4.5 Memory map of registers relevant to USB | | | _ | 2.4.6 Description of the register structure | | | Fig. | 2.4.7 Register structures relevant to USB (1) | . 2-58 | | _ | 2.4.8 Register structures relevant to USB (2) | | | Fig. | 2.4.9 Register structures relevant to USB (3) | . 2-60 | | Fig. | 2.4.10 Register structures relevant to USB (4) | . 2-61 | | | 2.4.11 Control method of control sequence | | | Fig. | 2.4.12 Timing chart of the transaction according to each token | . 2-63 | | Fig. | 2.4.13 USB interrupt processing example (OUT token) | . 2-65 | | Fig. | 2.4.14 USB interrupt processing example (IN token) | . 2-66 | | _ | 2.4.15 Data read timing of SETUP token | | | _ | 2.4.16 Data read timing of OUT token | | | _ | 2.4.17 Data read timing of IN token (endpoint 0) and IN token (endpoint 1) token | | | | 2.4.18 Timing chart of each signal | | | _ | 2.4.19 Example for determination of resume interrupt | | | | 2.4.20 Processing for width of SE0 signal | | | | 2.5.1 Memory map of registers relevant to A-D converter | | | | 2.5.2 Structure of A-D control register | | | | 2.5.3 Structure of A-D conversion register (high-order) | | | | 2.5.4 Structure of A-D conversion register (low-order) | | | _ | e v | | | _ | 2.5.5 Structure of Interrupt edge selection register | | | _ | 2.5.6 Structure of Interrupt request register 1 | | | _ | 2.5.7 Structure of Interrupt control register 1 | | | _ | 2.5.8 Connection diagram | | | ΓIĢ. | 2.5.9 Relevant registers setting | . 2-74 | | Fig. 2.6.1 Example of poweron reset circuit | 2-77 | |----------------------------------------------------------------------------------------------------------|--------| | CHAPTER 3 APPENDIX | | | Fig. 3.1.1 Power source current measurement circuit in USB mode at oscillation stop | | | Fig. 3.1.2 Output switching characteristics measurement circuit | | | Fig. 3.1.3 Timing chart | | | Fig. 3.2.1 Icc-Vcc characteristic example (in double-speed mode) | | | Fig. 3.2.2 Icc-Vcc characteristic example (at WIT instruction execution) | | | Fig. 3.2.3 Icc-Vcc characteristic example (At STP instruction execution, Ta = 25 °C) | | | Fig. 3.2.4 Icc-Vcc characteristic example (At STP instruction execution, Ta = 85 °C) | | | Fig. 3.2.5 lcc-Vcc characteristic example (at USB suspend, Ta = 25 °C) | | | Fig. 3.2.6 Icc-Vcc characteristic example (A-D conversion executed/not executed, f(X <sub>IN</sub> ) = 6 | | | in double-speed mode) | | | Fig. 3.2.7 VoH-loh characteristic example of P-channel (Ta = 25 °C): normal port | | | Fig. 3.2.8 VoH-loh characteristic example of P-channel (Ta = 85 °C): normal port | | | Fig. 3.2.9 Vol-lot characteristic example of N-channel (Ta = 25 °C): Normal port | | | Fig. 3.2.10 Volloc characteristic example of N-channel (Ta = 85 °C): Normal port | | | Fig. 3.2.11 Volloc characteristic example of N-channel (Ta = 25 °C): LED drive port | | | Fig. 3.2.12 Vollol characteristic example N-channel (Ta = 85 °C): LED drive port | | | Fig. 3.2.13 "L" input current of port at pull-up transistor connected | | | Fig. 3.2.15 A-D conversion typical characteristic example | | | Fig. 3.3.1 Sequence of switch the detection edge | | | Fig. 3.3.2 Sequence of check of interrupt request bit | | | Fig. 3.3.3 Structure of interrupt control register 1 | | | Fig. 3.3.4 Sequence of clearing serial I/O | | | Fig. 3.3.5 Initialization of processor status register | | | Fig. 3.3.6 Sequence of PLP instruction execution | | | Fig. 3.3.7 Stack memory contents after PHP instruction execution | | | Fig. 3.3.8 Status flag at decimal calculations | | | Fig. 3.3.9 Programming and testing of One Time PROM version | | | Fig. 3.3.10 Switching method of CPU mode register | | | Fig. 3.4.1 Selection of packages | | | Fig. 3.4.2 Wiring for the RESET pin | . 3-27 | | Fig. 3.4.3 Wiring for clock I/O pins | 3-28 | | Fig. 3.4.4 Wiring for CNVss pin | . 3-28 | | Fig. 3.4.5 Wiring for the VPP pin of the One Time PROM | . 3-29 | | Fig. 3.4.6 Bypass capacitor across the Vss line and the Vcc line | . 3-29 | | Fig. 3.4.7 Analog signal line and a resistor and a capacitor | . 3-30 | | Fig. 3.4.8 Wiring for a large current signal line | | | Fig. 3.4.9 Wiring of signal lines where potential levels change frequently | . 3-31 | | Fig. 3.4.10 Vss pattern on the underside of an oscillator | . 3-31 | | Fig. 3.4.11 Setup for I/O ports | | | Fig. 3.4.12 Watchdog timer by software | | | Fig. 3.5.1 Structure of Port Pi (i = 0 to 4) | | | Fig. 3.5.2 Structure of Port Pi direction register (i = 0 to 4) | | | Fig. 3.5.3 Structure of Pull-up control register | | | Fig. 3.5.4 Structure of Port P1P3 control register | | | Fig. 3.5.5 Structure of Transmit/Receive buffer register | 3-36 | # List of figures | Fig. | 3.5.6 Structure of UART status register | 3-36 | |------|--------------------------------------------------------------------|------| | Fig. | 3.5.7 Structure of USB status register | 3-37 | | Fig. | 3.5.8 Structure of Serial I/O1 control register | 3-38 | | Fig. | 3.5.9 Structure of UART control register | 3-38 | | Fig. | 3.5.10 Structure of Baud rate generator | 3-39 | | Fig. | 3.5.11 Structure of USB data toggle synchronization register | 3-39 | | Fig. | 3.5.12 Structure of USB interrupt source discrimination register 1 | 3-39 | | Fig. | 3.5.13 Structure of USB interrupt source discrimination register 2 | 3-40 | | Fig. | 3.5.14 Structure of USB interrupt control register | 3-40 | | Fig. | 3.5.15 Structure of USB transmit data byte number set register 0 | 3-41 | | Fig. | 3.5.16 Structure of USB transmit data byte number set register 1 | 3-41 | | Fig. | 3.5.17 Structure of USB PID control register 0 | 3-41 | | Fig. | 3.5.18 Structure of USB PID control register 1 | 3-42 | | Fig. | 3.5.19 Structure of USB address register | 3-42 | | Fig. | 3.5.20 Structure of USB sequence bit initialization register | 3-42 | | Fig. | 3.5.21 Structure of USB control register | 3-42 | | Fig. | 3.5.22 Structure of Prescaler 12, Prescaler X | 3-43 | | Fig. | 3.5.23 Structure of Timer 1 | 3-43 | | Fig. | 3.5.24 Structure of Timer 2 | 3-44 | | Fig. | 3.5.25 Structure of Timer X mode register | 3-45 | | Fig. | 3.5.26 Structure of Timer X | 3-46 | | Fig. | 3.5.27 Structure of Timer count source set register | 3-46 | | Fig. | 3.5.28 Structure of Serial I/O2 control register | 3-47 | | Fig. | 3.5.29 Structure of Serial I/O2 register | 3-47 | | Fig. | 3.5.30 Structure of A-D control register | 3-48 | | Fig. | 3.5.31 Structure of A-D conversion register (high-order) | 3-49 | | | 3.5.32 Structure of A-D conversion register (low-order) | | | Fig. | 3.5.33 Structure of MISRG | 3-50 | | Fig. | 3.5.34 Structure of Watchdog timer control register | 3-50 | | Fig. | 3.5.35 Structure of Interrupt edge selection register | 3-51 | | Fig. | 3.5.36 Structure of CPU mode register | 3-51 | | Fig. | 3.5.37 Structure of Interrupt request register 1 | 3-52 | | _ | 3.5.38 Structure of Interrupt control register 1 | | | _ | 3.10.1 M37534M4-XXXFP, M37534E8FP pin configuration | | | Fig. | 3.10.2 M37534M4-XXXGP, M37534E4GP pin configuration | 3-69 | | _ | 3 10 3 M37534M4-XXXSP M37534F8SP M37534RSS pin configuration | | # List of tables | CHAPTER 1 HARDWARE | | |-----------------------------------------------------------------------------------|------| | Table 1 Pin description | 1-8 | | Table 2 List of supported products | | | Table 3 Push and pop instructions of accumulator or processor status register | | | Table 4 Set and clear instructions of each bit of processor status register | 1-12 | | Table 5 I/O port function table | 1-17 | | Table 6 Interrupt vector address and priority | 1-20 | | Table 7 Relation of the width of SE0 and the state of the device | 1-33 | | Table 8 Special programming adapter | | | Table 9 Interrupt sources, vector addresses and interrupt priority | | | Table 10 Change of A-D conversion register during A-D conversion | | | Table 11 Stop mode state | | | Table 12 Wait mode state | | | Table 13 Description of improved USB function for 7534 Group | | | Table 14 Differences among 32-pin, 36-pin and 42-pin | | | Table 15 Differences among 32-pin, 36-pin and 42-pin (SFR) | 1-51 | | CHAPTER 2 APPLICATION | | | Table 2.1.1 Handling of unused pins | 2.7 | | Table 2.2.1 CNTR0 active edge switch bit function | | | Table 2.3.1 Setting example of baud rate generator (BRG) and transfer bit rate va | | | Table 2.4.1 Transfer types of USB | | | Table 2.4.2 Packet types of USB | | | Table 2.4.3 Data structure of USB packet | | | Table 2.4.4 PID | | | Table 2.4.5 Special signal of USB | | | CHAPTER 3 APPENDIX | | | | | | Table 3.1.1 Absolute maximum ratings | | | Table 3.1.2 Recommended operating conditions | | | Table 3.1.3 Electrical characteristics (1) | | | Table 3.1.4 Electrical characteristics (2) | | | Table 3.1.5 A-D Converter characteristics (1) | | | Table 3.1.6 Timing requirements | | | Table 3.1.7 Switching characteristics Table 3.3.1 Programming adapters | | | Table 3.3.1 Programming adapters | | | Table 3.5.1 CNTR <sub>0</sub> active edge switch bit function | | | Table 5.5.1 Civity active edge switch bit function | 3-43 | # CHAPTER 1 # **HARDWARE** **DESCRIPTION FEATURES APPLICATION** PIN CONFIGURATION **FUNCTIONAL BLOCK** PIN DESCRIPTION **GROUP EXPANSION FUNCTIONAL DESCRIPTION** NOTES ON PROGRAMMING NOTES ON USE DATA REQUIRED FOR MASK ORDERS ROM PROGRAMMING METHOD FUNCTIONAL DESCRIPTION SUPPLEMENT DESCRIPTION OF IMPROVED USB FUNCTION FOR 7534 GROUP DIFFERENCES AMONG 32-PIN, 36-PIN AND 42-PIN DESCRIPTION SUPPLEMENT FOR USE OF USB FUNCTION STABLY ## DESCRIPTION/FEATURES/APPLICATION/PIN CONFIGURATION #### **DESCRIPTION** The 7534 Group is the 8-bit microcomputer based on the 740 family core technology. The 7534 Group has a USB, 8-bit timers, and an A-D converter, and is useful for an input device for personal computer peripherals. ## **FEATURES** | Basic machine-language instructions | 69 | |------------------------------------------|------------------------------| | • The minimum instruction execution time | 0.34 µs | | (at 6 MHz oscillation frequency for | or the shortest instruction) | | Memory size | | | ROM | 8K to 16K bytes | | RAM | 256 to 384 bytes | | Programmable I/O ports | 28 (36-pin type) | | | 24 (32-pin type) | | | 33 (42-pin type) | | Serial I/O1 used only for Low Speed in USB | |----------------------------------------------------------------------------------------------------------------------------------| | (based on USBSpec. Rev.1.1) | | (USB/UART) | | • Serial I/O2 8-bit X 1 | | (Clock-synchronized) | | A-D converter 10-bit X 8 channels | | Clock generating circuit Built-in type | | (connect to external ceramic resonator or quartz-crystal oscillator) | | | | Watchdog timer 16-bit X 1 | | <ul><li>Watchdog timer</li></ul> | | 3 | | Power source voltage | | Power source voltage At 6 MHz XIN oscillation frequency at ceramic resonator | | Power source voltage At 6 MHz XIN oscillation frequency at ceramic resonator 4.1 to 5.5 V(4.4 to 5.25 V at USB operation) | | Power source voltage At 6 MHz XIN oscillation frequency at ceramic resonator | ## **APPLICATION** Rev.1.1 Input device for personal computer peripherals Fig. 1 Pin configuration of M37534M4-XXXFP, M37534E8FP Fig. 2 Pin configuration of M37534M4-XXXGP, M37534E4GP Fig. 3 Pin configuration of M37534RSS, M37534M4-XXXSP, M37534E8SP ## **FUNCTIONAL BLOCK** Fig. 4 Functional block diagram (36P2R-A package type) Fig. 5 Functional block diagram (32P6U-A package type) Fig. 6 Functional block diagram (42P4B package type) # PIN DESCRIPTION ## **PIN DESCRIPTION** Table 1 Pin description | Pin | Name | Function | Function expect a port function | | | | | |----------------------|------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------|--|--|--|--| | Vcc, Vss | Power source | •Apply voltage of 4.1 to 5.5 V to Vcc, and 0 V to Vss. | | | | | | | VREF | Analog reference voltage | •Reference voltage input pin for A-D converter | | | | | | | USBVREFOUT | USB reference voltage output | •Output pin for pulling up a D- line with 1.5 k $\Omega$ external resistor | | | | | | | CNVss | CNVss | •Chip operating mode control pin, which is always connected to Vs | S. | | | | | | RESET | Reset input | •Reset input pin for active "L" | | | | | | | XIN | Clock input | •Input and output pins for main clock generating circuit | | | | | | | Xout | Clock output | Connect a ceramic resonator or quartz crystal oscillator between the connect and ceramic resonator or quartz crystal oscillator between the connect and ceramic resonator or quartz crystal oscillator between the connect and ceramic resonator or quartz crystal oscillator between the connect and ceramic resonator or quartz crystal oscillator between the | he XIN and XOUT pins. | | | | | | X001 | Clock output | •If an external clock is used, connect the clock source to the XIN pir | n and leave the Xout pin open. | | | | | | P00-P07 | I/O port P0 | •8-bit I/O port. | •Key-input (key-on wake up | | | | | | | | •I/O direction register allows each pin to be individually programmed as either input or output. | interrupt input) pins | | | | | | | | •CMOS 3-state output structure at CMOS compatible input level | | | | | | | | | Whether a built-in pull-up resistor is to be used or not can be determined by program. | | | | | | | P10/RxD/D- | I/O port P1 | •7-bit I/O port | •Serial I/O1 function pin | | | | | | P11/TxD/D+ | | •I/O direction register allows each pin to be individually programmed | | | | | | | P12/SCLK | | as either input or output. | •Serial I/O2 function pin | | | | | | P13/SDATA | | CMOS 3-state output structure at CMOS compatible input level | | | | | | | P14/CNTR0 | | •CMOS/TTL level can be switched for P10, P12, P13. | •Timer X function pin | | | | | | | | •When using the USB function, input level of ports P1o and P11 becomes USB input level, and output level of them becomes | | | | | | | P15, P16 | | USB output level. | | | | | | | P20/AN0- | I/O port P2 | •8-bit I/O port having almost the same function as P0 | •Input pins for A-D converter | | | | | | P27/AN7 | | •CMOS 3-state output structure at CMOS compatible input level | | | | | | | P30-P35 | I/O port P3 | •8-bit I/O port | 1 | | | | | | | | •I/O direction register allows each pin to be individually programme | d as either input or output. | | | | | | | | •CMOS 3-state output structure at CMOS compatible input level (C for P36, P37). | MOS/TTL level can be switched | | | | | | | | •P30 to P36 can output a large current for driving LED. | | | | | | | P36/INT1<br>P37/INT0 | | •Whether a built-in pull-up resistor is to be used or not can be determined by program. | •Interrupt input pins | | | | | | P40, P41 | I/O port P4 | •2-bit I/O port | | | | | | | | | •I/O direction register allows each pin to be individually programme | d as either input or output. | | | | | #### **GROUP EXPANSION** Mitsubishi plans to expand the 7534 group as follow: #### Memory type Support for Mask ROM version, One Time PROM version, and Emulator MCU . ## Memory size | ROM/PROM size | 8 K to 16 K bytes | |---------------|-------------------| | RAM size | 256 to 384 bytes | | Package | | |---------|----------------------------------| | 36P2R-A | 0.8 mm-pitch plastic molded SOP | | 32P6U-A | 0.8 mm-pitch plastic molded LQFP | | 42P4B | 42 pin plastic molded SDIP | | 42SIM | 42 pin shrink ceramic PIGGY BACK | Fig. 7 Memory expansion plan Currently supported products are listed below. Table 2 List of supported products | Product | (P) ROM size (bytes)<br>ROM size for User () | RAM size<br>(bytes) | Package | Remarks | |----------------|----------------------------------------------|---------------------|---------|-------------------------------| | M37534M4-XXXFP | 8192 (8062) | 256 | 36P2R-A | Mask ROM version | | M37534M4-XXXGP | 8192 (8062) | 256 | 32P6U-A | Mask ROM version | | M37534M4-XXXSP | 8192 (8062) | 256 | 42P4B | Mask ROM version | | M37534E4GP | 8192 (8062) | 256 | 32P6U-A | One Time PROM version (blank) | | M37534E8FP | 16384 (16254) | 384 | 36P2R-A | One Time PROM version (blank) | | M37534E8SP | 16384 (16254) | 384 | 42P4B | One Time PROM version (blank) | | M37534RSS | | 384 | 42S1M | Emulator MCU | ## **FUNCTIONAL DESCRIPTION** ## FUNCTIONAL DESCRIPTION Central Processing Unit (CPU) The 7534 group uses the standard 740 family instruction set. Refer to the table of 740 family addressing modes and machine instructions or the 740 Family Software Manual for details on the instruction set. Machine-resident 740 family instructions are as follows: The FST and SLW instructions cannot be used. The MUL and DIV instructions cannot be used. The WIT and STP instructions can be used. The central processing unit (CPU) has the six registers. ## Accumulator (A) The accumulator is an 8-bit register. Data operations such as data transfer, etc., are executed mainly through the accumulator. ## Index register X (X), Index register Y (Y) Both index register X and index register Y are 8-bit registers. In the index addressing modes, the value of the OPERAND is added to the contents of register X or register Y and specifies the real address. When the T flag in the processor status register is set to "1", the value contained in index register X becomes the address for the second OPERAND. ## Stack pointer (S) The stack pointer is an 8-bit register used during sub-routine calls and interrupts. The stack is used to store the current address data and processor status when branching to subroutines or interrupt routines. The lower eight bits of the stack address are determined by the contents of the stack pointer. The upper eight bits of the stack address are determined by the Stack Page Selection Bit. If the Stack Page Selection Bit is "0", then the RAM in the zero page is used as the stack area. If the Stack Page Selection Bit is "1", then RAM in page 1 is used as the stack area. The Stack Page Selection Bit is located in the SFR area in the zero page. Note that the initial value of the Stack Page Selection Bit varies with each microcomputer type. Also some microcomputer types have no Stack Page Selection Bit and the upper eight bits of the stack address are fixed. The operations of pushing register contents onto the stack and popping them from the stack are shown in Figure 9. ## Program counter (PC) The program counter is a 16-bit counter consisting of two 8-bit registers PCH and PCL. It is used to indicate the address of the next instruction to be executed. Fig. 8 740 Family CPU register structure Fig. 9 Register push and pop at interrupt generation and subroutine call Table 3 Push and pop instructions of accumulator or processor status register | | Push instruction to stack | Pop instruction from stack | | |---------------------------|---------------------------|----------------------------|--| | Accumulator | PHA | PLA | | | Processor status register | PHP | PLP | | ## **FUNCTIONAL DESCRIPTION** #### Processor status register (PS) The processor status register is an 8-bit register consisting of flags which indicate the status of the processor after an arithmetic operation. Branch operations can be performed by testing the Carry (C) flag, Zero (Z) flag, Overflow (V) flag, or the Negative (N) flag. In decimal mode, the Z, V, N flags are not valid. After reset, the Interrupt disable (I) flag is set to "1", but all other flags are undefined. Since the Index X mode (T) and Decimal mode (D) flags directly affect arithmetic operations, they should be initialized in the beginning of a program. #### (1) Carry flag (C) The C flag contains a carry or borrow generated by the arithmetic logic unit (ALU) immediately after an arithmetic operation. It can also be changed by a shift or rotate instruction. #### (2) Zero flag (Z) The Z flag is set if the result of an immediate arithmetic operation or a data transfer is "0", and cleared if the result is anything other than "0". #### (3) Interrupt disable flag (I) The I flag disables all interrupts except for the interrupt generated by the BRK instruction. Interrupts are disabled when the I flag is "1". When an interrupt occurs, this flag is automatically set to "1" to prevent other interrupts from interfering until the current interrupt is serviced. #### (4) Decimal mode flag (D) The D flag determines whether additions and subtractions are executed in binary or decimal. Binary arithmetic is executed when this flag is "0"; decimal arithmetic is executed when it is "1". Decimal correction is automatic in decimal mode. Only the ADC and SBC instructions can be used for decimal arithmetic. #### (5) Break flag (B) The B flag is used to indicate that the current interrupt was generated by the BRK instruction. The BRK flag in the processor status register is always "0". When the BRK instruction is used to generate an interrupt, the processor status register is pushed onto the stack with the break flag set to "1". The saved processor status is the only place where the break flag is ever set. #### (6) Index X mode flag (T) When the T flag is "0", arithmetic operations are performed between accumulator and memory, e.g. the results of an operation between two memory locations is stored in the accumulator. When the T flag is "1", direct arithmetic operations and direct data transfers are enabled between memory locations, i.e. between memory and memory, memory and I/O, and I/O and I/O. In this case, the result of an arithmetic operation performed on data in memory location 1 and memory location 2 is stored in memory location 1. The address of memory location 1 is specified by index register X, and the address of memory location 2 is specified by normal addressing modes. #### (7) Overflow flag (V) The V flag is used during the addition or subtraction of one byte of signed data. It is set if the result exceeds +127 to -128. When the BIT instruction is executed, bit 6 of the memory location operated on by the BIT instruction is stored in the overflow flag. #### (8) Negative flag (N) The N flag is set if the result of an arithmetic operation or data transfer is negative. When the BIT instruction is executed, bit 7 of the memory location operated on by the BIT instruction is stored in the negative flag. Table 4 Set and clear instructions of each bit of processor status register | | C flag | Z flag | I flag | D flag | B flag | T flag | V flag | N flag | |-------------------|--------|--------|--------|--------|--------|--------|--------|--------| | Set instruction | SEC | - | SEI | SED | _ | SET | - | _ | | Clear instruction | CLC | _ | CLI | CLD | _ | CLT | CLV | _ | #### [CPU Mode Register] CPUM The CPU mode register contains the stack page selection bit. This register is allocated at address 003B<sub>16</sub>. Fig. 10 Structure of CPU mode register ## Switching method of CPU mode register Switch the CPU mode register (CPUM) at the head of program after releasing Reset in the following method. Fig. 11 Switching method of CPU mode register ## **FUNCTIONAL DESCRIPTION** ## Memory #### Special function register (SFR) area The SFR area in the zero page contains control registers such as I/O ports and timers. #### RAM RAM is used for data storage and for a stack area of subroutine calls and interrupts. #### ROM The first 128 bytes and the last 2 bytes of ROM are reserved for device testing and the rest is a user area for storing programs. #### Interrupt vector area The interrupt vector area contains reset and interrupt vectors. #### Zero page The 256 bytes from addresses 000016 to 00FF16 are called the zero page area. The internal RAM and the special function registers (SFR) are allocated to this area. The zero page addressing mode can be used to specify memory and register addresses in the zero page area. Access to this area with only 2 bytes is possible in the zero page addressing mode. ## Special page The 256 bytes from addresses FF0016 to FFFF16 are called the special page area. The special page addressing mode can be used to specify memory addresses in the special page area. Access to this area with only 2 bytes is possible in the special page addressing mode. Fig. 12 Memory map diagram | 000016 | Port P0 (P0) | 002016 | USB interrupt control register (USBICON) | |--------------------|-------------------------------------------------------------|--------------------|--------------------------------------------------------| | 000116 | Port P0 direction register (P0D) | 002016 | USB transmit data byte number set register 0 (EP0BYTE) | | 000216 | Port P1 (P1) | 002116 | USB transmit data byte number set register 1 (EP1BYTE) | | 000316 | Port P1 direction register (P1D) | 002316 | USBPID control register 0 (EP0PID) | | 000416 | Port P2 (P2) | 002416 | USBPID control register 1 (EP1PID) | | 000516 | Port P2 direction register (P2D) | 002516 | USB address register (USBA) | | 000616 | Port P3 (P3) | 002616 | USB sequence bit initialization register (INISQ1) | | 000716 | Port P3 direction register (P3D) | 002716 | USB control register (USBCON) | | 000816 | Port P4 (P4) | 002816 | Prescaler 12 (PRE12) | | 000916 | Port P4 direction register (P4D) | 002916 | Timer 1 (T1) | | 000A16 | | 002A16 | Timer 2 (T2) | | 000B16 | | 002B <sub>16</sub> | Timer X mode register (TM) | | 000C16 | | 002C16 | Prescaler X (PREX) | | 000D16 | | 002D16 | Timer X (TX) | | 000E16 | | 002E16 | Timer count source set register (TCSS) | | 000F16 | | 002F16 | | | 001016 | | 003016 | Serial I/O2 control register (SIO2CON) | | 001116 | | 003116 | Serial I/O2 register (SIO2) | | 001216 | | 003216 | | | 001316 | | 003316 | | | 001416 | | 003416 | A-D control register (ADCON) | | 001516 | | 003516 | A-D conversion register (low-order) (ADL) | | 001616 | Pull-up control register (PULL) | 003616 | A-D conversion register (high-order) (ADH) | | 001716 | Port P1P3 control register (P1P3C) | 003716 | | | 001816 | Transmit/Receive buffer register (TB/RB) | 003816 | MISRG | | 001916 | USB status register (USBSTS)/UART status register (UARTSTS) | 003916 | Watchdog timer control register (WDTCON) | | 001A16 | Serial I/O1 control register (SIO1CON) | 003A16 | Interrupt edge selection register (INTEDGE) | | 001B <sub>16</sub> | UART control register (UARTCON) | 003B <sub>16</sub> | CPU mode register (CPUM) | | 001C <sub>16</sub> | Baud rate generator (BRG) | 003C16 | Interrupt request register 1 (IREQ1) | | 001D16 | USB data toggle synchronization register ( TRSYNC) | 003D16 | | | 001E <sub>16</sub> | USB interrupt source discrimination register 1 (USBIR1) | 003E16 | Interrupt control register 1 (ICON1) | | 001F <sub>16</sub> | USB interrupt source discrimination register 2 (USBIR2) | 003F16 | | Fig. 13 Memory map of special function register (SFR) ## **FUNCTIONAL DESCRIPTION** #### I/O Ports #### [Direction registers] PiD The I/O ports have direction registers which determine the input/output direction of each pin. Each bit in a direction register corresponds to individual pin, and each pin can be set to be input or output. When "1" is set to the bit corresponding to a pin, this pin becomes an output port. When "0" is set to the bit, the pin becomes an input port. When data is read from a pin set to output, not the value of the pin itself but the value of port latch is read. Pins set to input are floating, and permit reading pin values. If a pin set to input is written to, only the port latch is written to and the pin remains floating. #### [Pull-up control] PULL By setting the pull-up control register (address 001616), ports P0 and P3 can exert pull-up control by program. However, pins set to output are disconnected from this control and cannot exert pull-up control. #### [Port P1P3 control] P1P3C By setting the port P1P3 control register (address 0017<sub>16</sub>), a CMOS input level or a TTL input level can be selected for ports P1<sub>0</sub>, P1<sub>2</sub>, P1<sub>3</sub>, P3<sub>6</sub> and P3<sub>7</sub> by program. Then, as for the 36-pin version, set "1" to each bit 6 of the port P3 direction register and port P3 register. As for the 32-pin version, set "1" to respective bits 5, 6, 7 of the port P3 direction register and port P3 register. Fig. 14 Structure of pull-up control register Fig. 15 Structure of port P1P3 control register # **FUNCTIONAL DESCRIPTION** Table 5 I/O port function table | Pin | Name | Input/output | I/O format | Non-port function | Related SFRs | Diagram No. | |---------------------|---------|----------------|------------------------------|-------------------------------|--------------------------|-------------| | P00-P07 | Port P0 | I/O individual | •CMOS compatible input level | Key input interrupt | Pull-up control register | (1) | | | | bits | •CMOS 3-state output | | | | | P1o/RxD/D- | Port P1 | 1 | •USB input/output level when | Serial I/O1 function | Serial I/O1 control | (2) | | P11/TxD/D+ | | | selecting USB function | input/output | register | (3) | | P12/Sclk | | | •CMOS compatible input level | Serial I/O2 function | Serial I/O2 control | (4) | | P13/SDATA | | | •CMOS 3-state output | input/output | register | (5) | | P14/CNTR0 | | | (Note) | Timer X function input/output | Timer X mode register | (6) | | P15, P16 | | | | | | (10) | | P20/AN0-<br>P27/AN7 | Port P2 | | | A-D conversion input | A-D control register | (7) | | P30-P35 | Port P3 | 1 | | | | (8) | | P36/INT1 | | | | External interrupt input | Interrupt edge selection | (9) | | P37/INTo | | | | | register | | | P40, P41 | Port P4 | | | | | (10) | Note: Port P10, P12, P13, P36, P37 is CMOS/TTL input level. Fig. 16 Block diagram of ports (1) Fig. 17 Block diagram of ports (2) ## **FUNCTIONAL DESCRIPTION** #### Interrupts Interrupts occur by 14 different sources : 4 external sources, 9 internal sources and 1 software source. #### Interrupt control All interrupts except the BRK instruction interrupt have an interrupt request bit and an interrupt enable bit, and they are controlled by the interrupt disable flag. When the interrupt enable bit and the interrupt request bit are set to "1" and the interrupt disable flag is set to "0", an interrupt is accepted. The interrupt request bit can be cleared by program but not be set. The interrupt enable bit can be set and cleared by program. It becomes usable by switching CNTRo and A-D interrupt sources with bit 7 of the interrupt edge selection register, timer 2 and serial I/O2 interrupt sources with bit 6, timer X and key-on wake-up interrupt sources with bit 5, and serial I/O transmit and INT1 interrupt sources with bit 4. The reset and BRK instruction interrupt can never be disabled with any flag or bit. All interrupts except these are disabled when the interrupt disable flag is set. When several interrupts occur at the same time, the interrupts are received according to priority. #### Interrupt operation Upon acceptance of an interrupt the following operations are automatically performed: - 1. The processing being executed is stopped. - 2. The contents of the program counter and processor status register are automatically pushed onto the stack. - The interrupt disable flag is set and the corresponding interrupt request bit is cleared. - Concurrently with the push operation, the interrupt destination address is read from the vector table into the program counter. #### Notes on use When the active edge of an external interrupt (INT0, INT1, CNTR0) is set, the interrupt request bit may be set. Therefore, please take following sequence: - 1. Disable the external interrupt which is selected. - 2. Change the active edge in interrupt edge selection register. (in case of CNTRo: Timer X mode register) - 3. Clear the set interrupt request bit to "0". - 4. Enable the external interrupt which is selected. ### Table 6 Interrupt vector address and priority | | | Vector addresses (Note 1) | | | | | |---------------------------------------------|----------|---------------------------|--------------------|------------------------------------------------------------------------------|---------------------------------------------|--| | Interrupt source | Priority | High-order | Low-order | Interrupt request generating conditions | Remarks | | | Reset (Note 2) | 1 | FFFD16 | FFFC16 | At reset input | Non-maskable | | | UART receive | 2 | FFFB16 | FFFA <sub>16</sub> | At completion of UART data receive | Valid in UART mode | | | USB IN token | | | | At detection of IN token | Valid in USB mode | | | UART transmit | 3 | FFF916 | FFF816 | At completion of UART transmit shift or when transmit buffer is empty | Valid in UART mode | | | USB SETUP/OUT token<br>Reset/Suspend/Resume | | | | At detection of SETUP/OUT token or<br>At detection of Reset/ Suspend/ Resume | Valid in USB mode | | | INT <sub>1</sub> — — — — | | | | At detection of either rising or falling edge of INT1 input | External interrupt (active edge selectable) | | | INT <sub>0</sub> | 4 | FFF7 <sub>16</sub> | FFF616 | At detection of either rising or falling edge of INTo input | External interrupt (active edge selectable) | | | Timer X | 5 | FFF516 | FFF416 | At timer X underflow | | | | Key-on wake-up | | | | At falling of conjunction of input logical level for port P0 (at input) | External interrupt (valid at falling) | | | Timer 1 | 6 | FFF316 | FFF216 | At timer 1 underflow | STP release timer underflow | | | Timer 2 | 7 | FFF116 | FFF016 | At timer 2 underflow | | | | Serial I/O2 | | | | At completion of transmit/receive shift | | | | CNTR <sub>0</sub> | 8 | FFEF16 | FFEE16 | At detection of either rising or falling edge of CNTR <sub>0</sub> input | External interrupt (active edge selectable) | | | A-D conversion | | | | At completion of A-D conversion | T | | | BRK instruction | 9 | FFED <sub>16</sub> | FFEC <sub>16</sub> | At BRK instruction execution | Non-maskable software interrupt | | Note 1: Vector addressed contain internal jump destination addresses. 2: Reset function in the same way as an interrupt with the highest priority. Fig. 18 Interrupt control Fig. 19 Structure of Interrupt-related registers ## **FUNCTIONAL DESCRIPTION** ## **Key Input Interrupt (Key-On Wake-Up)** A key-on wake-up interrupt request is generated by applying "L" level to any pin of port P0 that has been set to input mode. In other words, it is generated when the AND of input level goes from "1" to "0". An example of using a key input interrupt is shown in Figure 20, where an interrupt request is generated by pressing one of the keys provided as an active-low key matrix which uses ports P00 to P03 as input ports. Fig. 20 Connection example when using key input interrupt and port P0 block diagram #### **Timers** The 7534 Group has 3 timers: timer X, timer 1 and timer 2. The division ratio of every timer and prescaler is 1/(n+1) provided that the value of the timer latch or prescaler is n. All the timers are down count timers. When a timer reaches "0", an underflow occurs at the next count pulse, and the corresponding timer latch is reloaded into the timer. When a timer underflows, the interrupt request bit corresponding to each timer is set to "1". #### ●Timer 1, Timer 2 Prescaler 12 always counts f(XIN)/16. Timer 1 and timer 2 always count the prescaler output and periodically sets the interrupt request bit. #### ●Timer X Timer X can be selected in one of 4 operating modes by setting the timer X mode register. #### • Timer Mode The timer counts the signal selected by the timer X count source selection bit. #### • Pulse Output Mode The timer counts the signal selected by the timer X count source selection bit, and outputs a signal whose polarity is inverted each time the timer value reaches "0", from the CNTR<sub>0</sub> pin. When the CNTRo active edge switch bit is "0", the output of the CNTRo pin is started with an "H" output. At "1", this output is started with an "L" output. When using a timer in this mode, set the port P14 direction register to output mode. #### Event Counter Mode The operation in the event counter mode is the same as that in the timer mode except that the timer counts the input signal from the CNTR<sub>0</sub> pin. When the CNTRo active edge switch bit is "0", the timer counts the rising edge of the CNTRo pin. When this bit is "1", the timer counts the falling edge of the CNTRo pin. #### • Pulse Width Measurement Mode When the CNTR $_0$ active edge switch bit is "0", the timer counts the signal selected by the timer X count source selection bit while the CNTR $_0$ pin is "H". When this bit is "1", the timer counts the signal while the CNTR $_0$ pin is "L". In any mode, the timer count can be stopped by setting the timer X count stop bit to "1". Each time the timer overflows, the interrupt request bit is set. Fig. 21 Structure of timer X mode register Fig. 22 Timer count source set register Fig. 23 Block diagram of timer X, timer 1 and timer 2 #### Serial I/O #### Serial I/O1 #### • Asynchronous serial I/O (UART) mode Serial I/O1 can be used as an asynchronous (UART) serial I/O. A dedicated timer (baud rate generator) is also provided for baud rate generation when serial I/O1 is in operation. Eight serial data transfer formats can be selected, and the transfer formats to be used by a transmitter and a receiver must be identi- Each of the transmit and receive shift registers has a buffer register (the same address on memory). Since the shift register cannot be written to or read from directly, transmit data is written to the transmit buffer, and receive data is read from the respective buffer registers. These buffer registers can also hold the next data to be transmitted and receive 2-byte receive data in succession. By selecting "1" for continuous transmit valid bit (bit 2 of SIO1CON), continuous transmission of the same data is made possible. This can be used as a simplified PWM. Serial I/O1 control register Address (001A16) Receive Buffer Register ➤ Receive buffer full flag (RBF) Character length selection bit Receive interrupt request (RI) P10/RXD O ST Detector 7-bit Receive Shift Register 1/16 UART Control Register PE FE Address (001B16) Clock Control Circuit BRG count source selection bit Division ratio 1/(n+1) Baud Rate Generator Address (001C16) ST/SP/PA Generator Transmit shift register shift completion flag (TSC) 1/16 Transmit interrupt source selection bit P11/TXD O Transmit Shift Register Transmit interrupt request (TI) Character length selection bit-Transmit buffer empty flag (TBE) Transmit Buffer Register Address Serial I/O1 status register Address (001916) Data bus Continuous transmit valid bit Fig. 24 Block diagram of UART serial I/O1 Fig. 25 Operation of UART serial I/O1 function #### **FUNCTIONAL DESCRIPTION** #### [Serial I/O1 control register] SIO1CON The serial I/O1 control register consists of eight control bits for the serial I/O1 function. #### [UART control register] UARTCON The UART control register consists of four control bits (bits 0 to 3) which are valid when asynchronous serial I/O is selected and set the data format of an data transfer. One bit in this register (bit 4) is always valid and sets the output structure of the P11/TxD pin. #### [UART status register] UARTSTS The read-only UART status register consists of seven flags (bits 0 to 6) which indicate the operating status of the UART function and various errors. This register functions as the UART status register (UARTSTS) when selecting the UART. The receive buffer full flag (bit 1) is cleared to "0" when the receive buffer is read. If there is an error, it is detected at the same time that data is transferred from the receive shift register to the receive buffer, and the receive buffer full flag is set. A write to the UART status register clears all the error flags OE, PE, FE, and SE (bit 3 to bit 6, respectively). Writing "0" to the serial I/O1 mode selection bits MOD1 and MOD0 (bit 7 and 6 of the Serial I/O1 control register) also clears all the status flags, including the error flags. All bits of the serial I/O1 status register are initialized to "8116" at reset, but if the transmit enable bit (bit 4) of the serial I/O1 control register has been set to "1", the continuous transmit valid bit (bit 2) becomes "1" #### [Transmit/Receive buffer register] TB/RB The transmit buffer and the receive buffer are located at the same address. The transmit buffer is write-only and the receive buffer is read-only. If a character bit length is 7-bit, the MSB of data stored in the receive buffer is "0". #### [Baud Rate Generator] BRG The baud rate generator determines the baud rate for serial transfer. The baud rate generator divides the frequency of the count source by 1/(n+1), where n is the value written to the baud rate generator. Fig. 26 Continuous transmission operation of UART serial I/O #### • Universal serial bus (USB) mode By setting bits 7 and 6 of the serial I/O1 control register (address 001A<sub>16</sub>) to "11", the USB mode is selected. This mode conforms to "Low Speed device" of USB Specification 1.1. In this mode serial I/O1 interrupt have 6 sources; USB in and out token receive, set-up token receive, USB reset, suspend, and resume. The USB status/ UART status register functions as the USB status register (USBSTS). There is the USBVREFOUT pin for the USB reference voltage output, and a D-line with 1.5 k $\Omega$ external resistor can be pull up. USB mode block and USB transceiver block show in figures 27 and 28. Fig. 27 USB mode block diagram Fig. 29 Structure of serial I/O1-related registers (1) Fig. 30 Structure of serial I/O1-related registers (2) Fig. 31 Structure of serial I/O1-related registers (3) Fig. 32 Structure of serial I/O1-related registers (4) Fig. 33 Structure of serial I/O1-related registers (5) #### Note on using USB mode #### Handling of SE0 signal in program (at receiving) 7534 group has the border line to detect as USB RESET or EOP (End of Packet) on the width of SE0 (Single Ended 0). A response apposite to a state of the device is expected. The name of the following short words which is used in table 5 shows as follow. •TKNE: Token interrupt enable (bit 6 of address 2016) •RSME: Resume interrupt enable (bit 5 of address 2016) •RSTE: USB reset interrupt enable (bit 4 of address 2016) •Spec: A response of the device requested by USB Specification 1.1 •SIE: Hardware operation in 7534 group •F/W: Recommendation process in the program •FEOPE: False EOP error flag (bit 2 of address 1916) •RxPID: Token interrupt flag (bit 7 of address 1F16) Table 7 Relation of the width of SE0 and the state of the device | | | State of device | | | | | | |-------------------|-------------|-------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------|------|---------------------------------------------|--| | Width of SE0 | | Idle state<br>TKNE = X<br>RSME = 0<br>RSTE =1 | End of Token in transaction TKNE = 1 RSME = 0 RSTE =1 | End of data or handshake<br>in transaction<br>TKNE = 0<br>RSME = 0<br>RSTE = 0 or 1 | | Suspend state TKNE = 0 RSME = 1 RSTE = 0 | | | 0 μs<br>0.5 μs | Spec | Ignore Keep counting suspend timer | Ignore Not detected as EOP(in case of no detection EOP, SIE returns idle state as time out. FEOPE flag is set.) | Ignore Not detected as EOP(in case of no detection EOP, SIE returns idle state as timeup. FEOPE flag is set.) | Spec | Reset or resume | | | | F/W<br>Spec | Not acknowledge<br>Keep alive | Not acknowledge EOP | Wait for the next EOP flag EOP | | | | | 0.5 μs | SIE | Initialize suspend timer count value | Token interrupt request | Set EOP flag | | | | | 2.5 µs | F/W | Not acknowledge | Token interrupt processing execute | After checking the set of EOP flag, go to the next processing | SIE | Reset interrupt | | | | Spec | Keep alive or Reset | EOP or Reset | EOP or Reset | | request | | | | SIE | may determine as keep alive and Reset interrupt | may determine as EOP and Reset interrupt | may determine as EOP and Reset interrupt | | | | | 2.5 µs<br>2.67 µs | F/W | Keep alive in case of no interrupt request Reset processing in case of interrupt request | RxPID = 1> Token interrupt<br>processing<br>RxPID = 0> Reset interrupt<br>processing | Continue the processing in case of no interrupt request Reset processing in case of interrupt request | F/W | Reset interrupt processing | | | 2.67 µs | Spec | Reset | Reset | Reset | | Resume interrupt processing | | | | SIE | Reset interrupt request | Reset interrupt request | Reset interrupt request | | _ | | | | F/W | Reset processing | Reset processing | Reset processing | | | | <sup>•</sup> Function of USBPID control register 0 (address 002316) Bit 4 (STALL handshake control for OUT token) of this register is forcibly set by SIE under the special condition shown below. Set condition; when PID of data packet = DATA0 (incorrect PID) in the status stage of the control read transfer. Normally, the SYNC field consists of "KJKJKJKK" (8 bits). However, as for SIE of the 7534 Group, when the low-order 6 bits are "KJKJKK", it is determined as SYNC. <sup>•</sup> SYNC field at reception #### **FUNCTIONAL DESCRIPTION** #### ●Serial I/O2 The serial I/O2 function can be used only for clock synchronous serial I/O For clock synchronous serial I/O2 the transmitter and the receiver must use the same clock. When the internal clock is used, transfer is started by a write signal to the serial I/O2 register. #### [Serial I/O2 control register] SIO2CON The serial I/O2 control register contains 8 bits which control various serial I/O functions. - For receiving, set "0" to bit 3. - When receiving, bit 7 is cleared by writing dummy data to serial I/ O2 register after shift is completed. - Bit 7 is set earlier a half cycle of shift clock than completion of shift operation. Accordingly, when checking shift completion by using this bit, the setting is as follows: - (1) check that this bit is set to "1", - (2) wait a half cycle of shift clock, - (3) read/write to serial I/O2 register. Fig. 34 Structure of serial I/O2 control registers Fig. 35 Block diagram of serial I/O2 #### Serial I/O2 operation By writing to the serial I/O2 register(address 003116) the serial I/O2 counter is set to "7". After writing, the SDATA pin outputs data every time the transfer clock shifts from a high to a low level. And, as the transfer clock shifts from a low to a high, the SDATA pin reads data, and at the same time the contents of the serial I/O2 register are shifted by 1 bit. When the internal clock is selected as the transfer clock source, the following operations execute as the transfer clock counts up to 8. - Serial I/O2 counter is cleared to "0". - Transfer clock stops at an "H" level. - Interrupt request bit is set. - Shift completion flag is set. Also, the SDATA pin is in a high impedance state after the data transfer is complete. Refer to Figure 36. When the external clock is selected as the transfer clock source, the interrupt request bit is set as the transfer clock counts up to 8, but external control of the clock is required since it does not stop. Notice that the SDATA pin is not in a high impedance state on the completion of data transfer. Fig. 36 Serial I/O2 timing (LSB first) #### **FUNCTIONAL DESCRIPTION** #### **A-D Converter** The functional blocks of the A-D converter are described below. #### [A-D conversion register] AD The A-D conversion register is a read-only register that stores the result of A-D conversion. Do not read out this register during an A-D conversion. #### [A-D control register] ADCON The A-D control register controls the A-D converter. Bit 2 to 0 are analog input pin selection bits. Bit 4 is the AD conversion completion bit. The value of this bit remains at "0" during A-D conversion, and changes to "1" at completion of A-D conversion. A-D conversion is started by setting this bit to "0" except during an A-D conversion. #### [Comparison voltage generator] The comparison voltage generator divides the voltage between Vss and VREF by 1024 by a resistor ladder, and outputs the divided voltages. Since the generator is disconnected from VREF pin and Vss pin, current is not flowing into the resistor ladder. #### [Channel Selector] The channel selector selects one of ports P27/AN7 to P20/AN0, and inputs the voltage to the comparator. #### [Comparator and control circuit] The comparator and control circuit compares an analog input voltage with the comparison voltage and stores its result into the A-D conversion register. When A-D conversion is completed, the control circuit sets the AD conversion completion bit and the AD interrupt request bit to "1". Because the comparator is constructed linked to a capacitor, set f(XIN) to 500 kHz or more during A-D conversion. Fig. 37 Structure of A-D control register Fig. 38 Structure of A-D conversion register Fig. 39 Block diagram of A-D converter #### **Watchdog Timer** The watchdog timer gives a means for returning to a reset status when the program fails to run on its normal loop due to a runaway. The watchdog timer consists of an 8-bit watchdog timer H and an 8-bit watchdog timer L, being a 16-bit counter. #### Standard operation of watchdog timer The watchdog timer stops when the watchdog timer control register (address 003916) is not set after reset. Writing an optional value to the watchdog timer control register (address 003916) causes the watchdog timer to start to count down. When the watchdog timer H underflows, an internal reset occurs. Accordingly, it is programmed that the watchdog timer control register (address 003916) can be set before an underflow occurs. When the watchdog timer control register (address 003916) is read, the values of the high-order 6-bit of the watchdog timer H, STP instruction disable bit and watchdog timer H count source selection bit are read. #### Initial value of watchdog timer By a reset or writing to the watchdog timer control register (address 003916), the watchdog timer H is set to "FF16" and the watchdog timer L is set to "FF16". #### Operation of watchdog timer H count source selection bit A watchdog timer H count source can be selected by bit 7 of the watchdog timer control register (address 003916). When this bit is "0", the count source becomes a watchdog timer L underflow signal. The detection time is 174.763 ms at f(XIN)=6 MHz. When this bit is "1", the count source becomes $f(X_{IN})/16$ . In this case, the detection time is 683 $\mu s$ at $f(X_{IN})=6$ MHz. This bit is cleared to "0" after reset. #### Operation of STP instruction disable bit When the watchdog timer is in operation, the STP instruction can be disabled by bit 6 of the watchdog timer control register (address 003916). When this bit is "0", the STP instruction is enabled. When this bit is "1", the STP instruction is disabled, and an internal reset occurs if the STP instruction is executed. Once this bit is set to "1", it cannot be changed to "0" by program. This bit is cleared to "0" after reset. Fig. 40 Block diagram of watchdog timer Fig. 41 Structure of watchdog timer control register #### **FUNCTIONAL DESCRIPTION** #### **Reset Circuit** The microcomputer is put into a reset status by holding the $\overline{\text{RESET}}$ pin at the "L" level for 15 $\mu s$ or more when the power source voltage is 4.1 to 5.5 V and XIN is in stable oscillation. After that, this reset status is released by returning the RESET pin to the "H" level. The program starts from the address having the contents of address FFFD16 as high-order address and the contents of address FFFC16 as low-order address. Note that the reset input voltage should be 0.82 V or less when the power source voltage passes 4.1 V. Fig. 42 Example of reset circuit Fig. 43 Timing diagram at reset | (1) Port P0 direction register | Address Register contents 000116 0016 | |-----------------------------------------------------|---------------------------------------| | | 000316 X 0 0 0 0 0 0 0 | | (2) Port P3 direction register | 000516 0016 | | (3) Port P2 direction register | 000716 0016 | | (4) Port P3 direction register | | | (5) Port P4 direction register | 000916 X X X X X X X 0 0 | | (6) Pull-up control register | 001616 FF16 | | (7) USB/UART status register | 001916 1 0 0 0 0 0 0 1 | | (8) Serial I/O1 control register | 001A16 0216 | | (9) UART control register | 001B <sub>16</sub> 1 1 1 0 0 0 0 0 | | (10) USB data toggle synchronization register | 001D16 0 1 1 1 1 1 1 1 1 | | (11) USB interrupt source discrimination register 1 | 001E16 0 1 1 1 1 1 1 1 1 | | (12) USB interrupt source discrimination register 2 | 001F16 0 1 1 1 0 0 1 1 | | (13) USB interrupt control register | 002016 0 0 0 0 0 1 1 1 | | (14) USB transmit data byte number set register 0 | 002116 0016 | | (15) USB transmit data byte number set register 1 | 002216 0016 | | (16) USBPID control register 0 | 002316 0 0 0 0 0 1 1 1 | | (17) USBPID control register 1 | 002416 0 0 1 1 1 1 1 1 1 | | (18) USB address register | 002516 1 0 0 0 0 0 0 0 | | (19) USB sequence bit initialization register | 002616 1 1 1 1 1 1 1 1 1 | | (20) USB control register | 002716 0 0 1 1 1 1 1 1 | | (21) Prescaler 12 | 002816 FF <sub>16</sub> | | (22) Timer 1 | 002916 0116 | | (23) Timer 2 | 002A16 0016 | | (24) Timer X mode register | 002B16 0016 | | (25) Prescaler X | 002C16 FF <sub>16</sub> | | (26) Timer X | 002D16 FF <sub>16</sub> | | (27) Timer count source set register | 002E16 0016 | | (28) Serial I/O2 control register | 003016 0016 | | (29) A-D control register | 003416 1016 | | (30) MISRG | 003816 0016 | | (31) Watchdog timer control register | 003916 0 0 1 1 1 1 1 1 | | (32) Interrupt edge selection register | 003A16 0016 | | | 003B16 1 0 0 0 0 0 0 0 | | (34) Interrupt request register 1 | | | (34) Interrupt request register 1 | | | (35) Interrupt control register 1 | 003E16 0016 | | (36) Processor status register | (PS) X X X X X X 1 X X | | (37) Program counter | (PCH) Contents of address FFFD16 | | | (PCL) Contents of address FFFC16 | Fig. 44 Internal status of microcomputer at reset #### **FUNCTIONAL DESCRIPTION** #### **Clock Generating Circuit** An oscillation circuit can be formed by connecting a resonator between $\ensuremath{\mathsf{XIN}}$ and $\ensuremath{\mathsf{XOUT}}$ . Use the circuit constants in accordance with the resonator manufacturer's recommended values. No external resistor is needed between XIN and XOUT since a feed-back resistor exists on-chip. #### Oscillation control #### Stop mode When the STP instruction is executed, the internal clock $\phi$ stops at an "H" level and the XIN oscillator stops. At this time, timer 1 is set to "0116" and prescaler 12 is set to "FF16" when the oscillation stabilization time set bit after release of the STP instruction is "0". On the other hand, timer 1 and prescaler 12 are not set when the above bit is "1". Accordingly, set the wait time fit for the oscillation stabilization time of the oscillator to be used. f(XIN)/16 is forcibly connected to the input of prescaler 12. When an external interrupt is accepted, oscillation is restarted but the internal clock $\varphi$ remains at "H" until timer 1 underflows. As soon as timer 1 underflows, the internal clock $\varphi$ is supplied. This is because when a ceramic oscillator is used, some time is required until a start of oscillation. In case oscillation is restarted by reset, no wait time is generated. So apply an "L" level to the $\overline{\text{RESET}}$ pin while oscillation becomes stable. #### Wait mode If the WIT instruction is executed, the internal clock $\phi$ stops at an "H" level, but the oscillator does not stop. The internal clock restarts if a reset occurs or when an interrupt is received. Since the oscillator does not stop, normal operation can be started immediately after the clock is restarted. To ensure that interrupts will be received to release the STP or WIT state, interrupt enable bits must be set to "1" before the STP or WIT instruction is executed. When the STP status is released, prescaler 12 and timer 1 will start counting clock which is XIN divided by 16, so set the timer 1 interrupt enable bit to "0" before the STP instruction is executed. #### Note For use with the oscillation stabilization set bit after release of the STP instruction set to "1", set values in timer 1 and prescaler 12 after fully appreciating the oscillation stabilization time of the oscillator to be used. #### Clock mode Operation is started by a built-in ring oscillator after releasing reset. A division ratio (1/1,1/2,1/8) is selected by setting bits 7 and 6 of the CPU mode register after releasing it. Fig. 45 External circuit of ceramic resonator Fig. 46 External clock input circuit Fig. 47 Structure of MISRG Fig. 48 Block diagram of system clock generating circuit (for ceramic resonator) #### NOTES ON PROGRAMMING/NOTES ON USE #### **NOTES ON PROGRAMMING** #### **Processor Status Register** The contents of the processor status register (PS) after reset are undefined except for the interrupt disable flag I which is "1". After reset, initialize flags which affect program execution. In particular, it is essential to initialize the T flag and the D flag because of their effect on calculations. #### Interrupts The contents of the interrupt request bit do not change even if the BBC or BBS instruction is executed immediately after they are changed by program because this instruction is executed for the previous contents. For executing the instruction for the changed contents, execute one instruction before executing the BBC or BBS instruction. #### **Decimal Calculations** - For calculations in decimal notation, set the decimal mode flag D to "1", then execute the ADC instruction or SBC instruction. In this case, execute SEC instruction, CLC instruction or CLD instruction after executing one instruction before the ADC instruction or SBC instruction. - In the decimal mode, the values of the N (negative), V (overflow) and Z (zero) flags are invalid. #### Timers - When n (0 to 255) is written to a timer latch, the frequency division ratio is 1/(n+1). - When a count source of timer X is switched, stop a count of timer X. #### **Ports** • The values of the port direction registers cannot be read. That is, it is impossible to use the LDA instruction, memory operation instruction when the T flag is "1", addressing mode using direction register values as qualifiers, and bit test instructions such as BBC and BBS. It is also impossible to use bit operation instructions such as CLB and SEB and read/modify/write instructions of direction registers for calculations such as ROR. For setting direction registers, use the LDM instruction, STA instruction, etc. - As for the 36-pin version, set "1" to each bit 6 of the port P3 direction register and the port P3 register. - As for the 32-pin version, set "1" to respective bits 5, 6, 7 of the port P3 direction register and port P3 register. #### A-D Converter The comparator uses internal capacitors whose charge will be lost if the clock frequency is too low. Make sure that f(XIN) is 500kHz or more during A-D conversion. Do not execute the STP instruction during A-D conversion. #### **Instruction Execution Timing** The instruction execution time can be obtained by multiplying the frequency of the internal clock $\phi$ by the number of cycles mentioned in the machine-language instruction table. The frequency of the internal clock $\phi$ is the same as that of the $X_{IN}$ in double-speed mode, twice the $X_{IN}$ cycle in high-speed mode and 8 times the $X_{IN}$ cycle in middle-speed mode. #### **NOTES ON USE** #### **Handling of Power Source Pin** In order to avoid a latch-up occurrence, connect a capacitor suitable for high frequencies as bypass capacitor between power source pin (Vcc pin) and GND pin (Vss pin). Besides, connect the capacitor to as close as possible. For bypass capacitor which should not be located too far from the pins to be connected, a ceramic or electrolytic capacitor of 1.0 $\mu F$ is recommended. #### Handling of USBVREFOUT Pin In order to prevent the instability of the USBVREFOUT output due to external noise, connect a capacitor as bypass capacitor between USBVREFOUT pin and GND pin (Vss pin). Besides, connect the capacitor to as close as possible. For bypass capacitor, a ceramic or electrolytic capacitor of 0.22 $\mu F$ is recommended. #### One Time PROM Version The CNVss pin is connected to the internal memory circuit block by a low-ohmic resistance, since it has the multiplexed function to be a programmable power source pin (VPP pin) as well. To improve the noise reduction, connect a track between CNVss pin and Vss pin with 1 to 10 $k\Omega$ resistance. The mask ROM version track of CNVss pin has no operational interference even if it is connected via a resistor #### DATA REQUIRED FOR MASK ORDERS The following are necessary when ordering a mask ROM production: - (1) Mask ROM Order Confirmation Form - (2) Mark Specification Form - (3) Data to be written to ROM, in EPROM form (three identical copies) #### **ROM PROGRAMMING METHOD** The built-in PROM of the blank One Time PROM version can be read or programmed with a general-purpose PROM programmer using a special programming adapter. Set the address of PROM programmer in the user ROM area. Table 8 Special programming adapter | Package | Name of Programming Adapter | |---------|-----------------------------| | 32P6U-A | PCA7435GP, PCA7435GP02 | | 36P2R-A | PCA7435FP, PCA7435FP02 | | 42P4B | PCA7435SP, PCA7435SP02 | The PROM of the blank One Time PROM version is not tested or screened in the assembly process and following processes. To ensure proper operation after programming, the procedure shown in Figure 49 is recommended to verify programming. Fig. 49 Programming and testing of One Time PROM version # FUNCTIONAL DESCRIPTION SUPPLEMENT # Interrupt 7534 group permits interrupts on the 14 sources for 42-pin version, 13 sources for 36-pin version and 12 sources for 32-pin version. It is vector interrupts with a fixed priority system. Accordingly, when two or more interrupt requests occur during the same sampling, the higher-priority interrupt is accepted first. This priority is determined by hardware, but variety of priority processing can be performed by software, using an interrupt enable bit and an interrupt disable flag. For interrupt sources, vector addresses and interrupt priority, refer to "Table 9." Table 9 Interrupt sources, vector addresses and interrupt priority | Interrupt source | Data att | Vector addre | sses (Note 1) | Indo- | Development | | |---------------------------------------------|----------|--------------------|--------------------|------------------------------------------------------------------------------|---------------------------------------------|--| | Interrupt source Prior | | High-order | Low-order | Interrupt request generating conditions | Remarks | | | Reset (Note 2) | 1 | FFFD16 | FFFC16 | At reset input | Non-maskable | | | UART receive | 2 | FFFB16 | FFFA <sub>16</sub> | At completion of UART data receive | Valid in UART mode | | | USB IN token | | | | At detection of IN token | Valid in USB mode | | | UART transmit | 3 | FFF916 | FFF816 | At completion of UART transmit shift or when transmit buffer is empty | Valid in UART mode | | | USB SETUP/OUT token<br>Reset/Suspend/Resume | | | | At detection of SETUP/OUT token or<br>At detection of Reset/ Suspend/ Resume | Valid in USB mode | | | INT <sub>1</sub> (Note 3) | | | | At detection of either rising or falling edge of INT1 input | External interrupt (active edge selectable) | | | INTo (Note 4) | 4 | FFF7 <sub>16</sub> | FFF616 | At detection of either rising or falling edge of INTo input | External interrupt (active edge selectable) | | | Timer X | 5 | FFF516 | FFF416 | At timer X underflow | | | | Key-on wake-up | | | | At falling of conjunction of input logical level for port P0 (at input) | External interrupt (valid at falling) | | | Timer 1 | 6 | FFF316 | FFF216 | At timer 1 underflow | STP release timer underflow | | | Timer 2 | 7 | FFF116 | FFF016 | At timer 2 underflow | | | | Serial I/O2 | | | | At completion of transmit/receive shift | | | | CNTR <sub>0</sub> | 8 | FFEF16 | FFEE16 | At detection of either rising or falling edge of CNTR <sub>0</sub> input | External interrupt (active edge selectable) | | | A-D conversion | | | | At completion of A-D conversion | T | | | BRK instruction | 9 | FFED16 | FFEC <sub>16</sub> | At BRK instruction execution | Non-maskable software interrupt | | Note 1: Vector addressed contain internal jump destination addresses. <sup>2:</sup> Reset function in the same way as an interrupt with the highest priority. <sup>3:</sup> The INT1 interrupt does not exist in the 36-pin and 32-pin version. <sup>4:</sup> The INTo interrupt does not exist in the 32-pin version. #### **Timing After Interrupt** The interrupt processing routine begins with the machine cycle following the completion of the instruction that is currently in execution. Figure 50 shows a timing chart after an interrupt occurs, and Figure 51 shows the time up to execution of the interrupt processing routine. Fig. 50 Timing chart after an interrupt occurs Fig. 51 Time up to execution of the interrupt processing routine # **FUNCTIONAL DESCRIPTION SUPPLEMENT** #### **A-D Converter** A-D conversion is started by setting AD conversion completion bit to "0." During A-D conversion, internal operations are performed as follows. - 1. After the start of A-D conversion, A-D conversion register goes to "0016." - 2. The highest-order bit of A-D conversion register is set to "1," and the comparison voltage Vref is input to the comparator. Then, Vref is compared with analog input voltage VIN. - As a result of comparison, when Vref < VIN, the highest-order bit of A-D conversion register becomes "1." When Vref > VIN, the highest-order bit becomes "0." By repeating the above operations up to the lowestorder bit of the A-D conversion register, an analog value converts into a digital value. A-D conversion completes at 122 clock cycles (20.34 $\mu s$ at f(XIN) = 6.0 MHz) after it is started, and the result of the conversion is stored into the A-D conversion register. Concurrently with the completion of A-D conversion, A-D conversion interrupt request occurs, so that the AD conversion interrupt request bit is set to "1." Relative formula for a reference voltage VREF of A-D converter and Vref When n = 0 Vref = 0 When n = 1 to 1023 Vref = $\frac{\text{VREF}}{1024}$ X n n: the value of A-D converter (decimal numeral) Table 10 Change of A-D conversion register during A-D conversion | | Change of A-D conversion register | Value of comparison voltage (Vref) | |--------------------------------------|----------------------------------------------------------------------------------------|-------------------------------------------------------------------------------| | At start of conversion | 0 0 0 0 0 0 0 0 0 0 | 0 | | First comparison | 1 0 0 0 0 0 0 0 0 0 | VREF 2 | | Second comparison | *1 1 0 0 0 0 0 0 0 0 | $\frac{\text{VREF}}{2} \pm \frac{\text{VREF}}{4}$ | | Third comparison | *1*2 1 0 0 0 0 0 0 0 | $\frac{\text{VREF}}{2} \pm \frac{\text{VREF}}{4} \pm \frac{\text{VREF}}{8}$ | | : | : | : | | After completion of tenth comparison | A result of A-D conversion * 1 * 2 * 3 * 4 * 5 * 6 * 7 * 8 * 9 * 10 | $\frac{\text{VREF}}{2} \pm \frac{\text{VREF}}{4} \pm \frac{\text{•••}}{1024}$ | \*1-\*10: A result of the first to tenth comparison Figures 52 shows A-D conversion equivalent circuit, and Figure 53 shows A-D conversion timing chart. Fig. 52 A-D conversion equivalent circuit Fig. 53 A-D conversion timing chart #### FUNCTIONAL DESCRIPTION SUPPLEMENT #### Stop mode System enters the stop mode by executing the **STP** instruction. In the stop mode, the f(XIN) oscillation is stopped, and the internal clock $\phi$ is stopped. Accordlingly, CPU and the peripheral devices are stopped. #### (1) Stop mode state Table 11 shows the state at stop mode. Table 11 Stop mode state | Table 11 Stop mode state | | | | | |-------------------------------------|--|--|--|--| | State | | | | | | Stop | | | | | | Stop | | | | | | State retained at STP instruction | | | | | | execution | | | | | | At selecting internal count source: | | | | | | Stop | | | | | | At selecting external count source: | | | | | | Operating (only Timer X) | | | | | | Stop | | | | | | Stop | | | | | | At selecting internal synchronous | | | | | | clock: Stop | | | | | | At selecting external synchronous | | | | | | clock: Operating | | | | | | Stop (suspend state) | | | | | | | | | | | | State | | |----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------| | Stop | | | State retained | | | State retained (Timer 1 ar | ٦d | | prescaler 12 excepted) | | | State retained | | | Accumulator | | | Index register X | | | Index register Y | | | Stack pointer | | | Program counter | | | Processor status register | | | | Stop State retained State retained (Timer 1 arprescaler 12 excepted) State retained Accumulator Index register X Index register Y Stack pointer Program counter | #### (2) Stop mode release Stop mode is released by reset input or interrupt occurrence. The interrupt sources which can be used for return from stop mode are shown below. - INTo - INT<sub>1</sub> - CNTR<sub>0</sub> - Timer (Timer X) when using external clock - Serial I/O2 when using external clock - Key-on wakeup - USB function (resume, reset) When the above interrupt sources are used for return from stop mode, execute the **STP** instruction after the following are set in order to enable the using interrupts. - ① Clear the timer 1 interrupt enable bit to "0" (ICON1, bit 4) - 2 Clear the timer 2 interrupt enable bit to "0" (ICON1, bit 5) - 3 Clear the timer 1 interrupt request bit to "0" (IREQ1, bit 4) - 4 Clear the timer 2 interrupt request bit to "0" (IREQ1, bit 5) - © Clear the interupt request bit of the interrupt using for return to "0" - © Set the interupt enable bit of the interrupt using for return to "1" - The contract of o #### Wait mode System enters the wait mode by executing the **WIT** instruction. In the wait mode, the oscillation is operating, but the internal clock $\phi$ is stopped. Accordingly, CPU is stopped, but the peripheral devices are operating. #### (1) Wait mode state Table 12 shows the state at wait mode. Table 12 Wait mode state | Table 12 Walt illoue State | | | | |----------------------------|-------------------------------------|--|--| | Parameter | State | | | | Oscillation | Stop | | | | CPU | Stop | | | | I/O port | State at WIT instruction execution | | | | | retained | | | | Timer | At selecting internal count source: | | | | | Operating | | | | | At selecting external count source: | | | | | Operating | | | | UART | Operating | | | | A-D conversion | Operating (Conversion is | | | | | continued if the WIT instruction | | | | | is executed during conversion) | | | | Serial I/O2 | At selecting internal synchronous | | | | | clock: Operating | | | | | At selecting external synchronous | | | | | clock: Operating | | | | USB | Operating | | | | Parameter | State | |----------------|--------------------------------------| | Watchdog timer | Operating | | RAM | State retained | | SFR | State retained (Timer 1, timer 2 and | | | prescaler 12 excepted) | | CPU register | State retained | | | Accumulator | | | <ul> <li>Index register X</li> </ul> | | | Index register Y | | | Stack pointer | | | Program counter | | | Processor status register | | | | #### (2) Wait mode release Wait mode is released by reset input or interrupt occurrence. In the wait mode, since the oscillation is continued, the instruction is executed after the system is released from the wait mode. The interrupt sources which can be used for return from wait mode are shown below. - INTo - INT1 - CNTR<sub>0</sub> - Timer - Serial I/O2 - A-D conversion - Key-on wakeup - USB function - UART When the above interrupt sources are used for return from wait mode, execute the **WIT** instruction after the following are set in order to enable the using interrupts. - ① Clear the interupt request bit of the interrupt using for return to "0" - 2 Set the interupt enable bit of the interrupt using for return to "1" - 3 Clear the interrupt disable flag (I) to "0" # HARDWARE DESCRIPTION OF IMPROVED USB FUNCTION FOR 7534 GROUP/ DIFFERENCES AMONG 32-PIN, 36-PIN AND 42-PIN # DESCRIPTION OF IMPROVED USB FUNCTION FOR 7534 GROUP Table 13 Description of improved USB function for 7534 Group | No | Parameter | 7532/7536 Group | 7534 Group | |----|------------------------------|-----------------------------------------------------|----------------------------------------------------| | 1 | Response at Control transfer | Not deal with the host which performs the Control | Connectable to the host which performs the Con- | | | | transfer in parallel to plural device. | trol transfer in parallel to plural device. | | 2 | D+/D- transceiver circuit | USB function can be used only at the condition of | Deal with the the following USB Spefification Rev. | | | | CL = 150 pF to 350 pF. | 1.1. | | | | | CL = 200 pF to 450 pF, | | | | | Trise and Tfall: 75 ns to 300 ns, | | | | | Tr/Tf: 80 % to 125 %, | | | | | Cross over Voltage: 1.3 V to 2.0 V. | | 3 | Power dissipation at Suspend | Rating is Max. 300 µA not including the output cur- | Rating is Max. 300 µA including the output current | | | | rent of USBVREFOUT. | of USBVREFOUT, by low-power dissipation of D+/ | | | | | D- input circuit and 3.3 V-regulator. | | 4 | STALL in Status stage | ACK is returned once to OUT (DATA0) to be valid | STALL is set automaticcally by hardware when | | | | in Status stage. | OUT (DATA0) is received in Status stage. | | 5 | 6-bit decode of SYNC field | SYNC is detected only when 8-bit full code (8016) | SYNC is detected only the low-order 6 bits even if | | | | is complete. | the high-order 2 bits are corrupted. | #### DIFFERENCES AMONG 32-PIN, 36-PIN AND 42-PIN The 7534 Group has three package types, and each of the number of I/O ports are different. Accordingly, when the pins which have the function except a port function are eliminated, be careful that the functions are also eliminated. Table 14 Differences among 32-pin, 36-pin and 42-pin | I/O port | 42-pin SDIP | 36-pin SSOP | 32-pin LQFP | |----------|----------------------------|--------------------------------|------------------------------| | Port P1 | P10-P16 (7-bit structure) | P10-P14 (5-bit structure) | P10-P14 (5-bit structure) | | Port P2 | P20-P27 (8-bit structure) | P20-P27 (8-bit structure) | P20-P25 (6-bit structure) | | | (A-D converter 8-channel) | (A-D converter 8-channel) | (A-D converter 6-channel) | | Port P3 | P30-P37 (8-bit structure) | P30-P35, P37 (7-bit structure) | P30-P34 (5-bit structure) | | | (INTo, INT1 available) | (INTo available) | (INT function not available) | | Port P4 | P40, P41 (2-bit structure) | No port | No port | Additionally, there are differences of SFR usage and functional definitions. Table 15 Differences among 32-pin, 36-pin and 42-pin (SFR) | Register (Address) | 42-pin SDIP | 36-pin SSOP | 32-pin LQFP | |---------------------|-----------------------------------------|---------------------------------------|---------------------------------------| | Port P1/Direction | Bit 7 not available | Bits 5 to 7 not available | Bits 5 to 7 not available | | (0216/0316) | | | | | Port P2/Direction | All bits available | All bits available | Bits 6 and 7 not available | | (0416/0516) | | | | | Port P3/Direction | All bits available | Bit 6 not available | Bits 5 to 7 not available | | (0616/0716) | | | | | Port P4/Direction | Bits 2 to 7 not available | All bits not available | All bits not available | | (0816/0916) | | | | | Pull-up control | Bit 6 definition: | Bit 6 definition: | Bits 6 and 7 not available | | (1616) | "P35, P36 pull-up control" | "P35 pull-up control" | | | | Bit 7 definition: | Bit 7 definition: | | | | "P37 pull-up control" | "P37 pull-up control" | | | Port P1P3 control | Bit 0 definition: | Bit 0 definition: | Bits 0 and 1 not available | | (1716) | "P37/INTo input level selection" | "P37/INT0 input level selection" | | | | Bit 1 definition: | Bit 1 not available | | | | "P36/INT1 input level selection" | | | | A-DControl | Bits 0 to 2 | Bits 0 to 2 | Bits 0 to 2 | | (3416) | "Input pins selected by setting these | "Input pins selected by setting these | "Input pins selected by setting these | | | bits to 000 to 111" | bits to 000 to 111" | bits to 000 to 101" | | Interrupt edge | Bit 0 definition | Bit 0 definition | Bits 0, 1 and 4 not available | | selection | "INTo interrupt edge selection" | "INTo interrupt edge selection" | | | (3A16) | Bit 1 definition | Bits 1 and 4 not available | | | | "INT1 interrupt edge selection" | | | | | Bit 4 definition | | | | | "Serial I/O1, INT1 interrupt selection" | | | | Interrupt request | Bit 1 definition | Bit 1 definition | Bit 1 definition | | (3C <sub>16</sub> ) | "UART transmission, USB (except IN), | "UART transmission, USB (except IN)" | "UART transmission, USB (except IN)" | | | INT1" | Bit 2 definition | Bit 2 not available | | | Bit 2 definition | "INTo" | | | | "INTo" | | | | Interrupt control | Bit 1 definition | Bit 1 definition | Bit 1 definition | | (3E16) | "UART transmission, USB (except IN), | "UART transmission, USB (except IN)" | "UART transmission, USB (except IN)" | | | INT1" | Bit 2 definition | Bit 2 not available | | | Bit 2 definition | "INTo" | | | | "INTo" | | | #### **DESCRIPTION SUPPLEMENT FOR USE OF USB FUNCTION STABLY** Fig. 54 Handling of Vcc, USBVREFOUT pins of M37534M4-XXXFP, M37534E8FP Fig. 55 Handling of VCC, USBVREFOUT pins of M37534M4-XXXGP, M37534E4GP Fig. 56 Handling of Vcc, USBVREFOUT pins of M37534E8SP, M37534M4-XXXSP, M37534RSS # CHAPTER 2 APPLICATION - 2.1 I/O port - 2.2 Timer - 2.3 Serial I/O - 2.4 USB - 2.5 A-D converter - 2.6 Reset # **APPLICATION** # 2.1 I/O port # 2.1 I/O port This paragraph explains the registers setting method and the notes relevant to the I/O ports. #### 2.1.1 Memory map | , | | | |--------|----------------------------------|--| | 000016 | Port P0 (P0) | | | 000116 | Port P0 direction register (P0D) | | | 000216 | Port P1 (P1) | | | 000316 | Port P1 direction register (P1D) | | | 000416 | Port P2 (P2) | | | 000516 | Port P2 direction register (P2D) | | | 000616 | Port P3 (P3) | | | 000716 | Port P3 direction register (P3D) | | | 000816 | Port P4 (P4) | | | 000916 | Port P4 direction register (P4D) | | | Î | | | Fig. 2.1.1 Memory map of registers relevant to I/O port #### 2.1.2 Relevant registers Fig. 2.1.2 Structure of Port Pi (i = 0 to 4) Fig. 2.1.3 Structure of Port Pi direction register (i = 0 to 4) Fig. 2.1.4 Structure of Pull-up control register # APPLICATION # 2.1 I/O port Fig. 2.1.5 Structure of P1P3 control register Fig. 2.1.6 Structure of Interrupt edge selection register Fig. 2.1.7 Structure of Interrupt request register 1 Fig. 2.1.8 Structure of Interrupt control register 1 ## 2.1 I/O port ### 2.1.3 Application example of key-on wake up Outline: The built-in pull-up resistor is used. Fig. 2.1.9 Relevant registers setting Fig. 2.1.10 Application circuit example Fig. 2.1.11 Control procedure ### 2.1.4 Handling of unused pins Table 2.1.1 Handling of unused pins | Pins/Ports name | Handling | | | |--------------------|---------------------------------------------------------------------------------------------|--|--| | P0, P1, P2, P3, P4 | •Set to the input mode and connect each to Vcc or Vss through a resistor of 1 k $\Omega$ to | | | | | 10 kΩ. | | | | | •Set to the output mode and open at "L" or "H" level. | | | | V <sub>REF</sub> | •Connect to Vss (GND). | | | | Хоит | Open, only when using an external clock | | | ## 2.1 I/O port #### 2.1.5 Notes on input and output pins #### (1) Notes in stand-by state In stand-by state\*1 for low-power dissipation, do not make input levels of an input port and an I/O port "undefined". Pull-up (connect the port to VCC) or pull-down (connect the port to VSS) these ports through a resistor. When determining a resistance value, note the following points: - External circuit - Variation of output levels during the ordinary operation When using a built-in pull-up resistor, note on varied current values: - When setting as an input port : Fix its input level - When setting as an output port : Prevent current from flowing out to external. #### Reason The potential which is input to the input buffer in a microcomputer is unstable in the state that input levels of a input port and an I/O port are "undefined". This may cause power source current. \*1 stand-by state : the stop mode by executing the **STP** instruction the wait mode by executing the **WIT** instruction #### (2) Modifying output data with bit managing instruction When the port latch of an I/O port is modified with the bit managing instruction\*2, the value of the unspecified bit may be changed. #### Reason The bit managing instructions are read-modify-write form instructions for reading and writing data by a byte unit. Accordingly, when these instructions are executed on a bit of the port latch of an I/O port, the following is executed to all bits of the port latch. - As for a bit which is set for an input port : - The pin state is read in the CPU, and is written to this bit after bit managing. - As for a bit which is set for an output port : The bit value of the port latch is read in the CPU, and is written to this bit after bit managing. #### Note the following: - Even when a port which is set as an output port is changed for an input port, its port latch holds the output data. - As for a bit of the port latch which is set for an input port, its value may be changed even when not specified with a bit managing instruction in case where the pin state differs from its port latch contents. <sup>\*2</sup> bit managing instructions: SEB, and CLB instructions #### 2.1.6 Termination of unused pins #### (1) Terminate unused pins ① Output ports : Open #### 2 Input ports: Connect each pin to VCC or Vss through each resistor of 1 k $\Omega$ to 10 k $\Omega$ . Ports that permit the selecting of a built-in pull-up resistor can also use this resistor. As for pins whose potential affects to operation modes such as pins CNVss, INT or others, select the Vcc pin or the Vss pin according to their operation mode. #### 3 I/O ports: • Set the I/O ports for the input mode and connect them to Vcc or Vss through each resistor of 1 k $\Omega$ to 10 k $\Omega$ . Ports that permit the selecting of a built-in pull-up resistor can also use this resistor. Set the I/O ports for the output mode and open them at "L" or "H". - When opening them in the output mode, the input mode of the initial status remains until the mode of the ports is switched over to the output mode by the program after reset. Thus, the potential at these pins is undefined and the power source current may increase in the input mode. With regard to an effects on the system, thoroughly perform system evaluation on the user side. - Since the direction register setup may be changed because of a program runaway or noise, set direction registers by program periodically to increase the reliability of program. #### (2) Termination remarks ① Input ports and I/O ports: Do not open in the input mode. #### Reason - The power source current may increase depending on the first-stage circuit. - An effect due to noise may be easily produced as compared with proper termination ② and ③ shown on the above. #### 2 I/O ports: When setting for the input mode, do not connect to VCC or VSS directly. #### Reason If the direction register setup changes for the output mode because of a program runaway or noise, a short circuit may occur between a port and VCC (or Vss). #### 3 I/O ports: When setting for the input mode, do not connect multiple ports in a lump to VCC or Vss through a resistor. #### Reason If the direction register setup changes for the output mode because of a program runaway or noise, a short circuit may occur between ports. • At the termination of unused pins, perform wiring at the shortest possible distance (20 mm or less) from microcomputer pins. #### 2.2 Timer #### 2.2 Timer This paragraph explains the registers setting method and the notes relevant to the timers. #### 2.2.1 Memory map Fig. 2.2.1 Memory map of registers relevant to timers #### 2.2.2 Relevant registers Fig. 2.2.2 Structure of Prescaler 12, Prescaler X Fig. 2.2.3 Structure of Timer 1 Fig. 2.2.4 Structure of Timer 2 Fig. 2.2.5 Structure of Timer X Fig. 2.2.6 Structure of Timer X mode register Table 2.2.1 CNTR<sub>0</sub> active edge switch bit function | Timer X operation modes | | CNTR <sub>0</sub> active edge switch bit (bit 2 of address 2B <sub>16</sub> ) contents | |------------------------------|-----|----------------------------------------------------------------------------------------| | Timer mode | | CNTR₀ interrupt request occurrence: Falling edge | | | | ; No influence to timer count | | | "1" | CNTR₀ interrupt request occurrence: Rising edge | | | | ; No influence to timer count | | Pulse output mode | | Pulse output start: Beginning at "H" level | | | | CNTR₀ interrupt request occurrence: Falling edge | | | "1" | Pulse output start: Beginning at "L" level | | | | CNTR₀ interrupt request occurrence: Rising edge | | Event counter mode | | Timer X: Rising edge count | | | | CNTR₀ interrupt request occurrence: Falling edge | | | "1" | Timer X: Falling edge count | | | | CNTR₀ interrupt request occurrence: Rising edge | | Pulse width measurement mode | | Timer X: "H" level width measurement | | | | CNTR₀ interrupt request occurrence: Falling edge | | | "1" | Timer X: "L" level width measurement | | | | CNTRo interrupt request occurrence: Rising edge | Fig. 2.2.7 Structure of Timer count source set register Fig. 2.2.8 Structure of Interrupt edge selection register Fig. 2.2.9 Structure of Interrupt request register 1 Fig. 2.2.10 Structure of Interrupt control register 1 #### 2.2 Timer #### 2.2.3 Timer application examples #### (1) Basic functions and uses #### [Function 1] Control of Event interval (Timer X, Timer 1, Timer 2) When a certain time, by setting a count value to each timer, has passed, the timer interrupt request occurs. <Use> - •Generation of an output signal timing - •Generation of a wait time #### [Function 2] Control of Cyclic operation (Timer X, Timer 1, Timer 2) The value of the timer latch is automatically written to the corresponding timer each time the timer underflows, and each timer interrupt request occurs in cycles. <Use> - Generation of cyclic interrupts - •Clock function (measurement of 100 ms); see Application example 1 - •Control of a main routine cycle #### [Function 3] Output of Rectangular waveform (Timer X) The output level of the CNTR<sub>0</sub> pin is inverted each time the timer underflows (in the pulse output mode). <Use> - •Piezoelectric buzzer output; see Application example 2 - •Generation of the remote-control carrier waveforms #### [Function 4] Count of External pulses (Timer X) External pulses input to the CNTR<sub>0</sub> pin are counted as the timer count source (in the event counter mode). <Use> - •Frequency measurement; see Application example 3 - Division of external pulses - •Generation of interrupts due to a cycle using external pulses as the count source; count of a reel pulse #### [Function 5] Measurement of External pulse width (Timer X) The "H" or "L" level width of external pulses input to CNTR<sub>0</sub> pin is measured (in the pulse width measurement mode). <Use> - Measurement of external pulse frequency (measurement of pulse width of FG pulse\* for a motor); see Application example 4 - •Measurement of external pulse duty (when the frequency is fixed) FG pulse\*: Pulse used for detecting the motor speed to control the motor speed. #### (2) Timer application example 1: Clock function (measurement of 100 ms) **Outline**: The input clock is divided by the timer so that the clock can count up at 100 ms intervals. **Specifications**: •The clock $f(X_{IN}) = 6.00$ MHz is divided by the timer. •The clock is counted up in the process routine of the timer X interrupt which occurs at 100 ms intervals. Figure 2.2.11 shows the timers connection and setting of division ratios; Figure 2.2.12 shows the relevant registers setting; Figure 2.2.13 shows the control procedure. Fig. 2.2.11 Timers connection and setting of division ratios Fig. 2.2.12 Relevant registers setting Fig. 2.2.13 Control procedure #### 2.2 Timer #### (3) Timer application example 2: Piezoelectric buzzer output **Outline**: The rectangular waveform output function of the timer is applied for a piezoelectric buzzer output. - **Specifications**: •The rectangular waveform, dividing the clock $f(X_{IN}) = 6.00$ MHz into about 2 kHz (1995 Hz), is output from the P1<sub>4</sub>/CNTR<sub>0</sub> pin. - •The level of the P14/CNTR0 pin is fixed to "H" while a piezoelectric buzzer output stops. Figure 2.2.14 shows a peripheral circuit example, and Figure 2.2.15 shows the timers connection and setting of division ratios. Figures 2.2.16 shows the relevant registers setting, and Figure 2.2.17 shows the control procedure. Fig. 2.2.14 Peripheral circuit example Fig. 2.2.15 Timers connection and setting of division ratios Fig. 2.2.16 Relevant registers setting Fig. 2.2.17 Control procedure #### (4) Timer application example 3: Frequency measurement **Outline**: The following two values are compared to judge whether the frequency is within a valid range. - •A value by counting pulses input to P14/CNTR0 pin with the timer. - •A reference value Specifications: •The pulse is input to the P14/CNTR0 pin and counted by the timer X. - •A count value is read out at about 2 ms intervals, the timer 1 interrupt interval. When the count value is 28 to 40, it is judged that the input pulse is valid. - •Because the timer is a down-counter, the count value is compared with 227 to 215 (Note). **Note**: 227 - 215 = 255 (initial value of counter) -28 to 40 (the number of valid count) Figure 2.2.18 shows the judgment method of valid/invalid of input pulses; Figure 2.2.19 shows the relevant registers setting; Figure 2.2.20 shows the control procedure. Fig. 2.2.18 Judgment method of valid/invalid of input pulses Fig. 2.2.19 Relevant registers setting Fig. 2.2.20 Control procedure #### 2.2 Timer ### (5) Timer application example 4: Measurement of FG pulse width for motor Outline: The timer X counts the "H" level width of the pulses input to the P14/CNTR0 pin. An underflow is detected by the timer X interrupt and an end of the input pulse "H" level is detected by the CNTR0 interrupt. Specifications: •The timer X counts the "H" level width of the FG pulse input to the P14/CNTR0 pin. #### <Example> When the clock frequency is 6.00 MHz, the count source is 2.7 $\mu$ s, which is obtained by dividing the clock frequency by 16. Measurement can be made up to 174 ms in the range of FFFF<sub>16</sub> to 0000<sub>16</sub>. Figure 2.2.21 shows the timers connection and setting of division ratio; Figure 2.2.22 shows the relevant registers setting; Figure 2.2.23 shows the control procedure. Fig. 2.2.21 Timers connection and setting of division ratios Fig. 2.2.22 Relevant registers setting Fig. 2.2.23 Control procedure #### 2.3 Serial I/O This paragraph explains the registers setting method and the notes relevant to the serial I/O. #### 2.3.1 Memory map Fig. 2.3.1 Memory map of registers relevant to serial I/O #### 2.3.2 Relevant registers Fig. 2.3.2 Structure of Transmit/Receive buffer register Fig. 2.3.3 Structure of UART status register Fig. 2.3.4 Structure of Serial I/O1 control register Fig. 2.3.5 Structure of UART control register Fig. 2.3.6 Structure of Baud rate generator Fig. 2.3.7 Structure of Serial I/O2 control register Fig. 2.3.8 Structure of Serial I/O2 register Fig. 2.3.9 Structure of Interrupt edge selection register Fig. 2.3.10 Structure of Interrupt request register 1 Fig. 2.3.11 Structure of Interrupt control register 1 #### 2.3.3 Serial I/O connection examples #### (1) Control of peripheral IC equipped with CS pin Figure 2.3.12 shows connection examples with a peripheral IC equipped with the CS pin. Each case uses the clock synchronous serial I/O mode. Fig. 2.3.12 Serial I/O connection examples (1) ## 2.3 Serial I/O ### (2) Connection with microcomputer Figure 2.3.13 shows connection examples with another microcomputer. Fig. 2.3.13 Serial I/O connection examples (2) #### 2.3.4 Serial I/O transfer data format The clock synchronous or the clock asynchronous (UART) can be selected as the serial I/O. Figure 2.3.14 shows the serial I/O transfer data format. Fig. 2.3.14 Serial I/O transfer data format #### 2.3 Serial I/O #### 2.3.5 Serial I/O application examples #### (1) Communication using clock synchronous serial I/O (transmit/receive) Outline: 2-byte data is transmitted and received, using the clock synchronous serial I/O. Port P0<sub>0</sub> is used for communication control and outputs the quasi-SRDY signal. The following explain an example using the serial I/O2. Figure 2.3.15 shows a connection diagram, and Figure 2.3.16 shows a timing chart. Fig. 2.3.15 Connection diagram Specifications: •The Serial I/O2, clock synchronous serial I/O, is used. •Synchronous clock frequency: 94 kHz; $f(X_{IN}) = 6$ MHz divided by 64 •Transfer direction : LSB first •The reception side outputs the quasi- $\overline{S_{RDY}}$ signal at 2 ms intervals which the timer generates, and 2-byte data is transferred from the transmission side to the reception side. Fig. 2.3.16 Timing chart Figures 2.3.17 and 2.3.19 show the registers setting relevant to the serial I/O2 and Figure 2.3.18 shows the transmission data setting of the serial I/O2. Fig. 2.3.17 Registers setting relevant to transmission side Fig. 2.3.18 Transmission data setting of serial I/O2 Fig. 2.3.19 Registers setting relevant to reception side Figure 2.3.20 shows a control procedure of transmission side, and Figure 2.3.21 shows a control procedure of reception side. Fig. 2.3.20 Control procedure of transmission side Fig. 2.3.21 Control procedure of reception side ## (2) Communication using asynchronous serial I/O, UART (transmit/receive) Outline: 2-byte data is transmitted and received, using the clock asynchronous serial I/O. Port P0<sub>0</sub> is used for communication control. Figure 2.3.22 shows a connection diagram, and Figure 2.3.23 shows a timing chart. Fig. 2.3.22 Connection diagram Specifications: •The Serial I/O1, asynchronous serial I/O, is used. - •Transfer bit rate : 9600 bps; $f(X_{IN}) = 4.9152$ MHz divided by 512 - •Communication control using port P0<sub>0</sub>; Port P0<sub>0</sub> output level is controlled by software. - •2-byte data is transferred from the transmission side to the reception side at 10 ms intervals which the timer generates Fig. 2.3.23 Timing chart ## 2.3 Serial I/O Table 2.3.1 shows a setting example of the baud rate generator (BRG) and transfer bit rate values; Figure 2.3.24 shows the registers setting relevant to transmission side; Figure 2.3.25 shows the registers setting relevant to reception side Table 2.3.1 Setting example of baud rate generator (BRG) and transfer bit rate values | BRG count source | BRG set value | Transfer bit rate | e (bps) ( <b>Note 2</b> ) | |-------------------------|-------------------------|-------------------------------------|--------------------------------| | (Note 1) | | At $f(X_{IN}) = 4.9152 \text{ MHz}$ | At $f(X_{IN}) = 6 \text{ MHz}$ | | f(X <sub>IN</sub> ) / 4 | 255 (FF <sub>16</sub> ) | 300 | 366.2109375 | | f(X <sub>IN</sub> ) / 4 | 127 (7F <sub>16</sub> ) | 600 | 732.421875 | | f(X <sub>IN</sub> ) / 4 | 63 (3F <sub>16</sub> ) | 1200 | 1464.84375 | | f(X <sub>IN</sub> ) / 4 | 31 (1F <sub>16</sub> ) | 2400 | 2929.6875 | | f(X <sub>IN</sub> ) / 4 | 15 (0F <sub>16</sub> ) | 4800 | 5859.375 | | f(X <sub>IN</sub> ) / 4 | 7 (0716) | 9600 | 11718.75 | | f(X <sub>IN</sub> ) / 4 | 3 (0316) | 19200 | 23437.5 | | f(X <sub>IN</sub> ) / 4 | 1 (0116) | 38400 | 46875 | | f(X <sub>IN</sub> ) | 3 (0316) | 76800 | 93750 | | f(X <sub>IN</sub> ) | 1 (0116) | 153600 | 187500 | | f(X <sub>IN</sub> ) | 0 (0016) | 307200 | 375000 | Notes 1: Select the BRG count source with bit 0 of the serial I/O1 control register (address 1A<sub>16</sub>). 2: Equation of transfer bit rate: Transfer bit rate (bps) = $$\frac{f(X_{IN})}{(BRG \text{ set value } + 1) \times 16 \times m^*}$$ m\*: m = 1 in the case of bit 0 of the serial I/O1 control register (address $001A_{16}$ ) = "0" m = 4 in the case of bit 0 of the serial I/O1 control register (address $001A_{16}$ ) = "1" Fig. 2.3.24 Registers setting relevant to transmission side Fig. 2.3.25 Registers setting relevant to reception side Figure 2.3.26 shows a control procedure of transmission side, and Figure 2.3.27 shows a control procedure of reception side. Fig. 2.3.26 Control procedure of transmission side Fig. 2.3.27 Control procedure of reception side ### 2.3.6 Notes on serial I/O ### (1) Handling of clear the serial I/O1 When serial I/O1 is set again or the transmit/receive operation is stopped/restarted while serial I/O1 is operating, clear the serial I/O1 as shown in Figure 2.3.28. Fig. 2.3.28 Sequence of clearing serial I/O ## (2) Data transmission control with referring to transmit shift register completion flag The transmit shift register completion flag changes from "1" to "0" with a delay of 0.5 to 1.5 shift clocks. When data transmission is controlled with referring to the flag after writing the data to the transmit buffer register, note the delay. ### (3) Writing transmit data When an external clock is used as the synchronous clock for the clock synchronous serial I/O, write the transmit data to the transmit buffer register (serial I/O shift register) at "H" of the transfer clock input level. ### (4) Serial I/O2 transmit/receive shift completion flag - •The transmit/receive shift completion flag (bit 7) of the serial I/O2 control register is set to "1" after completing transmit/receive shift. In order to set this flag to "0", write data (dummy data at reception) to the serial I/O2 register by program. - •Bit 7 of the serial I/O2 control register is set to "1" a half cycle (of the shift clock) earlier than completion of shift operation. Accordingly, when using this bit to confirm shift completion, a half cycle or more of the shift clock must pass after confirming that this bit is set to "1", before performing read/write to the serial I/O2 register. ### 2.4 **USB** ### 2.4 **USB** This paragraph explains operational outline, the registers relevant to the USB, the registers setting method, the application example for communication and notes on use. ### 2.4.1 Outline of USB 7534 Group has low-speed communication function (L.S.:Low Speed function) in accordance with USB Specification V.1.1 among USB (Universal Serial Bus) communication functions which are connection standard with PC peripherals. In this section, the outline of USB communication function and the USB function of 7534 Group are described. ## (1) Transfer type In present PC, 2 or more standards used for the connection with peripherals exist (RS-232C and Centronics, etc.). USB tries to unite all those communication standards. The standard of USB has the host side (PC,Hub) which controls connected peripherals and the connected peripherals side (device). The following 2 types of communication standards exist depending on the data amount treated on the peripherals side. ## • High-speed communication (F.S.: Full Speed function): Communication standard with fast transfer rate (12 Mbps) This standard is used for peripherals that a large amount of data transfer is required for one time (image and voice, etc.). ### • Low-speed communication (L.S.: Low Speed function): Communication standard with slow transfer rate (1.5 Mbps) This standard is used for peripherals with a small amount of data (keyboard and mouse, etc.). This communication standard depends on the kind of peripherals. The transfer type for each peripheral is decided. Table 2.4.1 shows the transfer types of USB. Table 2.4.1 Transfer types of USB | Transfer type | L.S./F.S | Operation | |---------------|----------|------------------------------------------------------------------------| | Control | L.S./F.S | This is used when setting up and for all devices common. | | Interrupt | L.S./F.S | This is used when transferring a small amount of data in real time. | | Bulk | F.S | This is used when transferring a large amount of data in no real time. | | Isochronous | F.S | This is used when transferring a large amount of data in real time. | L.S.: Low-Speed function, F.S.: Full-Speed function The 7534 Group has one low-speed communication function, and the control transfer and interrupt transfer can be used in Table 2.4.1 ### (2) Communication sequence The control transfer and the interrupt transfer have a different communication sequence, respectively. The control transfer is used when setting up all devices common and communicates combining 3 types of stages in one processing. The communication starts first in Setup Stage, and Data Stage of the content is executed, and then, one processing of the communication sequence is completed by executing Status Stage. Data can be set from host to device through this sequence (=Control Write), and the result can be read out to host from device (=Control Read). Use endpoint (ENDP) "0" in the control transfer. The interrupt transfer is used when transferring a small amount of data in real time. There is no stage unlike the control transfer. Only when the host requests data (Token=IN), the device can transmit data. Use the endpoint in the interrupt transfer excluding "0" ("1" is set for the 7534 Group). Figure 2.4.1 shows the communication sequence of USB. Fig. 2.4.1 Communication sequence of USB ### **2.4 USB** #### (3) Packet type The host side controls all the communications in USB. Basically, the host gives the device the instruction of the communication processing which the host side executes (= Token), executes data transmit/receive (= Data), and indicates the completion of the communication is shown at the end (= Handshake). These communication processings are executed in order by each one unit which has the data structure (= Packet format), and one processing (= Transaction) is completed. The content of processing can be identified according to PID (Packet IDentifier field) which is one unit of data (Field) which composes each packet. Not only the content of processing, but also the data structure in the packet can be identified by this PID. Table 2.4.2 shows the packet type of USB. Table 2.4.2 Packet types of USB | Packet type | Transmitter | Operation | |----------------------|-------------|---------------------------------------------------------------------------| | SOF (Start of Frame) | Host | Packet indicating the top of frame (1 ms) including all transfer types | | Token | Host | Packet indicating the processing to execute | | Data | Host/Device | Packet indicating the transmit/receive data for processing shown by token | | Handshake | Host/Device | Packet indicating the result of communication processing | In 7534 Group, the token, data, and the handshake of packet types in Table 2.4.2 can be controlled by software. ### (4) Packet structure As for the packet type of USB, the data and the structure are different by PID. Each packet includes the following data shown with PID for which the control is required by 7534 Group; - token: the receiver to communicate (ADDR) and transfer type (ENDP) - data: execution (DATA) of the processing ordered by the token - handshake: the completion of the communication Figure 2.4.2 shows the data structure of the packet. Notes 1: The shaded parts show the data which requires processing by software in 7534 Group. - 2: The DATA number of data PID shows the number in L.S. - 3: Determination of "Start Of Frame" is not executed because the processing is not required. Fig. 2.4.2 Data structure of USB packet In 7534 Group, the PID, ADDR, ENDP and DATA of packet structure data in Figure 2.4.2 can be controlled by software. ### (5) Data structure Data which composes the communication of USB transmits and receives data that the structure number of bits is different as shown in Figure 2.4.2 continuously by the LSB first. Basically, the contents except SYNC which is synchronizing signal and EOP which is the completion signal are treated as data. Accordingly, the difference of the number of bits can be detected by forecasting and determining the following data from the content of PID. Table 2.4.3 shows the content of data which composes the packet. Table 2.4.3 Data structure of USB packet | Data name | Symbol | Structure | Operation | | | |-------------------|--------|-----------------------|--------------------------------------------------------|--|--| | Synchronize | Sync | 8 bits | Synchronized signal to communicate | | | | Packet IDentifier | PID | 8 bits | Data indicating processing of packet | | | | Frame Number | _ | 11 bits | Data to control the frame during communication by time | | | | Address | ADDR | 7 bits | Data to confirm the transmit destination of packet | | | | | | | and notify from transmitter | | | | Endpoint | ENDP | 4 bits | Data indicating transfer type used by device | | | | Data | DATA | 8 bits X 0 to 8 bytes | Data to be used when the processing specified | | | | | | | PID is executed | | | | Token CRCs | CRC5 | 5 bits | Data to check error when PID is token and SOF | | | | Data CRCs | CRC16 | 16 bits | Data to check error when PID is DATA | | | | End Of Packet | EOP | 2 bits | Data indicating the completion of packet | | | Note: The DATA numbers in L.S. are shown in this table. PID is classified into 3 kinds in the structure data of Table 2.4.3. Token is used to give the device the instruction of communication processing, and report on the processing of the following stages. It is only a host to be able to issue the token. Data is used to transmit and receive data which is the content of the instruction of the token, and execute the processing in the stage. It is a host to be able to issue the data when the token is SETUP and OUT, and it is a device when the token is IN. Handshake indicates the completion of the communication at the end. It is a host to be able to issue the handshake when the token is IN, and it is a host when the token is SETUP and OUT. Table 2.4.4 shows PID. Table 2.4.4 PID | Packet | PID name | Bit structure | Processing | |-----------|----------|---------------|---------------------------------------------------------------------------| | type | | (bits 3 to 0) | | | Token | SETUP | 11012 | The processing is reported by host to device | | | IN | 10012 | Data transmit is requested from host to device | | | OUT | 00012 | Data receive is requested from host to device | | | SOF | 01012 | Top of frame is indicated by host to device | | Data | DATA0 | 00112 | The state that sequence bit of transmit/receive data is even is indicated | | | DATA1 | 10112 | The state that sequence bit of transmit/receive data is odd is indicated | | Handshake | ACK | 00102 | Normal completion of communication is reported | | | NAK | 10102 | The state that device is waiting for communication is reported | | | STALL | 11102 | Completion error of communication is reported | | Special | PRE | 11002 | Communication to the L.S. device which has low-priority is enabled | In 7534 Group, data except SOF and PRE of PID can be controlled by software. ### 2.4 **USB** ### (6) USB special signal The host side has function to control the state of the device side, and the device side has the function to transmit the state to the host side and other devices on USB communications line by the signal besides the above-mentioned data transfer. Usually, the transfer confirmation [Keep alive, Idle: only for L.S.] is performed on the USB communication line regardless of data transmit/receive. The contents of transfer confirmation are as follows; - host confirms the connection of device on the communication line - device confirms the normal data transfer of host. The confirmation transfer is transmitted by host side for each frame (1ms/frame) which is the basic time unit of the USB transfer. When the host stops all the device, the host informs device of the stop of functions by suspending the confirmation transfer for 3 ms or more. The signal to stop the function is called "Suspend". The stopped device can be returned by 2 methods. The return is performed basically when there is a change in the device in the stopped state. One is a method (change on communications line) to return to a normal state by restarting the data communication which is suspended before suspend. The signal to return is called "Resume". The other is a method (change on the device) to return to a normal state by the change in an external input of the device. The host can inform all the other connected devices of the return of the device by the change in an external input by outputting K state signal of 1 to 15 ms. The signal to activate for other devices is called "Remote wake up". When the SE0 signal of $2.5~\mu s$ or more is input on communications line regardless of the state of the stop/start of the function of the device side, the packet, and the stage processing, the device makes all states concerning the USB function initial state. The signal to initialize is called "Reset". Table 2.4.5 shows a special signal of USB. Table 2.4.5 Special signal of USB | Signal type | Operation | Signal format | |----------------|-----------------------------------|------------------------------------------------| | Suspend | Stop of all device function | No data transfer for 3 ms | | Resume | Return of device function | K state input/reset input in the suspend state | | Reset | Initialization of USB setting | SE0 input for 2.5 μs or more | | Remote wake up | Report of return to other devices | K state output for 1 to 15 ms | ## (7) USB interface In 7534 Group, the USB interface divides one communications line by 2 depending on the contents of data. Figure 2.4.3 shows the interface of USB. Fig. 2.4.3 USB (L.S.) interface ### (8) System configuration of USB In the system configuration used with the low-speed communication device of USB, the host side can recognize the connection of the low-speed communication device by pull-up the D-pin with the voltage of 3.0 to 3.6 V and the resistor of 1.5 k $\Omega$ of communications lines. Figure 2.4.4 shows the example of connecting USB [L.S]. Fig. 2.4.4 USB (L.S.) connection example ## 2.4 USB ### 2.4.2 Memory map Fig. 2.4.5 Memory map of registers relevant to USB ### 2.4.3 Relevant registers In this section, the contents of control are described as follows; - Transmit/Receive buffer - Setting to enable/disable of each function including USB communication and interrupts - Determination of USB communication error occurrence - · Setting to stage and handshake by unit of endpoint - · Auto-determination of self-address of USB device Figure 2.4.6 shows the description of the register structure, and Figure 2.4.7 to Figure 2.4.10 show the register structures relevant to USB. Fig. 2.4.6 Description of the register structure Fig. 2.4.7 Register structures relevant to USB (1) Fig. 2.4.8 Register structures relevant to USB (2) Fig. 2.4.9 Register structures relevant to USB (3) Fig. 2.4.10 Register structures relevant to USB (4) ### **2.4 USB** ### 2.4.4 USB application example In this section, the application examples when using the USB communication are described using examples of the timing chart and register setting. ### (1) Example of processing each control sequence In 7534 Group, the control and the determination of the control sequence are executed by software. The content of processing is executed in the setup stage, transmitting and receiving the data stage of the content are executed, and the completion of the sequence is shown in the status stage. Note that the contents of the control and the determination are different even in the software of 7534 Group, because the following processing is different respectively depending on the content of the setup stage. In the control transfer, the processing since the data stage is determined when receiving the setup stage, the execution of the transmit and receive processing and the number of data bytes are controlled, the status stage at the end is executed, and the sequence is completed. Only the control of each packet is performed because there is no stage in the interrupt transfer. Figure 2.4.11 shows the control method of control sequence. Fig. 2.4.11 Control method of control sequence ### (2) Example of processing each transaction In 7534 Group, the control and the determination of the packet are executed by software. First, the content of the received token is determined, transmit and receive data according to it are executed, the completion of the transaction is shown by the handshake. Note that the contents of the control and the determination are different even of the software so that processing is different depending on the content of the token. Figure 2.4.12 shows timing chart of the transaction according to each token. Fig. 2.4.12 Timing chart of the transaction according to each token ### **2.4 USB** ### (3) Interrupt processing In 7534 Group, the interrupt related to the USB communication processes 7 sources 2 jump destination. Accordingly, determine the interrupt source and execute the processing after executing the interrupt processing. Moreover, control the USB function and the interrupt source which has been enabled before interrupt is enabled. The interrupt jump destination and the source are shown as follows. IN token interrupt: IN token (endpoint 0) and IN token (endpoint 1) OUT token interrupt: OUT token, SETUP token, Reset, Suspend, and Resume The determination (processing at the OUT token in figure) by the interrupt and the setting of a related register when using the interrupt of the OUT token is shown in Figure 2.4.13. The determination (processing at the IN token (endpoint 0) in figure) by the interrupt and the setting a related register when using the interrupt of the IN token in Figure 2.4.14. In the OUT token interrupt, read data of OUT token and SETUP token at the timing shown in Figures 2.4.15 and 2.4.16. Also, in the IN token interrupt, write data to IN token (endpoint 0) and IN token (endpoint 1) at the timing shown in Figure 2.4.17. Fig. 2.4.13 USB interrupt processing example (OUT token) Fig. 2.4.14 USB interrupt processing example (IN token) Fig. 2.4.15 Data read timing of SETUP token Fig. 2.4.16 Data read timing of OUT token Fig. 2.4.17 Data read timing of IN token (endpoint 0) and IN token (endpoint 1) token ### **2.4 USB** ### (4) Processing to special signal In 7534 Group, control the USB function to the signal shown in Table 2.4.5 by software. At USB reset, initialize the registers relevant to USB described in the above section 2.4.3. Also, at Suspend, execute the STP instruction after the interrupt is enabled. Set an external interrupt which is the return condition from the stopped state before STP instruction. The enable of resume is included in this condition. The generation of these signals can be recognized by the interrupt request. The interrupt to a special signal is all included in the OUT token interrupt. IN token interrupt: IN token (endpoint 0) and IN token (endpoint 1) OUT token interrupt: OUT token, SETUP token, Reset, Suspend, and Resume The remote wake up function is used to output signals when to output as USB function is required for the return from the stopped state by an external input. Figure 2.4.18 shows timing chart of each signal. Fig. 2.4.18 Timing chart of each signal ### 2.4.5 Notes concerning USB ## (1) Determination of interrupt condition in OUT token interrupt processing Determine the occurrence of the reset/suspend/resume interrupt from other interrupt conditions in the order as shown in Figure 2.4.19 when they occur in the OUT token interrupt processing. Fig. 2.4.19 Example for determination of resume interrupt ### (2) Clear of suspend request flag When the request of the suspend interrupt occurs, the suspend request flag is set to "1". After the suspend state is fixed, the state of this flag is retained during fixed time (13 $\mu$ s). The purpose of this is to retain the internal state until the count source to measure the time (3 ms) until suspend is fixed is updated. Accordingly, the state might not change even if this flag is cleared to "0" immediately after the suspend request flag is "1" is determined. Clear this flag to "0" after the wait of 13 $\mu$ s or 79 machine cycle (f(XIN) =6 MHz time) after this flag is "1". #### (3) Determination of SE0 signal In 7534 Group, USB reset and EOP can be distinguished according to the width of the SE0 signal. However, there is the time zone which corresponds any on the dividing line of the time of the width of the signal. Moreover, the control in a present state is required because there is a difference in processing by the state of the device. Accordingly, select the processing method in software by the state of the device. Figure 2.4.20 shows processing to the width of the signal according to the situation. Fig. 2.4.20 Processing for width of SE0 signal ### 2.5 A-D converter ### 2.5 A-D converter This paragraph explains the registers setting method and the notes relevant to the A-D converter. ### 2.5.1 Memory map Fig. 2.5.1 Memory map of registers relevant to A-D converter ### 2.5.2 Relevant registers Fig. 2.5.2 Structure of A-D control register Fig. 2.5.3 Structure of A-D conversion register (high-order) Fig. 2.5.4 Structure of A-D conversion register (low-order) ## 2.5 A-D converter | <del>, , , , , , , , , , , , , , , , , , , </del> | Int | Interrupt edge selection register (INTEDGE) [Address: 3A 16] | | | | | |---------------------------------------------------|-----|-----------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------|----------|---|---| | | В | Name | Function | At reset | R | W | | | 0 | INTo interrupt edge selection bit ( <b>Note 1</b> ) | 0 : Falling edge active<br>1 : Rising edge active | 0 | 0 | 0 | | | 1 | INT <sub>1</sub> interrupt edge selection bit ( <b>Note 2</b> ) | 0 : Falling edge active<br>1 : Rising edge active | 0 | 0 | 0 | | | 2 | Nothing is allocated for these bits. These are write disabled bits. When these bits are read out, the values are "0". | | 0 | 0 | × | | | 3 | | | 0 | 0 | × | | | 4 | Serial I/O1 or INT1 interrupt selection bit | 0 : Serial I/O1<br>1 : INT1 | 0 | 0 | 0 | | | 5 | Timer X or key-on wake up interrupt selection bit | 0 : Timer X<br>1 : Key-on wake up | 0 | 0 | 0 | | | 6 | Timer 2 or serial I/O2 interrupt selection bit | 0 : Timer 2<br>1 : Serial I/O2 | 0 | 0 | 0 | | L | 7 | CNTR <sub>0</sub> or AD converter interrupt selection bit | 0 : CNTR <sub>0</sub><br>1 : AD converter | 0 | 0 | 0 | | | Not | 2: 36-pin and 32-pin version: | When this bit is read out, the value Not used. When this bit is read out, the value | | | | Fig. 2.5.5 Structure of Interrupt edge selection register Fig. 2.5.6 Structure of Interrupt request register 1 ## 2.5 A-D converter Fig. 2.5.7 Structure of Interrupt control register 1 ## 2.5 A-D converter ### 2.5.3 A-D converter application examples ### (1) Conversion of analog input voltage Outline: The analog input voltage from a sensor is converted to digital values. Figure 2.5.8 shows a connection diagram, and Figure 2.5.9 shows the relevant registers setting. Fig. 2.5.8 Connection diagram Specifications: •The analog input voltage from a sensor is converted to digital values. •P2<sub>0</sub>/AN<sub>0</sub> pin is used as an analog input pin. Fig. 2.5.9 Relevant registers setting An analog input signal from a sensor is converted to the digital value according to the relevant registers setting shown by Figure 2.5.9. Figure 2.5.10 shows the control procedure for 8-bit read, and Figure 2.5.11 shows the control procedure for 10-bit read. Fig. 2.5.10 Control procedure for 8-bit read Fig. 2.5.11 Control procedure for 10-bit read ## 2.5 A-D converter ### 2.5.4 Notes on A-D converter ### (1) Analog input pin Make the signal source impedance for analog input low, or equip an analog input pin with an external capacitor of $0.01\mu F$ to $1\mu F$ . Further, be sure to verify the operation of application products on the user side. #### Reason An analog input pin includes the capacitor for analog voltage comparison. Accordingly, when signals from signal source with high impedance are input to an analog input pin, charge and discharge noise generates. This may cause the A-D conversion/comparison precision to be worse. ## (2) Clock frequency during A-D conversion The comparator consists of a capacity coupling, and a charge of the capacity will be lost if the clock frequency is too low. Thus, make sure the following during an A-D conversion. - f(X<sub>IN</sub>) is 500 kHz or more - Do not execute the STP instruction #### 2.6 Reset #### 2.6.1 Connection example of reset IC Figure 2.6.1 shows the system example to switch to the RAM back-up mode when detecting the falling of system power source by the INT interrupt. Fig. 2.6.1 Example of poweron reset circuit #### 2.6.2 Notes on RESET pin #### Connecting capacitor In case where the RESET signal rise time is long, connect a ceramic capacitor or others across the RESET pin and the Vss pin. Use a 1000 pF or more capacitor for high frequency use. When connecting the capacitor, note the following: - Make the length of the wiring which is connected to a capacitor as short as possible. - Be sure to verify the operation of application products on the user side. #### Reason If the several nanosecond or several ten nanosecond impulse noise enters the <del>RESET</del> pin, it may cause a microcomputer failure. ## **APPLICATION** 2.6 Reset **MEMO** # CHAPTER 3 ## **APPENDIX** - 3.1 Electrical characteristics - 3.2 Typical characteristics - 3.3 Notes on use - 3.4 Countermeasures against noise - 3.5 List of registers - 3.6 Package outline - 3.7 List of instruction code - 3.8 Machine instructions - 3.9 SFR memory map - 3.10 Pin configurations #### 3.1 Electrical characteristics #### 3.1 Electrical characteristics #### 3.1.1 Absolute Maximum Ratings Table 3.1.1 Absolute maximum ratings | Symbol | | Parameter | Conditions | Ratings | Unit | |--------|----------------------|--------------------------------------------------------------------|----------------------------------|-------------------|------| | Vcc | Power source voltage | | | -0.3 to 7.0 | V | | Vı | Input voltage | P00-P07, P10-P16, P20-P27, P30-<br>P37, VREF, P40, P41 | All voltages are | -0.3 to Vcc + 0.3 | ٧ | | Vı | Input voltage | RESET, XIN | based on Vss. Output transistors | -0.3 to Vcc + 0.3 | V | | Vı | Input voltage | CNVss (Note 1) | are cut off. | -0.3 to 13 | V | | Vo | Output voltage | P00-P07, P10-P16, P20-P27, P30-<br>P37, XOUT, USBVREFOUT, P40, P41 | - | -0.3 to Vcc + 0.3 | V | | Pd | Power dissipation | (Note 2) | Ta = 25°C | 1000 (Note 3) | mW | | Topr | Operating temperat | ure | | -20 to 85 | °C | | Tstg | Storage temperature | e | | -40 to 125 | °C | Notes 1: It is a rating only for the One Time PROM version. Connect to Vss for mask ROM version. 2: The rating value depends on packages. 3: This is the value for the 42-pin version. The value of the 36-pin version is 300 mW. The value of the 32-pin version is 200 mW. #### 3.1.2 Recommended Operating Conditions Table 3.1.2 Recommended operating conditions (VCC = 4.1 to 5.5 V, Ta = -20 to 85 °C, unless otherwise noted) | Symbol | Daramete | Parameter | | Limits | | | |------------|-------------------------------------------------------------------------------|-------------------------------------------------|---------|--------|---------|------| | Symbol | Paramete | | Min. | Тур. | Max. | Unit | | Vcc | Power source voltage | f(XIN) = 6 MHz | 4.1 | 5.0 | 5.5 | V | | Vss | Power source voltage | | | 0 | | V | | VREF | Analog reference voltage | | 2.0 | | Vcc | V | | VIH | "H" input voltage | P00-P07, P10-P16, P20-P27, P30-P37, P40, P41 | 0.8 Vcc | | Vcc | V | | VIH | "H" input voltage (TTL input level selected) | P10, P12, P13, P36, P37 | 2.0 | | Vcc | V | | VIH | "H" input voltage | RESET, XIN | 0.8 Vcc | | Vcc | V | | VIH | "H" input voltage | D+, D- | 2.0 | | 3.6 | V | | VIL | "L" input voltage | P00-P07, P10-P16, P20-P27,<br>P30-P37, P40, P41 | 0 | | 0.3 Vcc | V | | VIL | "L" input voltage (TTL input level selected) | P10, P12, P13, P36, P37 | 0 | | 0.8 | V | | VIL | "L" input voltage | RESET, CNVss | 0 | | 0.2 Vcc | V | | VIL | "L" input voltage | D+, D- | 0 | | 0.8 | V | | VIL | "L" input voltage | XIN | 0 | | 0.16Vcc | V | | I OH(peak) | "H" total peak output current (Note 1) | P00–P07, P10–P16, P20–P27,<br>P30–P37, P40, P41 | | | -80 | m/ | | I OL(peak) | "L" total peak output current (Note 1) | P00-P07, P10-P16, P20-P27,<br>P37, P40, P41 | | | 80 | m/ | | I OL(peak) | "L" total peak output current (Note 1) | P30-P36 | | | 60 | m/ | | I OH(avg) | "H" total average output current (Note 1) | P00-P07, P10-P16, P20-P27,<br>P30-P37, P40, P41 | | | -40 | m/ | | I OL(avg) | "L" total average output current (Note 1) | P00-P07, P10-P16, P20-P27,<br>P37, P40, P41 | | | 40 | m | | I OL(avg) | "L" total average output current (Note 1) | P30-P36 | | | 30 | m | | IOH(peak) | "H" peak output current (Note 2) | P00-P07, P10-P16, P20-P27, P30-P37, P40, P41 | | | -10 | m/ | | IOL(peak) | "L" peak output current (Note 2) | P00-P07, P10-P16, P20-P27,<br>P37 , P40, P41 | | | 10 | m/ | | IOL(peak) | "L" peak output current (Note 2) | P30-P36 | | | 30 | m/ | | IOH(avg) | "H" average output current (Note 3) | P00-P07, P10-P16, P20-P27,<br>P30-P37, P40, P41 | | | -5 | m/ | | IOL(avg) | "L" average output current (Note 3) | P00-P07, P10-P16, P20-P27,<br>P37, P40, P41 | | | 5 | mA | | IOL(avg) | "L" average output current (Note 3) | P30-P36 | | | 15 | m/ | | f(XIN) | Oscillation frequency (Note 4) at ceramic oscillation or external clock input | Vcc = 4.1 to 5.5 V<br>Double-speed mode | | | 6 | MH | Note 1: The total output current is the sum of all the currents flowing through all the applicable ports. The total average current is an average value measured a term of 100 ms. The total peak current is the peak value of all the currents. <sup>2:</sup> The peak output current is the peak current flowing in each port. <sup>3:</sup> The average output current IoL (avg), IoH (avg) in an average value measured a term of 100 ms. <sup>4:</sup> When the oscillation frequency has a duty cycle of 50 %. #### 3.1 Electrical characteristics #### 3.1.3 Electrical Characteristics Table 3.1.3 Electrical characteristics (1) (Vcc = 4.1 to 5.5 V, Vss = 0 V, Ta = -20 to 85 °C, unless otherwise noted) | 0 | | D | Took oo a distan | Limits | | | | |---------|--------------------|--------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|------|------|------| | Symbol | | Parameter | Test conditions | Min. | Тур. | Max. | Unit | | Voн | "H" output voltage | P00-P07, P10-P16, P20-P27,<br>P30-P37, P40, P41 (Note 1) | IOH = -5 mA<br>VCC = 4.1 to 5.5 V | Vcc-1.5 | | | V | | | | | IOH = -1.0 mA<br>VCC = 4.1 to 5.5 V | Vcc-1.0 | | | V | | Vон | "H" output voltage | D+, D- | VCC = 4.4 to 5.25 V<br>Pull-down through<br>15k $\Omega$ ±5 % for D+, D-<br>Pull-up through 1.5k $\Omega$<br>±5 % by USBVREFOUT<br>for D- (Ta = 0 to 70 °C) | 2.8 | | 3.6 | V | | VoL | "L" output voltage | P00-P07, P10-P16, P20-P27,<br>P37, P40, P41 | IOL = 5 mA<br>VCC = 4.1 to 5.5 V | | | 1.5 | V | | | | | IOL = 1.5 mA<br>VCC = 4.1 to 5.5 V | | | 0.3 | V | | VOL | "L" output voltage | D+, D- | VCC = 4.4 to 5.25 V<br>Pull-down through<br>15k $\Omega$ ±5 % for D+, D-<br>Pull-up through 1.5k $\Omega$<br>±5 % by USBVREFOUT<br>for D-(Ta = 0 to 70 °C) | | | 0.3 | V | | VoL | "L" output voltage | P30-P36 | IOL = 15 mA<br>VCC = 4.1 to 5.5 V | | | 2.0 | V | | | | | IOL = 1.5 mA<br>VCC = 4.1 to 5.5 V | | | 0.3 | V | | VT+-VT- | Hysteresis | D+, D- | | | 0.15 | | V | | VT+-VT- | Hysteresis | CNTR <sub>0</sub> , INT <sub>0</sub> , INT <sub>1</sub> (Note 2),<br>P00–P07(Note 3) | | | 0.4 | | V | | VT+-VT- | Hysteresis | RXD, SCLK, SDATA (Note 2) | | | 0.5 | | V | | VT+-VT- | Hysteresis | RESET | | | 0.5 | | V | | lін | "H" input current | P00-P07, P10-P16, P20-P27,<br>P30-P37, P40, P41 | VI = VCC<br>(Pin floating. Pull-up<br>transistors "off") | | | 5.0 | μA | | lін | "H" input current | RESET | VI = VCC | | | 5.0 | μΑ | | lін | "H" input current | XIN | VI = VCC | | 4 | | μA | | lıL | "L" input current | P00–P07, P10–P16, P20–P27,<br>P30–P37, P40, P41 | VI = VSS<br>(Pin floating. Pull-up<br>transistors "off") | | | -5.0 | μA | | lıL | "L" input current | RESET, CNVss | VI = VSS | | | -5.0 | μΑ | | lıL | "L" input current | XIN | VI = VSS | | -4 | | μA | | lıL | "L" input current | P00-P07, P30-P37 | VI = VSS<br>(Pull-up transistors"on") | | -0.2 | -0.5 | mA | | VRAM | RAM hold voltage | | When clock stopped | 2.0 | | 5.5 | V | Note 1: P11 is measured when the P-channel output disable bit of the UART control register (bit 4 of address 001B16) is "0". 2: RXD, SCLK, SDATA, INTo and INT1 have hystereses only when bits 0, 1 and 2 of the port P1P3 control register are set to "0" (CMOS level). 3: It is available only when operating key-on wake-up. | Cumah al | Dozomotor | Took oon diking o | Limits | | | | | |----------|----------------------|-------------------------------------------------------------------------------------------------------------------------------|-----------------|------|------|------|------| | Symbol | Parameter | Test conditions | | Min. | Тур. | Max. | Unit | | Icc | Power source current | Double-speed mode, f(XIN) = 6 MHz,<br>Output transistors "off" | | | 6 | 10 | mA | | | | f(XIN) = 6 MHz, (in WIT state)<br>Output transistors "off" | | | 1.6 | 3.2 | mA | | | | Increment when A-D conversion is executed f(XIN) = 6 MHz, Vcc = 5 V | | | 0.8 | | mA | | | | All oscillation stopped (in STP state) | Ta = 25 °C | | 0.1 | 1.0 | μA | | | | Output transistors "off" | Ta = 85 °C | | | 10 | μA | | | | Vcc = 4.4 V to 5.25 V<br>Oscillation stopped in USB mode<br>USB (SUSPEND), (pull-up resistor<br>output included) (Fig. 3.1.1) | Ta = 0 to 70 °C | | | 300 | μА | Table 3.1.4 Electrical characteristics (2) (Vcc = 4.1 to 5.5 V, Vss = 0 V, Ta = -20 to 85 °C, unless otherwise noted) #### 3.1.4 A-D Converter Characteristics | Symbol | Parameter | Took oon dikiono | | Limits | | | | |---------|--------------------------------------|----------------------------------|------|--------|------|---------|--| | | | Test conditions | Min. | Тур. | Max. | Unit | | | _ | Resolution | | | | 10 | Bits | | | _ | Linearity error | Vcc = 4.1 to 5.5 V<br>Ta = 25 °C | | | ±3 | LSB | | | _ | Differential nonlinear error | VCC = 4.1 to 5.5 V<br>Ta = 25 °C | | | ±0.9 | LSB | | | VOT | Zero transition voltage | VCC = VREF = 5.12 V | 0 | 5 | 20 | mV | | | VFST | Full scale transition voltage | VCC = VREF = 5.12 V | 5105 | 5115 | 5125 | mV | | | tCONV | Conversion time | | | | 122 | tc(XIN) | | | RLADDER | Ladder resistor | | | 55 | | kΩ | | | IVREF | Reference power source input current | VREF = 5.0 V | 50 | 150 | 200 | | | | | | VREF = 3.0 V | 30 | 70 | 120 | μA | | | lı(AD) | A-D port input current | | | | 5.0 | μA | | Fig. 3.1.1 Power source current measurement circuit in USB mode at oscillation stop #### 3.1 Electrical characteristics #### 3.1.5 Timing Requirements Table 3.1.6 Timing requirements (VCC = 4.1 to 5.5 V, Vss = 0 V, Ta = -20 to 85 °C, unless otherwise noted) | Symbol | Parameter | Limits | | | Unit | |-----------------|-------------------------------------------------------------------------------|--------|------|------|-------| | | Parameter | Min. | Тур. | Max. | Uniii | | tw(RESET) | Reset input "L" pulse width | 15 | | | μs | | tc(XIN) | External clock input cycle time | 166 | | | ns | | twh(XIN) | External clock input "H" pulse width | 70 | | | ns | | twL(XIN) | External clock input "L" pulse width | 70 | | | ns | | tc(CNTR) | CNTRo input cycle time | 200 | | | ns | | twH(CNTR) | CNTR <sub>0</sub> , INT <sub>0</sub> , INT <sub>1</sub> input "H" pulse width | 80 | | | ns | | twL(CNTR) | CNTR <sub>0</sub> , INT <sub>0</sub> , INT <sub>1</sub> input "L" pulse width | 80 | | | ns | | tc(Sclk) | Serial I/O2 clock input cycle time | 1000 | | | ns | | twh(Sclk) | Serial I/O2 clock input "H" pulse width | 400 | | | ns | | twL(Sclk) | Serial I/O2 clock input "L" pulse width | 400 | | | ns | | tsu(SDATA-SCLK) | Serial I/O2 input set up time | 200 | | | ns | | th(SCLK-SDATA) | Serial I/O2 input hold time | 200 | | | ns | #### 3.1.6 Switching Characteristics Table 3.1.7 Switching characteristics (Vcc = 4.1 to 5.5 V, Vss = 0 V, Ta = -20 to 85 °C, unless otherwise noted) | Cumbal | Devemates | Lin | Limits | | Unit | |----------------|--------------------------------------------------------------------------------------------|---------------|--------|------|------| | Symbol | Parameter | Min. | Тур. | Max. | Unit | | twh(Sclk) | Serial I/O2 clock output "H" pulse width | tc(Sclk)/2-30 | | | ns | | twL(Sclk) | Serial I/O2 clock output "L" pulse width | tc(Sclk)/2-30 | | | ns | | td(SCLK-SDATA) | Serial I/O2 output delay time | | | 140 | ns | | tv(SCLK-SDATA) | Serial I/O2 output valid time | 0 | | | ns | | tr(SCLK) | Serial I/O2 clock output rising time | | | 30 | ns | | tf(SCLK) | Serial I/O2 clock output falling time | | | 30 | ns | | tr(CMOS) | CMOS output rising time (Note) | | 10 | 30 | ns | | tf(CMOS) | CMOS output falling time (Note) | | 10 | 30 | ns | | tr(D+), tr(D-) | USB output rising time, CL = 200 to 450 pF, Ta = 0 to 70 $^{\circ}$ C, Vcc = 4.4 to 5.25 V | 75 | 150 | 300 | ns | | tf(D+), tf(D-) | USB output falling time, CL = 200 to 450 pF, Ta = 0 to 70 °C, Vcc = 4.4 to 5.25 V | 75 | 150 | 300 | ns | Notes: XOUT pin is excluded. Fig. 3.1.2 Output switching characteristics measurement circuit Fig. 3.1.3 Timing chart ## 3.2 Typical characteristics ## 3.2 Typical characteristics ## 3.2.1 Power source current characteristic example (Icc-Vcc characteristic) Fig. 3.2.1 Icc-Vcc characteristic example (in double-speed mode) Fig. 3.2.2 Icc-Vcc characteristic example (at WIT instruction execution) Fig. 3.2.3 Icc-Vcc characteristic example (At STP instruction execution, Ta = 25 °C) Fig. 3.2.4 Icc-Vcc characteristic example (At STP instruction execution, Ta = 85 °C) ## 3.2 Typical characteristics Fig. 3.2.5 ICC-VCC characteristic example (at USB suspend, Ta = 25 °C) Fig. 3.2.6 ICC-VCC characteristic example (A-D conversion executed/not executed, f(XIN) = 6MHz, in double-speed mode) #### 3.2.2 Von-loh characteristic example Fig. 3.2.7 Voн-loн characteristic example of P-channel (Ta = 25 °C): normal port Fig. 3.2.8 Voн-loн characteristic example of P-channel (Ta = 85 °C): normal port ### 3.2 Typical characteristics Fig. 3.2.9 Vol-lol characteristic example of N-channel (Ta = 25 °C): Normal port Fig. 3.2.10 Vol-lol characteristic example of N-channel (Ta = 85 °C): Normal port Fig. 3.2.11 Vol-lol characteristic example of N-channel (Ta = 25 °C): LED drive port Fig. 3.2.12 Vol-lol characteristic example N-channel (Ta = 85 °C): LED drive port ## 3.2 Typical characteristics Fig. 3.2.13 "L" input current of port at pull-up transistor connected #### 3.2.3 A-D conversion typical characteristics example #### (1) Definition of A-D conversion accuracy The A-D conversion accuracy is defined below (refer to Fig. 3.2.14). #### Relative accuracy - ① Zero transition voltage (VoT) - This means an analog input voltage when the actual A-D conversion output data changes from "0" to "1." - ② Full-scale transition voltage (V<sub>FST</sub>) - This means an analog input voltage when the actual A-D conversion output data changes from "1023" to "1022." - ③ Non-linearity error - This means a deviation from the line between $V_{\text{OT}}$ and $V_{\text{FST}}$ of a converted value between $V_{\text{OT}}$ and $V_{\text{FST}}$ . - 4 Differential non-linearity error - This means a deviation from the input potential difference required to change a converted value between Vot and Vfst by 1 LSB of the 1 LSB at the relative accuracy. #### Absolute accuracy This means a deviation from the ideal characteristics between 0 to VREF of actual A-D conversion characteristics. Fig. 3.2.14 Definition of A-D conversion accuracy Vn: Analog input voltage when the output data changes from "n" to "n + 1" (n = 0 to 1022) - 1 LSB at relative accuracy $\rightarrow \frac{V_{FST} V_{OT}}{1022}$ (V) - 1 LSB at absolute accuracy $\rightarrow \frac{VREF}{1024}$ (V) ## 3.2 Typical characteristics Fig. 3.2.15 A-D conversion typical characteristic example #### 3.3 Notes on use #### 3.3.1 Notes on interrupts #### (1) Switching external interrupt detection edge For the products able to switch the external interrupt detection edge, switch it as the following sequence. Fig. 3.3.1 Sequence of switch the detection edge #### Reason The interrupt circuit recognizes the switching of the detection edge as the change of external input signals. This may cause an unnecessary interrupt. #### (2) Check of interrupt request bit When executing the **BBC** or **BBS** instruction to an interrupt request bit of an interrupt request register immediately after this bit is set to "0" by using a data transfer instruction, execute one or more instructions before executing the **BBC** or **BBS** instruction. Fig. 3.3.2 Sequence of check of interrupt request bit #### Reason If the **BBC** or **BBS** instruction is executed immediately after an interrupt request bit of an interrupt request register is cleared to "0", the value of the interrupt request bit before being cleared to "0" is read. #### 3.3 Notes on use #### (3) Structure of interrupt control register 1 Fix the bit 7 of the interrupt control register 1 to "0". Figure 3.3.3 shows the structure of the interrupt control register 1. Fig. 3.3.3 Structure of interrupt control register 1 #### 3.3.2 Notes on serial I/O #### (1) Handling of serial I/O1 clear When serial I/O1 is set again or the transmit/receive operation is stopped/restarted while serial I/O1 is operating, clear the serial I/O1 as shown in Figure 3.3.4. Fig. 3.3.4 Sequence of clearing serial I/O #### (2) Data transmission control with referring to transmit shift register completion flag The transmit shift register completion flag changes from "1" to "0" with a delay of 0.5 to 1.5 shift clocks. When data transmission is controlled with referring to the flag after writing the data to the transmit buffer register, note the delay. #### (3) Writing transmit data When an external clock is used as the synchronous clock for the clock synchronous serial I/O, write the transmit data to the transmit buffer register (serial I/O shift register) at "H" of the transfer clock input level. #### (4) Serial I/O2 transmit/receive shift completion flag - •The transmit/receive shift completion flag of the serial I/O2 control register is set to "1" after completing transmit/receive shift. In order to set this flag to "0", write data (dummy data at reception) to the serial I/O2 register by program. - •Bit 7 of the serial I/O2 control register is set to "1" a half cycle (of the shift clock) earlier than completion of shift operation. Accordingly, when using this bit to confirm shift completion, a half cycle or more of the shift clock must pass after confirming that this bit is set to "1", before performing read/write to the serial I/O2 register. #### 3.3.3 Notes on A-D converter #### (1) Analog input pin Make the signal source impedance for analog input low, or equip an analog input pin with an external capacitor of $0.01\mu\text{F}$ to $1\mu\text{F}$ . Further, be sure to verify the operation of application products on the user side. #### Reason An analog input pin includes the capacitor for analog voltage comparison. Accordingly, when signals from signal source with high impedance are input to an analog input pin, charge and discharge noise generates. This may cause the A-D conversion precision to be worse. #### (2) Clock frequency during A-D conversion The comparator consists of a capacity coupling, and a charge of the capacity will be lost if the clock frequency is too low. Thus, make sure the following during an A-D conversion. - f(XIN) is 500 kHz or more - Do not execute the STP instruction #### 3.3.4 Notes on RESET pin #### (1) Connecting capacitor In case where the $\overline{\text{RESET}}$ signal rise time is long, connect a ceramic capacitor or others across the $\overline{\text{RESET}}$ pin and the Vss pin. And use a 1000 pF or more capacitor for high frequency use. When connecting the capacitor, note the following : - Make the length of the wiring which is connected to a capacitor as short as possible. - Be sure to verify the operation of application products on the user side. #### Reason If the several nanosecond or several ten nanosecond impulse noise enters the RESET pin, it may cause a microcomputer failure. #### 3.3 Notes on use #### 3.3.5 Notes on input and output pins #### (1) Notes in stand-by state In stand-by state\*1 for low-power dissipation, do not make input levels of an input port and an I/O port "undefined". Pull-up (connect the port to VCC) or pull-down (connect the port to VSS) these ports through a resistor. When determining a resistance value, note the following points: - External circuit - Variation of output levels during the ordinary operation When using built-in pull-up or pull-down resistor, note on varied current values: - When setting as an input port : Fix its input level - When setting as an output port : Prevent current from flowing out to external #### Reason The potential which is input to the input buffer in a microcomputer is unstable in the state that input levels of a input port and an I/O port are "undefined". This may cause power source current. \*1 stand-by state : the stop mode by executing the **STP** instruction the wait mode by executing the **WIT** instruction #### (2) Modifying output data with bit managing instruction When the port latch of an I/O port is modified with the bit managing instruction\*2, the value of the unspecified bit may be changed. #### Reason The bit managing instructions are read-modify-write form instructions for reading and writing data by a byte unit. Accordingly, when these instructions are executed on a bit of the port latch of an I/O port, the following is executed to all bits of the port latch. - As for a bit which is set for an input port : The pin state is read in the CPU, and is written to this bit after bit managing. - As for a bit which is set for an output port : The bit value of the port latch is read in the CPU, and is written to this bit after bit managing. Note the following: - Even when a port which is set as an output port is changed for an input port, its port latch holds the output data. - As for a bit of the port latch which is set for an input port, its value may be changed even when not specified with a bit managing instruction in case where the pin state differs from its port latch contents. <sup>\*2</sup> bit managing instructions: SEB, and CLB instructions #### 3.3.6 Notes on programming #### (1) Processor status register #### ① Initializing of processor status register Flags which affect program execution must be initialized after a reset. In particular, it is essential to initialize the T and D flags because they have an important effect on calculations. #### Reason After a reset, the contents of the processor status register (PS) are undefined except for the I flag which is "1". Fig. 3.3.5 Initialization of processor status register #### 2 How to reference the processor status register To reference the contents of the processor status register (PS), execute the **PHP** instruction once then read the contents of (S+1). If necessary, execute the **PLP** instruction to return the PS to its original status. A NOP instruction should be executed after every PLP instruction. Fig. 3.3.6 Sequence of PLP instruction execution Fig. 3.3.7 Stack memory contents after PHP instruction execution #### 3.3 Notes on use #### (2) Decimal calculations #### 1 Execution of decimal calculations The **ADC** and **SBC** are the only instructions which will yield proper decimal notation, set the decimal mode flag (D) to "1" with the **SED** instruction. After executing the **ADC** or **SBC** instruction, execute another instruction before executing the **SEC**, **CLC**, or **CLD** instruction. #### 2 Notes on status flag in decimal mode When decimal mode is selected, the values of three of the flags in the status register (the N, V, and Z flags) are invalid after a **ADC** or **SBC** instruction is executed. The carry flag (C) is set to "1" if a carry is generated as a result of the calculation, or is cleared to "0" if a borrow is generated. To determine whether a calculation has generated a carry, the C flag must be initialized to "0" before each calculation. To check for a borrow, the C flag must be initialized to "1" before each calculation. Fig. 3.3.8 Status flag at decimal calculations #### (3) JMP instruction When using the **JMP** instruction in indirect addressing mode, do not specify the last address on a page as an indirect address. #### 3.3.7 Programming and test of built-in PROM version As for in the One Time PROM version (shipped in blank), its built-in PROM can be read or programmed with a general-purpose PROM programmer using a special programming adapter. The programming test and screening for PROM of the One Time PROM version (shipped in blank) are not performed in the assembly process and the following processes. To ensure reliability after programming, performing programming and test according to the Figure 3.3.9 before actual use are recommended. Fig. 3.3.9 Programming and testing of One Time PROM version #### 3.3.8 Notes on built-in PROM version #### (1) Programming adapter Use a special programming adapter shown in Table 3.3.1 and a general-purpose PROM programmer when reading from or programming to the built-in PROM in the built-in PROM version. Table 3.3.1 Programming adapters | Microcomputer | Programming adapter | |-----------------------------------------------------|------------------------| | M37534E8GP (One Time PROM version shipped in blank) | PCA7435GP, PCA7435GP02 | | M37534E8SP (One Time PROM version shipped in blank) | PCA7435SP, PCA7435SP02 | | M37534E8FP (One Time PROM version shipped in blank) | PCA7435FP, PCA7435FP02 | #### 3.3 Notes on use #### (2) Programming/reading In PROM mode, operation is the same as that of the M5M27C101AK, but programming conditions of PROM programmer are not set automatically because there are no internal device ID codes. Accurately set the following conditions for data programming /reading. Take care not to apply 21 V to VPP pin (is also used as the CNVss pin), or the product may be permanently damaged. - Programming voltage: 12.5 V - Setting of PROM programmer switch: refer to Table 3.3.2. Table 3.3.2 PROM programmer address setting | Product name format | PROM programmer start address | PROM programmer end address | |---------------------|-----------------------------------|----------------------------------| | M37534E8GP | Address 0E08016 ( <b>Note 1</b> ) | Address 0FFFD16 (Note 1) | | M37534E8SP | Address 0C08016 ( <b>Note 2</b> ) | Address 0FFFD16 ( <b>Note</b> 2) | | M37534E8FP | Address 0000016 (Note 2) | Address of Fibit (Note 2) | - **Notes 1:** Addersses E08016 to FFFD16 in the built-in PROM corresponds to addresses 0E08016 to 0FFFD16 in the PROM programmer. - 2: Addersses C08016 to FFFD16 in the built-in PROM corresponds to addresses 0C08016 to 0FFFD16 in the PROM programmer. #### 3.3.9 Termination of unused pins #### (1) Terminate unused pins ① Output ports : Open #### 2 Input ports: Connect each pin to VCC or Vss through each resistor of 1 k $\Omega$ to 10 k $\Omega$ . Ports that permit the selecting of a built-in pull-up resistor can also use this resistor. As for pins whose potential affects to operation modes such as pins CNVss, INT or others, select the Vcc pin or the Vss pin according to their operation mode. #### 3 I/O ports: • Set the I/O ports for the input mode and connect them to Vcc or Vss through each resistor of 1 k $\Omega$ to 10 k $\Omega$ . Ports that permit the selecting of a built-in pull-up resistor can also use this resistor. Set the I/O ports for the output mode and open them at "L" or "H". - When opening them in the output mode, the input mode of the initial status remains until the mode of the ports is switched over to the output mode by the program after reset. Thus, the potential at these pins is undefined and the power source current may increase in the input mode. With regard to an effects on the system, thoroughly perform system evaluation on the user side. - Since the direction register setup may be changed because of a program runaway or noise, set direction registers by program periodically to increase the reliability of program. #### (2) Termination remarks ① Input ports and I/O ports: Do not open in the input mode. #### Reason - The power source current may increase depending on the first-stage circuit. - An effect due to noise may be easily produced as compared with proper termination ② and ③ shown on the above. #### 2 I/O ports: When setting for the input mode, do not connect to VCC or VSS directly. #### Reason If the direction register setup changes for the output mode because of a program runaway or noise, a short circuit may occur between a port and Vcc (or Vss). #### 3 I/O ports: When setting for the input mode, do not connect multiple ports in a lump to VCC or Vss through a resistor. #### Reason If the direction register setup changes for the output mode because of a program runaway or noise, a short circuit may occur between ports. • At the termination of unused pins, perform wiring at the shortest possible distance (20 mm or less) from microcomputer pins. #### 3.3 Notes on use #### 3.3.10 Notes on CPU mode register #### (1) Switching method of CPU mode register after releasing reset Switch the CPU mode register (CPUM) at the head of program after releasing reset in the following method. Fig. 3.3.10 Switching method of CPU mode register #### 3.3.11 Notes on using 32-pin version - Do not change the P35, P36 pull-up control bit of the pull-up control register from the initial value "1". - Do not write to "1" to the serial I/O1 or INT1 interrupt selection bit of the interrupt edge selection register. ## 3.4 Countermeasures against noise #### 3.4.1 Shortest wiring length #### (1) Package Select the smallest possible package to make the total wiring length short. #### Reason The wiring length depends on a microcomputer package. Use of a small package, for example QFP and not DIP, makes the total wiring length short to reduce influence of noise. Fig. 3.4.1 Selection of packages #### (2) Wiring for RESET pin Make the length of wiring which is connected to the $\overline{\mathsf{RESET}}$ pin as short as possible. Especially, connect a capacitor across the $\overline{\mathsf{RESET}}$ pin and the Vss pin with the shortest possible wiring (within 20mm). #### Reason The width of a pulse input into the RESET pin is determined by the timing necessary conditions. If noise having a shorter pulse width than the standard is input to the RESET pin, the reset is released before the internal state of the microcomputer is completely initialized. This may cause a program runaway. Fig. 3.4.2 Wiring for the RESET pin ### 3.4 Countermeasures against noise #### (3) Wiring for clock input/output pins - Make the length of wiring which is connected to clock I/O pins as short as possible. - Make the length of wiring (within 20mm) across the grounding lead of a capacitor which is connected to an oscillator and the Vss pin of a microcomputer as short as possible. - Separate the Vss pattern only for oscillation from other Vss patterns. #### Reason If noise enters clock I/O pins, clock waveforms may be deformed. This may cause a program failure or program runaway. Also, if a potential difference is caused by the noise between the Vss level of a microcomputer and the Vss level of an oscillator, the correct clock will not be input in the microcomputer. Fig. 3.4.3 Wiring for clock I/O pins #### (4) Wiring to CNVss pin Connect the CNVss pin to the Vss pin with the shortest possible wiring. #### Reason The processor mode of a microcomputer is influenced by a potential at the CNVss pin. If a potential difference is caused by the noise between pins CNVss and Vss, the processor mode may become unstable. This may cause a microcomputer malfunction or a program runaway. Fig. 3.4.4 Wiring for CNVss pin #### (5) Wiring to VPP pin of One Time PROM version Connect an approximately 5 $k\Omega$ resistor to the VPP pin the shortest possible in series and also to the Vss pin. When not connecting the resistor, make the length of wiring between the VPP pin and the Vss pin the shortest possible. **Note:** Even when a circuit which included an approximately 5 $k\Omega$ resistor is used in the Mask ROM version, the microcomputer operates correctly. #### Reason The VPP pin of the One Time PROM is the power source input pin for the built-in PROM. When programming in the built-in PROM, the impedance of the VPP pin is low to allow the electric current for writing flow into the PROM. Because of this, noise can enter easily. If noise enters the VPP pin, abnormal instruction codes or data are read from the built-in PROM, which may cause a program runaway. Fig. 3.4.5 Wiring for the VPP pin of the One Time PROM #### 3.4.2 Connection of bypass capacitor across Vss line and Vcc line Connect an approximately 1.0 $\mu$ F bypass capacitor across the Vss line and the Vcc line as follows: - Connect a bypass capacitor across the Vss pin and the Vcc pin at equal length. - Connect a bypass capacitor across the Vss pin and the Vcc pin with the shortest possible wiring. - Use lines with a larger diameter than other signal lines for Vss line and Vcc line. - Connect the power source wiring via a bypass capacitor to the Vss pin and the Vcc pin. Fig. 3.4.6 Bypass capacitor across the Vss line and the Vcc line ### 3.4 Countermeasures against noise #### 3.4.3 Wiring to analog input pins - Connect an approximately 100 $\Omega$ to 1 k $\Omega$ resistor to an analog signal line which is connected to an analog input pin in series. Besides, connect the resistor to the microcomputer as close as possible. - Connect an approximately 1000 pF capacitor across the Vss pin and the analog input pin. Besides, connect the capacitor to the Vss pin as close as possible. Also, connect the capacitor across the analog input pin and the Vss pin at equal length. #### Reason Signals which is input in an analog input pin (such as an A-D converter/comparator input pin) are usually output signals from sensor. The sensor which detects a change of event is installed far from the printed circuit board with a microcomputer, the wiring to an analog input pin is longer necessarily. This long wiring functions as an antenna which feeds noise into the microcomputer, which causes noise to an analog input pin. If a capacitor between an analog input pin and the Vss pin is grounded at a position far away from the Vss pin, noise on the GND line may enter a microcomputer through the capacitor. Fig. 3.4.7 Analog signal line and a resistor and a capacitor #### 3.4.4 Oscillator concerns Take care to prevent an oscillator that generates clocks for a microcomputer operation from being affected by other signals. #### (1) Keeping oscillator away from large current signal lines Install a microcomputer (and especially an oscillator) as far as possible from signal lines where a current larger than the tolerance of current value flows. #### Reason In the system using a microcomputer, there are signal lines for controlling motors, LEDs, and thermal heads or others. When a large current flows through those signal lines, strong noise occurs because of mutual inductance. Fig. 3.4.8 Wiring for a large current signal line #### (2) Installing oscillator away from signal lines where potential levels change frequently Install an oscillator and a connecting pattern of an oscillator away from signal lines where potential levels change frequently. Also, do not cross such signal lines over the clock lines or the signal lines which are sensitive to noise. #### Reason Signal lines where potential levels change frequently (such as the CNTR pin signal line) may affect other lines at signal rising edge or falling edge. If such lines cross over a clock line, clock waveforms may be deformed, which causes a microcomputer failure or a program runaway. Fig. 3.4.9 Wiring of signal lines where potential levels change frequently #### (3) Oscillator protection using Vss pattern As for a two-sided printed circuit board, print a Vss pattern on the underside (soldering side) of the position (on the component side) where an oscillator is mounted. Connect the Vss pattern to the microcomputer Vss pin with the shortest possible wiring. Besides, separate this Vss pattern from other Vss patterns. Fig. 3.4.10 Vss pattern on the underside of an oscillator ### 3.4 Countermeasures against noise #### 3.4.5 Setup for I/O ports Setup I/O ports using hardware and software as follows: #### <Hardware> • Connect a resistor of 100 $\Omega$ or more to an I/O port in series. #### <Software> - As for an input port, read data several times by a program for checking whether input levels are equal or not. - As for an output port, since the output data may reverse because of noise, rewrite data to its port latch at fixed periods. - Rewrite data to direction registers and pull-up control registers at fixed periods. **Note:** When a direction register is set for <u>input port</u> again at fixed periods, a several-nanosecond short pulse may be output from this port. If this is undesirable, connect a capacitor to this port to remove the noise pulse. Fig. 3.4.11 Setup for I/O ports #### 3.4.6 Providing of watchdog timer function by software If a microcomputer runs away because of noise or others, it can be detected by a software watchdog timer and the microcomputer can be reset to normal operation. This is equal to or more effective than program runaway detection by a hardware watchdog timer. The following shows an example of a watchdog timer provided by software. In the following example, to reset a microcomputer to normal operation, the main routine detects errors of the interrupt processing routine and the interrupt processing routine detects errors of the main routine. This example assumes that interrupt processing is repeated multiple times in a single main routine processing. #### <The main routine> - Assigns a single byte of RAM to a software watchdog timer (SWDT) and writes the initial value N in the SWDT once at each execution of the main routine. The initial value N should satisfy the following condition: - $N+1 \ge$ (Counts of interrupt processing executed in each main routine) - As the main routine execution cycle may change because of an interrupt processing or others, the initial value N should have a margin. - Watches the operation of the interrupt processing routine by comparing the SWDT contents with counts of interrupt processing after the initial value N has been set. - Detects that the interrupt processing routine has failed and determines to branch to the program initialization routine for recovery processing in the following case: If the SWDT contents do not change after interrupt processing. #### <The interrupt processing routine> - Decrements the SWDT contents by 1 at each interrupt processing. - Determines that the main routine operates normally when the SWDT contents are reset to the initial value N at almost fixed cycles (at the fixed interrupt processing count). - Detects that the main routine has failed and determines to branch to the program initialization routine for recovery processing in the following case: If the SWDT contents are not initialized to the initial value N but continued to decrement and if they reach 0 or less. Fig. 3.4.12 Watchdog timer by software ## 3.5 List of registers Fig. 3.5.1 Structure of Port Pi (i = 0 to 4) Fig. 3.5.2 Structure of Port Pi direction register (i = 0 to 4) | | Pι | III-up control register (PULL) [A | ddress : 16 <sub>16</sub> ] | | | | |-------|----|-------------------------------------------------------------------------------------------------|-----------------------------------|----------|---|---| | | В | Name | Function | At reset | R | W | | | 0 | P0 <sub>0</sub> pull-up control bit | 0 : Pull-up Off<br>1 : Pull-up On | 1 | 0 | 0 | | | 1 | P0 <sub>1</sub> pull-up control bit | 0 : Pull-up Off<br>1 : Pull-up On | 1 | 0 | 0 | | | 2 | P02, P03 pull-up control bit | 0 : Pull-up Off<br>1 : Pull-up On | 1 | 0 | 0 | | | 3 | P04 – P07 pull-up control bit | 0 : Pull-up Off<br>1 : Pull-up On | 1 | 0 | 0 | | | 4 | P3 <sub>0</sub> – P3 <sub>3</sub> pull-up control bit | 0 : Pull-up Off<br>1 : Pull-up On | 1 | 0 | 0 | | | 5 | P3 <sub>4</sub> pull-up control bit | 0 : Pull-up Off<br>1 : Pull-up On | 1 | 0 | 0 | | | 6 | P35, P36 pull-up control bit (Note 2) | 0 : Pull-up Off<br>1 : Pull-up On | 1 | 0 | 0 | | Ĺ<br> | 7 | P37 pull-up control bit (Note 3) | 0 : Pull-up Off<br>1 : Pull-up On | 1 | 0 | 0 | | | No | tes 1: Pins set to output are dis<br>2: • 36-pin version: P36 is r<br>• 32-pin version: Not use | | | | | Fig. 3.5.3 Structure of Pull-up control register Fig. 3.5.4 Structure of Port P1P3 control register Fig. 3.5.5 Structure of Transmit/Receive buffer register Fig. 3.5.6 Structure of UART status register Fig. 3.5.7 Structure of USB status register Fig. 3.5.8 Structure of Serial I/O1 control register Fig. 3.5.9 Structure of UART control register Fig. 3.5.10 Structure of Baud rate generator Fig. 3.5.11 Structure of USB data toggle synchronization register Fig. 3.5.12 Structure of USB interrupt source discrimination register 1 #### 3.5 List of registers Fig. 3.5.13 Structure of USB interrupt source discrimination register 2 Fig. 3.5.14 Structure of USB interrupt control register Fig. 3.5.15 Structure of USB transmit data byte number set register 0 Fig. 3.5.16 Structure of USB transmit data byte number set register 1 Fig. 3.5.17 Structure of USB PID control register 0 ### 3.5 List of registers Fig. 3.5.18 Structure of USB PID control register 1 Fig. 3.5.19 Structure of USB address register Fig. 3.5.20 Structure of USB sequence bit initialization register Fig. 3.5.21 Structure of USB control register Fig. 3.5.22 Structure of Prescaler 12, Prescaler X Fig. 3.5.23 Structure of Timer 1 Fig. 3.5.24 Structure of Timer 2 Fig. 3.5.25 Structure of Timer X mode register Table 3.5.1 CNTR<sub>0</sub> active edge switch bit function | Timer X operation modes | | CNTR <sub>0</sub> active edge switch bit (bit 2 of address 2B <sub>16</sub> ) contents | |------------------------------|-----|----------------------------------------------------------------------------------------| | Timer mode | "0" | CNTR₀ interrupt request occurrence: Falling edge | | | | ; No influence to timer count | | | "1" | CNTR <sub>0</sub> interrupt request occurrence: Rising edge | | | | ; No influence to timer count | | Pulse output mode | "0" | Pulse output start: Beginning at "H" level | | | | CNTR <sub>0</sub> interrupt request occurrence: Falling edge | | | "1" | Pulse output start: Beginning at "L" level | | | | CNTR <sub>0</sub> interrupt request occurrence: Rising edge | | Event counter mode | "0" | Timer X: Rising edge count | | | | CNTR <sub>0</sub> interrupt request occurrence: Falling edge | | | "1" | Timer X: Falling edge count | | | | CNTR <sub>0</sub> interrupt request occurrence: Rising edge | | Pulse width measurement mode | "0" | Timer X: "H" level width measurement | | | | CNTR <sub>0</sub> interrupt request occurrence: Falling edge | | | "1" | Timer X: "L" level width measurement | | | | CNTR <sub>0</sub> interrupt request occurrence: Rising edge | Fig. 3.5.26 Structure of Timer X Fig. 3.5.27 Structure of Timer count source set register Fig. 3.5.28 Structure of Serial I/O2 control register Fig. 3.5.29 Structure of Serial I/O2 register Fig. 3.5.30 Structure of A-D control register Fig. 3.5.31 Structure of A-D conversion register (high-order) Fig. 3.5.32 Structure of A-D conversion register (low-order) Fig. 3.5.33 Structure of MISRG Fig. 3.5.34 Structure of Watchdog timer control register Fig. 3.5.35 Structure of Interrupt edge selection register Fig. 3.5.36 Structure of CPU mode register | | l in | terrupt request register 1 (IREQ1 | ) [Address: 3C 16] | | | | |--|------|---------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------|----------|---|---| | | В | Name | Function | At reset | R | W | | | 0 | UART receive/USBIN token interrupt request bit | 0 : No interrupt request issued 1 : Interrupt request issued | 0 | 0 | * | | | - 1 | UART transmit/USBSETUP/<br>OUT token/Reset/Suspend/<br>Resume/INT <sub>1</sub> interrupt<br>request bit ( <b>Note 1</b> ) | 0 : No interrupt request issued 1 : Interrupt request issued | 0 | 0 | * | | | 2 | INTo interrupt request bit (Note 2) | 0 : No interrupt request issued 1 : Interrupt request issued | 0 | 0 | * | | | 3 | Timer X or key-on wake up interrupt request bit | 0 : No interrupt request issued 1 : Interrupt request issued | 0 | 0 | * | | | 4 | Timer 1 interrupt request bit | 0 : No interrupt request issued 1 : Interrupt request issued | 0 | 0 | * | | | - 5 | Timer 2 or serial I/O2 interrupt request bit | 0 : No interrupt request issued 1 : Interrupt request issued | 0 | 0 | * | | | - 6 | CNTR <sub>0</sub> or AD converter interrupt request bit | 0 : No interrupt request issued 1 : Interrupt request issued | 0 | 0 | * | | | 7 | Nothing is allocated for this bit.<br>When this bit is read out, the va | | 0 | 0 | × | Fig. 3.5.37 Structure of Interrupt request register 1 Fig. 3.5.38 Structure of Interrupt control register 1 # 3.6 Package outline ## 42P4B Plastic 42pin 600mil SDIP ### 36P2R-A Plastic 36pin 450mil SSOP # 3.7 List of instruction code | | D3 - D0 | 0000 | 0001 | 0010 | 0011 | 0100 | 0101 | 0110 | 0111 | 1000 | 1001 | 1010 | 1011 | 1100 | 1101 | <b>1</b> 110 | 1111 | |---------|----------------------|------------|---------------|----------------|-------------|--------------|--------------|--------------|--------------|------|---------------|----------|-------------|---------------|---------------|---------------|--------------| | D7 - D4 | lexadecimal notation | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | А | В | С | D | E | F | | 0000 | 0 | BRK | ORA<br>IND, X | JSR<br>ZP, IND | BBS<br>0, A | _ | ORA<br>ZP | ASL<br>ZP | BBS<br>0, ZP | PHP | ORA<br>IMM | ASL<br>A | SEB<br>0, A | _ | ORA<br>ABS | ASL<br>ABS | SEB<br>0, ZP | | 0001 | 1 | BPL | ORA<br>IND, Y | CLT | BBC<br>0, A | ı | ORA<br>ZP, X | ASL<br>ZP, X | BBC<br>0, ZP | CLC | ORA<br>ABS, Y | DEC<br>A | CLB<br>0, A | _ | ORA<br>ABS, X | ASL<br>ABS, X | CLB<br>0, ZP | | 0010 | 2 | JSR<br>ABS | AND<br>IND, X | JSR<br>SP | BBS<br>1, A | BIT<br>ZP | AND<br>ZP | ROL<br>ZP | BBS<br>1, ZP | PLP | AND<br>IMM | ROL<br>A | SEB<br>1, A | BIT<br>ABS | AND<br>ABS | ROL<br>ABS | SEB<br>1, ZP | | 0011 | 3 | ВМІ | AND<br>IND, Y | SET | BBC<br>1, A | - | AND<br>ZP, X | ROL<br>ZP, X | BBC<br>1, ZP | SEC | AND<br>ABS, Y | INC<br>A | CLB<br>1, A | LDM<br>ZP | AND<br>ABS, X | ROL<br>ABS, X | CLB<br>1, ZP | | 0100 | 4 | RTI | EOR<br>IND, X | STP | BBS<br>2, A | COM<br>ZP | EOR<br>ZP | LSR<br>ZP | BBS<br>2, ZP | PHA | EOR<br>IMM | LSR<br>A | SEB<br>2, A | JMP<br>ABS | EOR<br>ABS | LSR<br>ABS | SEB<br>2, ZP | | 0101 | 5 | BVC | EOR<br>IND, Y | _ | BBC<br>2, A | _ | EOR<br>ZP, X | LSR<br>ZP, X | BBC<br>2, ZP | CLI | EOR<br>ABS, Y | ı | CLB<br>2, A | _ | EOR<br>ABS, X | LSR<br>ABS, X | CLB<br>2, ZP | | 0110 | 6 | RTS | ADC<br>IND, X | _ | BBS<br>3, A | TST<br>ZP | ADC<br>ZP | ROR<br>ZP | BBS<br>3, ZP | PLA | ADC<br>IMM | ROR<br>A | SEB<br>3, A | JMP<br>IND | ADC<br>ABS | ROR<br>ABS | SEB<br>3, ZP | | 0111 | 7 | BVS | ADC<br>IND, Y | _ | BBC<br>3, A | _ | ADC<br>ZP, X | ROR<br>ZP, X | BBC<br>3, ZP | SEI | ADC<br>ABS, Y | ı | CLB<br>3, A | _ | ADC<br>ABS, X | ROR<br>ABS, X | CLB<br>3, ZP | | 1000 | 8 | BRA | STA<br>IND, X | RRF<br>ZP | BBS<br>4, A | STY<br>ZP | STA<br>ZP | STX<br>ZP | BBS<br>4, ZP | DEY | _ | TXA | SEB<br>4, A | STY<br>ABS | STA<br>ABS | STX<br>ABS | SEB<br>4, ZP | | 1001 | 9 | всс | STA<br>IND, Y | _ | BBC<br>4, A | STY<br>ZP, X | STA<br>ZP, X | STX<br>ZP, Y | BBC<br>4, ZP | TYA | STA<br>ABS, Y | TXS | CLB<br>4, A | _ | STA<br>ABS, X | _ | CLB<br>4, ZP | | 1010 | А | LDY<br>IMM | LDA<br>IND, X | LDX<br>IMM | BBS<br>5, A | LDY<br>ZP | LDA<br>ZP | LDX<br>ZP | BBS<br>5, ZP | TAY | LDA<br>IMM | TAX | SEB<br>5, A | LDY<br>ABS | LDA<br>ABS | LDX<br>ABS | SEB<br>5, ZP | | 1011 | В | BCS | LDA<br>IND, Y | JMP<br>ZP, IND | BBC<br>5, A | LDY<br>ZP, X | LDA<br>ZP, X | LDX<br>ZP, Y | BBC<br>5, ZP | CLV | LDA<br>ABS, Y | TSX | CLB<br>5, A | LDY<br>ABS, X | LDA<br>ABS, X | LDX<br>ABS, Y | CLB<br>5, ZP | | 1100 | С | CPY<br>IMM | CMP<br>IND, X | WIT | BBS<br>6, A | CPY<br>ZP | CMP<br>ZP | DEC<br>ZP | BBS<br>6, ZP | INY | CMP<br>IMM | DEX | SEB<br>6, A | CPY<br>ABS | CMP<br>ABS | DEC<br>ABS | SEB<br>6, ZP | | 1101 | D | BNE | CMP<br>IND, Y | _ | BBC<br>6, A | _ | CMP<br>ZP, X | DEC<br>ZP, X | BBC<br>6, ZP | CLD | CMP<br>ABS, Y | _ | CLB<br>6, A | _ | CMP<br>ABS, X | DEC<br>ABS, X | CLB<br>6, ZP | | 1110 | Е | CPX<br>IMM | SBC<br>IND, X | _ | BBS<br>7, A | CPX<br>ZP | SBC<br>ZP | INC<br>ZP | BBS<br>7, ZP | INX | SBC<br>IMM | NOP | SEB<br>7, A | CPX<br>ABS | SBC<br>ABS | INC<br>ABS | SEB<br>7, ZP | | 1111 | F | BEQ | SBC<br>IND, Y | _ | BBC<br>7, A | _ | SBC<br>ZP, X | INC<br>ZP, X | BBC<br>7, ZP | SED | SBC<br>ABS, Y | _ | CLB<br>7, A | _ | SBC<br>ABS, X | INC<br>ABS, X | CLB<br>7, ZP | | : 3-byte instruction | n | |----------------------|---| |----------------------|---| : 2-byte instruction : 1-byte instruction ## 3.8 Machine instructions | | | | | | | | | | Α. | Addr | essi | ng r | mod | e | | | | | | | |-----------------------|----------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|-----|---|----|-----|---|----|------|------|-------------------|------|-----|----|----|---|-------------------|------|------| | Symbol | Function | Details | | IMP | | | IMN | 1 | | Α | | ВΙ | Г, А | , R | | ΖP | | віт | , ZP | ', R | | | | | OP | n | # | OP | n | # | OP | n | # | OP | n | # | OP | n | # | OP | n | # | | ADC (Note 1) (Note 5) | When T = 0<br>$A \leftarrow A + M + C$<br>When T = 1<br>$M(X) \leftarrow M(X) + M + C$ | When T = 0, this instruction adds the contents M, C, and A; and stores the results in A and C. When T = 1, this instruction adds the contents of M(X), M and C; and stores the results in M(X) and C. When T=1, the contents of A remain unchanged, but the contents of status flags are changed. M(X) represents the contents of memory where is indicated by X. | | | | 69 | 2 | 2 | | | | | | | 65 | 3 | 2 | | | | | AND<br>(Note 1) | When T = 0<br>$A \leftarrow A \land M$<br>When T = 1<br>$M(X) \leftarrow M(X) \land M$ | When T = 0, this instruction transfers the contents of A and M to the ALU which performs a bit-wise AND operation and stores the result back in A. When T = 1, this instruction transfers the contents M(X) and M to the ALU which performs a bit-wise AND operation and stores the results back in M(X). When T = 1, the contents of A remain unchanged, but status flags are changed. M(X) represents the contents of memory where is indicated by X. | | | | 29 | 2 | 2 | | | | | | | 25 | 3 | 2 | | | | | ASL | 7 0 □ ← 0 | This instruction shifts the content of A or M by one bit to the left, with bit 0 always being set to 0 and bit 7 of A or M always being contained in C. | | | | | | | 0A | 2 | 1 | | | | 06 | 5 | 2 | | | | | BBC<br>(Note 4) | Ai or Mi = 0? | This instruction tests the designated bit i of M or A and takes a branch if the bit is 0. The branch address is specified by a relative address. If the bit is 1, next instruction is executed. | | | | | | | | | | 1 <u>3</u><br>20i | 4 | 2 | | | | 1 <u>7</u><br>20i | 5 | 3 | | BBS<br>(Note 4) | Ai or Mi = 1? | This instruction tests the designated bit i of the M or A and takes a branch if the bit is 1. The branch address is specified by a relative address. If the bit is 0, next instruction is executed. | | | | | | | | | | 03<br>20i | 4 | 2 | | | | 07<br>20i | 5 | 3 | | BCC<br>(Note 4) | C = 0? | This instruction takes a branch to the appointed address if C is 0. The branch address is specified by a relative address. If C is 1, the next instruction is executed. | | | | | | | | | | | | | | | | | | | | BCS<br>(Note 4) | C = 1? | This instruction takes a branch to the appointed address if C is 1. The branch address is specified by a relative address. If C is 0, the next instruction is executed. | | | | | | | | | | | | | | | | | | | | BEQ<br>(Note 4) | Z = 1? | This instruction takes a branch to the appointed address when Z is 1. The branch address is specified by a relative address. If Z is 0, the next instruction is executed. | | | | | | | | | | | | | | | | | | | | BIT | A ^ M | This instruction takes a bit-wise logical AND of A and M contents; however, the contents of A and M are not modified. The contents of N, V, Z are changed, but the contents of A, M remain unchanged. | | | | | | | | | | | | | 24 | 3 | 2 | | | | | BMI<br>(Note 4) | N = 1? | This instruction takes a branch to the appointed address when N is 1. The branch address is specified by a relative address. If N is 0, the next instruction is executed. | | | | | | | | | | | | | | | | | | | | BNE<br>(Note 4) | Z = 0? | This instruction takes a branch to the appointed address if Z is 0. The branch address is specified by a relative address. If Z is 1, the next instruction is executed. | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Ac | ldre | ssi | ng r | noc | de | | | | | | | | | | | | | | | F | roc | esso | or st | atus | s reç | giste | r | |----|-------|---|----|-----|--------|-----|----|-----|---|----|----|-----|----|----|-----|------|-----|------|-----|----|------|---|-----|-----|---|----|-----|---|----|-----|---|----|----|---|----|-----|------|-------|------|-------|-------|---| | Z | ZP, 2 | X | Ι. | ZP, | Υ | | , | ABS | 3 | А | BS | , X | А | BS | , Y | | IN | D | T | ZP | , IN | D | II. | ND, | X | 11 | ND, | Υ | | REL | | | SP | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | OP | | _ | OF | _ | $\top$ | # ( | OP | | _ | OF | _ | _ | OF | 1 | _ | OP | _ | | + | ЭP | | | OP | | _ | OP | 1 | | OP | _ | _ | OP | | # | N | ٧ | Т | В | D | ı | Z | С | | 75 | 4 | 2 | | | | | 6D | 4 | 3 | 7D | 5 | 3 | 79 | 5 | 3 | | | | | | | | 61 | 6 | 2 | 71 | 6 | 2 | | | | | | | N | V | • | • | • | • | Z | С | | 35 | 4 | 2 | | | | | 2D | 4 | 3 | 3D | 5 | 3 | 39 | 5 | 3 | | | | | | | | 21 | 6 | 2 | 31 | 6 | 2 | | | | | | | N | • | • | • | • | • | Z | • | | 16 | 6 | 2 | | | | | 0E | 6 | 3 | 1E | 7 | 3 | | | | | | | | | | | | | | | | | | | | | | | N | • | • | • | • | • | Z | С | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | • | • | • | • | • | • | • | • | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | • | • | • | • | • | • | • | • | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 90 | 2 | 2 | | | | • | • | • | • | • | • | • | • | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | В0 | 2 | 2 | | | | • | • | • | • | • | • | • | • | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | F0 | 2 | 2 | | | | • | • | • | • | • | • | • | • | | | | | | | | | 2C | 4 | 3 | | | | | | | | | | | | | | | | | | | | | | | | | | М7 | M6 | • | • | • | • | Z | • | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 30 | | | | | | • | • | • | • | • | • | • | • | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | D0 | 2 | 2 | | | | • | • | • | • | • | • | • | • | | | | | | | | | | | | Addr | essi | ing ı | mod | e | | | | | | |-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|-----|---|----|-----|---|----|------|------|-------------------|------|---|----|----|---|-------------------|-------| | Symbol | Function | Details | | IMF | • | | IMN | 1 | | Α | | В | SIT, | A | | ΖP | | ВІ | T, ZF | | | | | OP | n | # | OF | n | # | OР | n | # | OP | n | # | OP | n | # | OP | n | | BPL<br>(Note 4) | N = 0? | This instruction takes a branch to the appointed address if N is 0. The branch address is specified by a relative address. If N is 1, the next instruction is executed. | | | | | | | | | | | | | | | | | | | BRA | PC ← PC ± offset | This instruction branches to the appointed address. The branch address is specified by a relative address. | | | | | | | | | | | | | | | | | | | BRK | $\begin{split} B \leftarrow 1 \\ (PC) \leftarrow (PC) + 2 \\ M(S) \leftarrow PCH \\ S \leftarrow S - 1 \\ M(S) \leftarrow PCL \\ S \leftarrow S - 1 \\ M(S) \leftarrow PCS \\ S \leftarrow S - 1 \\ I \leftarrow 1 \\ PCL \leftarrow ADL \\ PCH \leftarrow ADH \end{split}$ | When the BRK instruction is executed, the CPU pushes the current PC contents onto the stack. The BADRS designated in the interrupt vector table is stored into the PC. | 00 | 7 | 1 | | | | | | | | | | | | | | | | BVC<br>(Note 4) | V = 0? | This instruction takes a branch to the appointed address if V is 0. The branch address is specified by a relative address. If V is 1, the next instruction is executed. | | | | | | | | | | | | | | | | | | | BVS<br>(Note 4) | V = 1? | This instruction takes a branch to the appointed address when V is 1. The branch address is specified by a relative address. When V is 0, the next instruction is executed. | | | | | | | | | | | | | | | | | | | CLB | Ai or Mi ← 0 | This instruction clears the designated bit i of A or M. | | | | | | | | | | 1 <u>В</u><br>20і | 2 | 1 | | | | 1 <u>F</u><br>20i | 5 | | CLC | C ← 0 | This instruction clears C. | 18 | 2 | 1 | | | | | | | | | | | | | | | | CLD | D ← 0 | This instruction clears D. | D8 | 2 | 1 | | | | | | | | | | | | | | | | CLI | I ← 0 | This instruction clears I. | 58 | 2 | 1 | | | | | | | | | | | | | | | | CLT | T ← 0 | This instruction clears T. | 12 | 2 | 1 | | | | | | | | | | | | | | | | CLV | V ← 0 | This instruction clears V. | В8 | 2 | 1 | | | | | | | | | | | | | | | | CMP<br>(Note 3) | When T = 0<br>A - M<br>When T = 1<br>M(X) - M | When T = 0, this instruction subtracts the contents of M from the contents of A. The result is not stored and the contents of A or M are not modified. When T = 1, the CMP subtracts the contents of M from the contents of M(X). The result is not stored and the contents of X, M, and A are not modified. $M(X) \ \ represents \ the \ contents \ of \ memory \ where is indicated by X.$ | | | | C9 | 2 | 2 | | | | | | | C5 | 3 | 2 | | | | СОМ | $M \leftarrow M$ | This instruction takes the one's complement of the contents of M and stores the result in M. | | | | | | | | | | | | | 44 | 5 | 2 | | | | CPX | X – M | This instruction subtracts the contents of M from the contents of X. The result is not stored and the contents of X and M are not modified. | | | | ΕO | 2 | 2 | | | | | | | E4 | 3 | 2 | | | | CPY | Y – M | This instruction subtracts the contents of M from the contents of Y. The result is not stored and the contents of Y and M are not modified. | | | | Co | 2 | 2 | | | | | | | C4 | 3 | 2 | | | | DEC | A ← A − 1 or<br>M ← M − 1 | This instruction subtracts 1 from the contents of A or M. | | | | | | | 1A | 2 | 1 | | | | C6 | 5 | 2 | | | | Г | | | | | | | | | | | | | | Ad | dres | sin | g mo | ode | | | | | | | | | | | | | | | F | roc | esso | or st | atus | s reg | giste | er | |----|-------|---|----|-------|---|----|-----|---|----|-----|---|----|-----|----|------|-----|------|-----|-------|----|-----|-----|---|----|-----|---|----|-----|---|----|----|---|---|-----|------|-------|------|-------|-------|----------| | | ZP, ) | X | 7 | ZP, ` | Y | | ABS | 3 | А | BS, | Х | А | BS, | | ı — | IND | | | P, IN | ID | II. | ND, | X | IN | ND, | Υ | | REL | | | SP | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | OP | | _ | OP | т — | | ОР | _ | _ | - | _ | 1 | - | _ | | OP | _ | _ | - | | r | _ | _ | | OP | _ | _ | _ | | _ | ОР | 1 | # | N | V | Т | В | D | ı | z | $\vdash$ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 10 | | | | | | • | • | • | • | • | • | • | • | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 80 | 4 | 2 | | | | • | • | • | • | • | • | • | • | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | • | • | • | 1 | • | 1 | • | • | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 50 | 2 | 2 | | | | • | • | • | • | • | • | • | • | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 70 | 2 | 2 | | | | • | • | • | • | • | • | • | • | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | • | • | • | • | • | • | • | • | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | • | • | • | • | • | • | • | 0 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | • | • | • | • | 0 | 0 | • | • | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | • | • | 0 | • | • | • | • | • | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | • | 0 | • | • | • | • | • | • | | D5 | 4 | 2 | | | | CD | 4 | 3 | DD | 5 | 3 | D9 | 5 | 3 | | | | | | | C1 | 6 | 2 | D1 | 6 | 2 | | | | | | | N | • | • | • | • | • | Z | С | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | N | • | • | • | • | • | Z | • | | | | | | | | EC | 4 | 3 | | | | | | | | | | | | | | | | | | | | | | | | | N | • | • | • | • | • | Z | С | | | | | | | | СС | 4 | 3 | | | | | | | | | | | | | | | | | | | | | | | | | N | • | • | • | • | • | Z | С | | D6 | 6 | 2 | | | | CE | 6 | 3 | DE | 7 | 3 | | | | | | | | | | | | | | | | | | | | | | N | • | • | • | • | • | z | • | | | | | | | | | | | Α | ddre | essi | ng ı | mod | е | | | | | | | |-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|-----|---|----|-----|---|----|------|------|------|------|---|----|----|---|----|-------|---| | Symbol | Function | Details | | IMP | | | IMN | 1 | | Α | | В | BIT, | Α | | ΖP | | BI | T, ZI | Ρ | | | | | OP | n | # | OP | n | # | OP | n | # | OP | n | # | OP | n | # | OP | n | # | | DEX | X ← X − 1 | This instruction subtracts one from the current contents of X. | CA | 2 | 1 | | | | | | | | | | | | | | | | | DEY | Y ← Y − 1 | This instruction subtracts one from the current contents of Y. | 88 | 2 | 1 | | | | | | | | | | | | | | | | | EOR<br>(Note 1) | When T = 0<br>$A \leftarrow A \forall M$<br>When T = 1<br>$M(X) \leftarrow M(X) \forall M$ | When T = 0, this instruction transfers the contents of the M and A to the ALU which performs a bit-wise Exclusive OR, and stores the result in A. When T = 1, the contents of M(X) and M are transferred to the ALU, which performs a bit-wise Exclusive OR and stores the results in M(X). The contents of A remain unchanged, but status flags are changed. M(X) represents the contents of memory where is indicated by X. | | | | 49 | 2 | 2 | | | | | | | 45 | 3 | 2 | | | | | INC | A ← A + 1 or<br>M ← M + 1 | This instruction adds one to the contents of A or M. | | | | | | | ЗА | 2 | 1 | | | | E6 | 5 | 2 | | | | | INX | X ← X + 1 | This instruction adds one to the contents of X. | E8 | 2 | 1 | | | | | | | | | | | | | | | | | INY | Y ← Y + 1 | This instruction adds one to the contents of Y. | C8 | 2 | 1 | | | | | | | | | | | | | | | | | JMP | If addressing mode is ABS PCL $\leftarrow$ ADL PCH $\leftarrow$ ADH If addressing mode is IND PCL $\leftarrow$ M (ADH, ADL) PCH $\leftarrow$ M (ADH, ADL + 1) If addressing mode is ZP, IND PCL $\leftarrow$ M(00, ADL) PCH $\leftarrow$ M(00, ADL + 1) | This instruction jumps to the address designated by the following three addressing modes: Absolute Indirect Absolute Zero Page Indirect Absolute | | | | | | | | | | | | | | | | | | | | JSR | $\begin{array}{l} M(S) \leftarrow PCH \\ S \leftarrow S-1 \\ M(S) \leftarrow PCL \\ S \leftarrow S-1 \\ After executing the above, if addressing mode is ABS, \\ PCL \leftarrow ADL \\ PCH \leftarrow ADH \\ if addressing mode is SP, \\ PCL \leftarrow ADL \\ PCH \leftarrow FF \\ If addressing mode is ZP, IND, \\ PCL \leftarrow M(00, ADL) \\ PCH \leftarrow M(00, ADL) \\ PCH \leftarrow M(00, ADL + 1) \end{array}$ | This instruction stores the contents of the PC in the stack, then jumps to the address designated by the following addressing modes: Absolute Special Page Zero Page Indirect Absolute | | | | | | | | | | | | | | | | | | | | LDA<br>(Note 2) | When T = 0<br>$A \leftarrow M$<br>When T = 1<br>$M(X) \leftarrow M$ | When T = 0, this instruction transfers the contents of M to A. When T = 1, this instruction transfers the contents of M to $(M(X))$ . The contents of A remain unchanged, but status flags are changed. $M(X)$ represents the contents of memory where is indicated by X. | | | | А9 | 2 | 2 | | | | | | | A5 | 3 | 2 | | | | | LDM | M ← nn | This instruction loads the immediate value in M. | | | | | | | | | | | | | 3С | 4 | 3 | | | | | LDX | X ← M | This instruction loads the contents of M in X. | | | | A2 | 2 | 2 | | | | | | | A6 | 3 | 2 | | | | | LDY | $Y \leftarrow M$ | This instruction loads the contents of M in Y. | | | | A0 | 2 | 2 | | | | | | | A4 | 3 | 2 | | | | | | | | | | | Addressing mode Processor status register | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | |----|-------|---|----|-------|---|-------------------------------------------|-----|---|----|-----|---|----|-----|---|----|-----|---|----|-------|----|----|-------|---|----|-----|---|----|-----|---|----|----|---|---|---|---|---|---|---|---|---| | Z | ZP, ) | < | Z | ZP, ` | Y | , | ABS | 3 | А | BS, | Х | Al | BS, | Υ | | IND | 1 | ZF | P, IN | ID | IN | ID, I | X | IN | ND, | Υ | ı | REL | | | SP | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | ОР | n | # | OP N | V | Т | В | D | ı | z | С | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | N | • | • | • | • | • | Z | • | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | N | • | • | • | • | • | Z | • | | 55 | 4 | 2 | | | | 4D | 4 | 3 | 5D | 5 | 3 | 59 | 5 | 3 | | | | | | | 41 | 6 | 2 | 51 | 6 | 2 | | | | | | | N | • | • | • | • | • | Z | • | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | F6 | 6 | 2 | | | | EE | 6 | 3 | FE | 7 | 3 | | | | | | | | | | | | | | | | | | | | | | N | • | • | • | • | • | Z | • | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | N | • | • | • | • | • | Z | • | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | N | • | • | • | • | • | z | • | | | | | | | | 4C | 3 | 3 | | | | | | | 6C | 5 | 3 | B2 | 4 | 2 | | | | | | | | | | | | | • | • | • | • | • | • | • | • | | | | | | | | 20 | 6 | 3 | | | | | | | | | | 02 | 7 | 2 | | | | | | | | | | 22 | 5 | 2 | • | • | • | • | • | • | • | • | | B5 | 4 | 2 | | | | AD | 4 | 3 | BD | 5 | 3 | В9 | 5 | 3 | | | | | | | A1 | 6 | 2 | B1 | 6 | 2 | | | | | | | N | • | • | • | • | • | Z | • | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | • | • | • | • | • | • | • | • | | | | | В6 | 4 | 2 | ΑE | 4 | 3 | | | | BE | 5 | 3 | | | | | | | | | | | | | | | | | | | N | • | • | • | • | • | z | • | | В4 | 4 | 2 | | | | AC | 4 | 3 | ВС | 5 | 3 | | | | | | | | | | | | | | | | | | | | | | N | • | • | • | • | • | Z | • | | | | | | | | | | | A | ddr | essi | ing i | mod | е | | | | | | _ | |-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|-----|---|----|-----|---|----|-----|------|-------|-----|---|----|----|---|----|------|---| | Symbol | Function | Details | | IMF | ) | | IMI | Л | | Α | | Е | IT, | A | | ΖP | | ВІ | T, Z | P | | | | | OP | n | # | OF | n | # | ОР | n | # | OP | n | # | OP | n | # | OP | n | # | | LSR | 7 0<br>0→ <u></u> →C | This instruction shifts either A or M one bit to the right such that bit 7 of the result always is set to 0, and the bit 0 is stored in C. | | | | | | | 4A | 2 | 1 | | | | 46 | 5 | 2 | | | | | NOP | PC ← PC + 1 | This instruction adds one to the PC but does no otheroperation. | EΑ | 2 | 1 | | | | | | | | | | | | | | | | | ORA<br>(Note 1) | When T = 0<br>$A \leftarrow A \lor M$<br>When T = 1<br>$M(X) \leftarrow M(X) \lor M$ | When T = 0, this instruction transfers the contents of A and M to the ALU which performs a bit-wise "OR", and stores the result in A. When T = 1, this instruction transfers the contents of M(X) and the M to the ALU which performs a bit-wise OR, and stores the result in M(X). The contents of A remain unchanged, but status flags are changed. M(X) represents the contents of memory where is indicated by X. | | | | 09 | 2 | 2 | | | | | | | 05 | 3 | 2 | | | | | PHA | S ← S − 1 | This instruction pushes the contents of A to the memory location designated by S, and decrements the contents of S by one. | 48 | 3 | 1 | | | | | | | | | | | | | | | | | PHP | $M(S) \leftarrow PS \\ S \leftarrow S - 1$ | This instruction pushes the contents of PS to the memory location designated by S and decrements the contents of S by one. | 08 | 3 | 1 | | | | | | | | | | | | | | | | | PLA | S ← S + 1<br>A ← M(S) | This instruction increments S by one and stores the contents of the memory designated by S in A. | 68 | 4 | 1 | | | | | | | | | | | | | | | | | PLP | $S \leftarrow S + 1$ $PS \leftarrow M(S)$ | This instruction increments S by one and stores the contents of the memory location designated by S in PS. | 28 | 4 | 1 | | | | | | | | | | | | | | | | | ROL | 7 0<br>←□□←C← | This instruction shifts either A or M one bit left through C. C is stored in bit 0 and bit 7 is stored in C. | | | | | | | 2A | 2 | 1 | | | | 26 | 5 | 2 | | | | | ROR | 7 0<br>—C→ | This instruction shifts either A or M one bit right through C. C is stored in bit 7 and bit 0 is stored in C. | | | | | | | 6A | 2 | 1 | | | | 66 | 5 | 2 | | | | | RRF | 7 0 | This instruction rotates 4 bits of the M content to the right. | | | | | | | | | | | | | 82 | 8 | 2 | | | | | RTI | $\begin{array}{l} S \leftarrow S+1 \\ PS \leftarrow M(S) \\ S \leftarrow S+1 \\ PCL \leftarrow M(S) \\ S \leftarrow S+1 \\ PCH \leftarrow M(S) \end{array}$ | This instruction increments S by one, and stores the contents of the memory location designated by S in PS. S is again incremented by one and stores the contents of the memory location designated by S in PCL. S is again incremented by one and stores the contents of memory location designated by S in PCH. | 40 | 6 | 1 | | | | | | | | | | | | | | | | | RTS | $S \leftarrow S + 1$ $PCL \leftarrow M(S)$ $S \leftarrow S + 1$ $PCH \leftarrow M(S)$ $(PC) \leftarrow (PC) + 1$ | This instruction increments S by one and stores the contents of the memory location designated by S in PCL. S is again incremented by one and the contents of the memory location is stored in PCH. PC is incremented by 1. | 60 | 6 | 1 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Addressing mode , X ZP, Y ABS ABS, X ABS, Y IND ZP, IND IND, X IND, Y REL SP | | | | | | | | | | | | | | | | F | roc | esso | sor status register | | | | | | | | | |----|-------|-----|----|-----|---|---|---|----|---|----|----|-----|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|----|-----|---|----|-------|----|-----|-----|---|----|-----|---|----|-----|---|-----|------|---------------------|---|-----|-------|------|-------|--------|------|---| | | ZP, Z | X | | ZP, | Υ | | Α | BS | ; | Α | BS | , X | А | BS, | Υ | | INC | ) | ZI | P, IN | ND | II. | ND, | X | 11 | ND, | Υ | | REL | _ | | SP | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | OP | т — | г – | OF | _ | _ | 0 | _ | | | 1- | _ | _ | OP | n | # | OP | _ | 1 | ₩ | _ | _ | - | _ | _ | ОР | | 1 | OP | _ | | - | | # | N | | Т | | D | ı | z | С | | 56 | 6 | 2 | | | | 4 | E | 6 | 3 | 5E | 7 | 3 | | | | | | | | | | | | | | | | | | | | | | 0 | • | • | • | • | • | Z | С | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | • | • | • | • | • | • | • | • | | 15 | 4 | 2 | | | | 0 | D | 4 | 3 | 1D | 5 | 3 | 19 | 5 | 3 | | | | | | | 01 | 6 | 2 | 11 | 6 | 2 | | | | | | | N | • | • | • | • | • | Z | • | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | • | • | • | • | • | • | • | • | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | • | • | • | • | • | • | • | • | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | N | • | • | • | • | • | Z | • | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | (Va | lue : | save | n sta | stack) | | | | 36 | 6 | 2 | | | | 2 | Е | 6 | 3 | 3E | 7 | 3 | | | | | | | | | | | | | | | | | | | | | | N | • | • | • | • | • | Z | С | | 76 | 6 | 2 | | | | 6 | Е | 6 | 3 | 7E | 7 | 3 | | | | | | | | | | | | | | | | | | | | | | N | • | • | • | • | • | Z | С | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | • | • | • | • | • | • | • | • | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | (Va | lue : | save | ed ir | n sta | ack) | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | • | • | • | • | • | • | • | • | | | | | | | | | | | Addr | essi | ng r | nod | е | | | | | | | | | | |-----------------------------|----------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|-----|---|----|-----|---|------|------|------|-----------|-----|---|----|----|---|-----------|------|----|--|--| | Symbol | Function | Details | | IMF | • | | IMI | М | | Α | | В | IT, | Α | | ΖP | | ВІ | T, Z | .P | | | | | | | OP | n | # | OF | r | # | OP | n | # | OP | n | # | OP | n | # | OP | n | # | | | | SBC<br>(Note 1)<br>(Note 5) | When T = 0<br>$A \leftarrow A - M - C$<br>When T = 1<br>$M(X) \leftarrow M(X) - M - C$ | When $T=0$ , this instruction subtracts the value of M and the complement of C from A, and stores the results in A and C. When $T=1$ , the instruction subtracts the contents of M and the complement of C from the contents of M(X), and stores the results in M(X) and C. A remain unchanged, but status flag are changed. M(X) represents the contents of memory where is indicated by X. | | | | E | 9 2 | 2 | | | | | | | E5 | 3 | 2 | | | | | | | SEB | Ai or Mi ← 1 | This instruction sets the designated bit i of A or M. | | | | | | | | | | 0В<br>20i | 2 | 1 | | | | 0F<br>20i | 5 | 2 | | | | SEC | C ← 1 | This instruction sets C. | 38 | 2 | 1 | | | | | | | | | | | | | | | | | | | SED | D ← 1 | This instruction set D. | F8 | 2 | 1 | | | | | | | | | | | | | | | | | | | SEI | I ← 1 | This instruction set I. | 78 | 2 | 1 | | | | | | | | | | | | | | | | | | | SET | T ← 1 | This instruction set T. | 32 | 2 | 1 | | | | | | | | | | | | | | | | | | | STA | M ← A | This instruction stores the contents of A in M. The contents of A does not change. | | | | | | | | | | | | | 85 | 4 | 2 | | | | | | | STP | | This instruction resets the oscillation control F/F and the oscillation stops. Reset or interrupt input is needed to wake up from this mode. | 42 | 2 | 1 | | | | | | | | | | | | | | | | | | | STX | $M \leftarrow X$ | This instruction stores the contents of X in M. The contents of X does not change. | | | | | | | | | | | | | 86 | 4 | 2 | | | | | | | STY | $M \leftarrow Y$ | This instruction stores the contents of Y in M. The contents of Y does not change. | | | | | | | | | | | | | 84 | 4 | 2 | | | | | | | TAX | X ← A | This instruction stores the contents of A in X. The contents of A does not change. | AA | 2 | 1 | | | | | | | | | | | | | | | | | | | TAY | Y ← A | This instruction stores the contents of A in Y. The contents of A does not change. | А8 | 2 | 1 | | | | | | | | | | | | | | | | | | | TST | M = 0? | This instruction tests whether the contents of M are "0" or not and modifies the N and Z. | | | | | | | | | | | | | 64 | 3 | 2 | | | | | | | TSX | $X \leftarrow S$ | This instruction transfers the contents of S in X. | ВА | 2 | 1 | | | | | | | | | | | | | | | | | | | TXA | $A \leftarrow X$ | This instruction stores the contents of X in A. | 8A | 2 | 1 | | | | | | | | | | | | | | | | | | | TXS | S ← X | This instruction stores the contents of X in S. | 9A | 2 | 1 | | | | | | | | | | | | | | | | | | | TYA | $A \leftarrow Y$ | This instruction stores the contents of Y in A. | 98 | 2 | 1 | | | | | | | | | | | | | | | | | | | WIT | | The WIT instruction stops the internal clock but not the oscillation of the oscillation circuit is not stopped. CPU starts its function after the Timer X over flows (comes to the terminal count). All registers or internal memory contents except Timer X will not change during this mode. (Of course needs VDD). | C2 | 2 | 1 | | | | | | | | | | | | | | | | | | Notes 1: The number of cycles "n" is increased by 3 when T is 1. 2: The number of cycles "n" is increased by 2 when T is 1. 3: The number of cycles "n" is increased by 1 when T is 1. 4: The number of cycles "n" is increased by 2 when branching has occurred. 5: N, V, and Z flags are invalid in decimal operation mode. | | | Addressing mode , X ZP, Y ABS ABS, X ABS, Y IND ZP, IND IND, X IND, Y REL SP | | | | | | | | | | | | | | | Р | roc | esso | or st | atus | s reç | giste | r | | | | | | | | | | | | | | | | | |----|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|-------|---|----|-----|---|----|-----|---|----|-----|---|----|-----|---|-----|-------|-------|------|-------|-------|----|-----|---|----|-----|---|----|----|---|--------|---|---|---|---|---|----------|---| | 7 | ZP, 2 | X | Z | ZP, ` | Y | | ABS | 3 | А | BS, | Х | А | BS, | Υ | | IND | | ZF | >, IN | 1D | II. | ND, | X | IN | ND, | Υ | ı | REL | | | SP | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | ОР | n | # | OP | n | # | OP | n | # | ОР | n | # | ОР | n | # | OР | n | # | OP | n | # | OP | n | # | OP | n | # | OP | n | # | OP | n | # | N | V | Т | В | D | ı | z | С | | F5 | 4 | 2 | | | | ED | 4 | 3 | FD | 5 | 3 | F9 | 5 | 3 | | | | | | | E1 | 6 | 2 | F1 | 6 | 2 | | | | | | | N | ٧ | • | • | • | • | Z | С | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | • | • | • | • | • | • | • | • | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | • | • | • | • | • | • | • | 1 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | • | • | • | • | 1 | • | • | • | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | • | • | • | • | • | 1 | • | • | | 95 | 5 | 2 | | | | 8D | 5 | 2 | 9D | 6 | 3 | 99 | 6 | 3 | | | | | | | 81 | 7 | 2 | 91 | 7 | 2 | | | | | | | • | • | 1 | • | • | • | • | • | | 93 | | _ | | | | 00 | 3 | 3 | 90 | 0 | 3 | 99 | 0 | 3 | | | | | | | 01 | , | | 91 | , | _ | | | | | | | • | • | • | • | • | • | • | • | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 96 | 5 | 2 | 8E | | | | | | | | | | | | | | | | | | | | | | | | | | | • | • | • | • | • | • | • | • | | 94 | 5 | 2 | | | | 8C | 5 | 3 | | | | | | | | | | | | | | | | | | | | | | | | | • | • | • | • | • | • | <u>.</u> | • | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | N<br>N | • | • | • | • | • | z<br>z | • | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | N | • | • | • | • | • | Z | • | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | • | • | • | • | • | z | • | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | • | • | • | • | • | z | • | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | • | • | • | • | • | • | • | • | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | N | • | • | • | • | • | Z | • | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | • | • | • | • | • | • | • | • | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Symbol | Contents | Symbol | Contents | |------------|---------------------------------------------|-------------|-------------------------------------------------------| | IMP | Implied addressing mode | + | Addition | | IMM | Immediate addressing mode | _ | Subtraction | | Α | Accumulator or Accumulator addressing mode | Λ | Logical OR | | BIT, A | Accumulator bit addressing mode | V | Logical AND | | BIT, A, R | Accumulator bit relative addressing mode | ∀ | Logical exclusive OR | | ZP | Zero page addressing mode | <b>-</b> | Negation | | BIT, ZP | Zero page bit addressing mode | ← | Shows direction of data flow | | BIT, ZP, R | Zero page bit relative addressing mode | X | Index register X | | ZP, X | Zero page X addressing mode | Υ | Index register Y | | ZP, Y | Zero page Y addressing mode | S | Stack pointer | | ABS | Absolute addressing mode | PC | Program counter | | ABS, X | Absolute X addressing mode | PS | Processor status register | | ABS, Y | Absolute Y addressing mode | РСн | 8 high-order bits of program counter | | IND | Indirect absolute addressing mode | PCL | 8 low-order bits of program counter | | | | ADH | 8 high-order bits of address | | ZP, IND | Zero page indirect absolute addressing mode | ADL | 8 low-order bits of address | | | | FF | FF in Hexadecimal notation | | IND, X | Indirect X addressing mode | nn | Immediate value | | IND, Y | Indirect Y addressing mode | ZZ | Zero page address | | REL | Relative addressing mode | М | Memory specified by address designation of any ad- | | SP | Special page addressing mode | | dressing mode | | С | Carry flag | M(X) | Memory of address indicated by contents of index | | Z | Zero flag | | register X | | 1 | Interrupt disable flag | M(S) | Memory of address indicated by contents of stack | | D | Decimal mode flag | | pointer | | В | Break flag | M(ADH, ADL) | Contents of memory at address indicated by ADH and | | Т | X-modified arithmetic mode flag | | ADL, in ADH is 8 high-order bits and ADL is 8 low-or- | | V | Overflow flag | | der bits. | | N | Negative flag | M(00, ADL) | Contents of address indicated by zero page ADL | | | | Ai | Bit i (i = 0 to 7) of accumulator | | | | Mi | Bit i (i = 0 to 7) of memory | | | | OP | Opcode | | | | n | Number of cycles | | | | # | Number of bytes | # 3.9 SFR memory map | 000016 | Port P0 (P0) | 002016 | USB interrupt control register (USBICON) | |--------------------|-------------------------------------------------------------|--------------------|--------------------------------------------------------| | | Port P0 direction register (P0D) | | USB transmit data byte number set register 0 (EP0BYTE) | | 000116 | Port P1 (P1) | 002116 | USB transmit data byte number set register 0 (EP1BYTE) | | 000216 | · ' | 002216 | | | 000316 | Port P1 direction register (P1D) | 002316 | USBPID control register 0 (EP0PID) | | 000416 | Port P2 (P2) | 002416 | USBPID control register 1 (EP1PID) | | 000516 | Port P2 direction register (P2D) | 002516 | USB address register (USBA) | | 000616 | Port P3 (P3) | 002616 | USB sequence bit initialization register (INISQ1) | | 000716 | Port P3 direction register (P3D) | 002716 | USB control register (USBCON) | | 000816 | Port P4 (P4) | 002816 | Prescaler 12 (PRE12) | | 000916 | Port P4 direction register (P4D) | 002916 | Timer 1 (T1) | | 000A16 | | 002A16 | Timer 2 (T2) | | 000B <sub>16</sub> | | 002B <sub>16</sub> | Timer X mode register (TM) | | 000C16 | | 002C <sub>16</sub> | Prescaler X (PREX) | | 000D16 | | 002D <sub>16</sub> | Timer X (TX) | | 000E16 | | 002E16 | Timer count source set register (TCSS) | | 000F16 | | 002F <sub>16</sub> | | | 001016 | | 003016 | Serial I/O2 control register (SIO2CON) | | 001116 | | 003116 | Serial I/O2 register (SIO2) | | 001216 | | 003216 | | | 001316 | | 003316 | | | 001416 | | 003416 | A-D control register (ADCON) | | 001516 | | 003516 | A-D conversion register (low-order) (ADL) | | 001616 | Pull-up control register (PULL) | 003616 | A-D conversion register (high-order) (ADH) | | 001716 | Port P1P3 control register (P1P3C) | 003716 | | | 001816 | Transmit/Receive buffer register (TB/RB) | 003816 | MISRG | | 001916 | USB status register (USBSTS)/UART status register (UARTSTS) | 003916 | Watchdog timer control register (WDTCON) | | 001A <sub>16</sub> | Serial I/O1 control register (SIO1CON) | 003A16 | Interrupt edge selection register (INTEDGE) | | 001B <sub>16</sub> | UART control register (UARTCON) | 003B <sub>16</sub> | CPU mode register (CPUM) | | 001C <sub>16</sub> | Baud rate generator (BRG) | 003C <sub>16</sub> | Interrupt request register 1 (IREQ1) | | 001D <sub>16</sub> | USB data toggle synchronization register ( TRSYNC) | 003D <sub>16</sub> | | | 001E <sub>16</sub> | USB interrupt source discrimination register 1 (USBIR1) | 003E <sub>16</sub> | Interrupt control register 1 (ICON1) | | 001F <sub>16</sub> | USB interrupt source discrimination register 2 (USBIR2) | 003F <sub>16</sub> | | | | | | | ## 3.10 Pin configurations Fig. 3.10.1 M37534M4-XXXFP, M37534E8FP pin configuration Fig. 3.10.2 M37534M4-XXXGP, M37534E4GP pin configuration Fig. 3.10.3 M37534M4-XXXSP, M37534E8SP, M37534RSS pin configuration ### MITSUBISHI SEMICONDUCTORS USER'S MANUAL 7534 Group Nov. First Edition 2000 Editioned by Committee of editing of Mitsubishi Semiconductor USER'S MANUAL Published by Mitsubishi Electric Corp., Semiconductor Marketing Division This book, or parts thereof, may not be reproduced in any form without permission of Mitsubishi Electric Corporation. ©2000 MITSUBISHI ELECTRIC CORPORATION # User's Manual 7534 Group