# Regarding the change of names mentioned in the document, such as Mitsubishi Electric and Mitsubishi XX, to Renesas Technology Corp. The semiconductor operations of Hitachi and Mitsubishi Electric were transferred to Renesas Technology Corporation on April 1st 2003. These operations include microcomputer, logic, analog and discrete devices, and memory chips other than DRAMs (flash memory, SRAMs etc.) Accordingly, although Mitsubishi Electric, Mitsubishi Electric Corporation, Mitsubishi Semiconductors, and other Mitsubishi brand names are mentioned in the document, these names have in fact all been changed to Renesas Technology Corp. Thank you for your understanding. Except for our corporate trademark, logo and corporate statement, no changes whatsoever have been made to the contents of the document, and these changes do not constitute any alteration to the contents of the document itself. Note: Mitsubishi Electric will continue the business operations of high frequency & optical devices and power devices. Renesas Technology Corp. Customer Support Dept. April 1, 2003 # MITSUBISHI 16-BIT SINGLE-CHIP MICROCOMPUTER 7700 FAMILY / 7700 SERIES # 7721 Group User's Manual | keen | safety | first i | n vour | circuit | designs | 1 | |------|---------|---------|------------|---------|---------|---| | NOOP | Julioty | 111011 | 11 y O O 1 | Uniount | acciquo | | • 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. | Ν | lotes | regarding | these | materia | ls | |---|-------|-----------|-------|---------|----| | | | | | | | - ◆ 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 or circuit application examples contained in these materials. - All information contained in these materials, including product data, diagrams and charts, represent 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. - 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 DESCRIPTION LIST 7721 Group User's Manual | No. date | Rev. | Revision Description | Rev. | |-------------------------|------|----------------------|--------| | 1.0 First Edition 97092 | | Revision Description | date | | | 1.0 | First Edition | 970926 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | ı ı | | | | | | | | | | | | | | | | | | | | | | | | ## **Preface** This manual describes the hardware of the Mitsubishi CMOS 16-bit microcomputers 7721 Group. After reading this manual, the user will be able to understand the functions, so that their capabilities can fully be utilized. ## **BEFORE USING THIS MANUAL** ## 1. Constitution This user's manual consists of the following chapters. Refer to the chapters relevant to the products. #### • Chapter 1. DESCRIPTION through Chapter 16. APPLICATION Functions which are common to the M37721S1BFP and the M37721S2BFP are explained, using the M37721S2BFP as an example. Differences between the M37721S1BFP and the M37721S2BFP are described as notes. ## Appendix Practical information for using the 7721 Group is described. ## 2. Remark #### Product expansion Refer to the latest catalog and data book, or contact the appropriate office, as listed in "CONTACT ADDRESSES FOR FURTHER INFORMATION" on the last page. #### Electrical characteristics Refer to the latest data book. #### Software Refer to "7700 Family Software Manual." ## Development support tools Refer to the latest data book of the development support tools. ## 3. Signal levels in Figure As a rule, signal levels in each operation example and timing diagram are as follows. Signal levels The upper line indicates "1," and the lower line indicates "0." • Input/output levels of pin The upper line indicates "H," and the lower line indicates "L." For the exception, the level is shown on the left side of a signal. ## 4. Register structure Below is the structure diagram for all registers: Blank : Set to "0" or "1" according to the usage. 0 : Set to "0" at writing.1 : Set to "1" at writing. X : Invalid depending on the mode or state. It may be "0" or "1." : Nothing is assigned. \*2 0 : "0" immediately after reset. 1 : "1" immediately after reset. Undefined : Undefined immediately after reset. RW : It is possible to read the bit state at reading. The written value becomes valid. RO: It is possible to read the bit state at reading. The written value becomes invalid. Accordingly, the written value may be "0" or "1." WO : The written value becomes valid. It is impossible to read the bit state. The value is undefined at reading. However, when ["0" at reading"] is indicated in the "Function" or "Note" column, the bit is always "0" at reading. (See \*4 above.) : It is impossible to read the bit state. The value is undefined at reading. However, when ["0" at reading"] is indicated in the "Function" or "Note" column, the bit is always "0" at reading. (See \*4 above.) The written value becomes invalid. Accordingly, the written value may be "0" or "1." **\***3 i # **Table of contents** | CHAPTER 1 DESCRIPTION | | |-----------------------------------------------------|------| | 1.1 Performance overview | 1-2 | | 1.2 Pin configuration | 1-3 | | 1.3 Pin description | | | 1.4 Block diagram | | | CHAPTER 2 CENTRAL PROCESSING UNIT (CPU) | | | | | | 2.1 Central processing unit | | | 2.1.1 Accumulator (Acc) | | | 2.1.2 Index register X (X) | | | 2.1.3 Index register Y (Y) | | | 2.1.4 Stack pointer (S) | | | 2.1.5 Program counter (PC) | | | 2.1.6 Program bank register (PG) | | | 2.1.7 Data bank register (DT) | | | 2.1.8 Direct page register (DPR) | | | 2.1.9 Processor status register (PS) | | | 2.2 Bus interface unit | | | 2.2.1 Overview | | | 2.2.2 Functions of bus interface unit (BIU) | | | 2.2.3 Operation of bus interface unit (BIU) | | | 2.3 Access space | | | 2.3.1 Banks | 2-16 | | 2.3.2 Direct page | 2-16 | | 2.4 Memory assignment | 2-17 | | 2.4.1 Memory assignment in internal area | 2-17 | | 2.4.2 External area | 2-18 | | 2.5 Bus access right | 2-23 | | CHAPTER 3 CONNECTION WITH EXTERNAL DEVICES | | | 3.1 Signals required for accessing external devices | 3_2 | | 3.1.1 Descriptions of signals | | | · | 3-5 | | 3.2 Software Wait | | | | | | 3.3 Ready function | | | 3.3.1 Operation description | | | 3.4.1 Operation description | | | · | | | [Precautions for Hold function] | 3-16 | | CHAPTER 4 RESET | | |----------------------------------------------------------------------------------------|------| | 4.1 Hardware reset | 4-2 | | 4.1.1 Pin state | 4-3 | | 4.1.2 State of CPU, SFR area, and internal RAM area | 4-4 | | 4.1.3 Internal processing sequence after reset | 4-11 | | 4.1.4 Time supplying "L" level to RESET pin | 4-12 | | 4.2 Software reset | 4-13 | | CHAPTER 5 CLOCK GENERATING CIRCUIT | | | 5.1 Oscillation circuit examples | 5-2 | | 5.1.1 Connection example using resonator/oscillator | 5-2 | | 5.1.2 Externally generated clock input example | 5-2 | | 5.2 Clocks | | | 5.2.1 Clocks generated in clock generating circuit | 5-4 | | 5.3 Stop mode | 5-5 | | 5.3.1 Stop mode | 5-5 | | [Precautions for Stop mode] | | | 5.4 Wait mode | 5-9 | | 5.4.1 Wait mode | | | [Precautions for Wait mode] | 5-11 | | CHAPTER 6 INPUT/OUTPUT PINS | | | 6.1 Overview | 6-2 | | 6.2 Programmable I/O ports | | | 6.2.1 Direction register | | | 6.2.2 Port register | | | 6.3 Examples of handling unused pins | | | CHAPTER 7 INTERRUPTS | | | 7.1 Overview | 7.2 | | 7.1 Overview | | | 7.3 Interrupt control | | | 7.3.1 Interrupt disable flag (I) | | | 7.3.2 Interrupt request bit | | | 7.3.3 Interrupt priority level select bits and processor interrupt priority level (IPI | | | 7.4 Interrupt priority level | • | | 7.5 Interrupt priority level detection circuit | | | 7.6 Interrupt priority level detection time | | | 7.7 Sequence from acceptance of interrupt request until execution of interrup | | | routine | | | 7.7.1 Change in IPL at acceptance of interrupt request | | | 7.7.2 Push operation for registers | | | 7.8 Return from interrupt routine | | | 7.9 Multiple interrupts | | | 7.10 External interrupts (INTi interrupt) | | | 7.10.1 Functions of INTi interrupt request bit | | | 7.10.2 Switching of INTi interrupt request occurrence factor | | | 7.11 Precautions for interrupts | /-22 | | CHAPTER 8 TIMER A | | |-------------------------------------------------------|------| | 8.1 Overview | 8-2 | | 8.2 Block description | | | 8.2.1 Counter and reload register (timer Ai register) | | | 8.2.2 Count start register | | | 8.2.3 Timer Ai mode register | | | 8.2.4 Timer Ai interrupt control register | | | 8.2.5 Port P5 direction register | | | 8.3 Timer mode | | | 8.3.1 Setting for timer mode | | | 8.3.2 Count source | | | 8.3.3 Operation in timer mode | | | 8.3.4 Selectable functions | | | [Precautions for timer mode] | | | 8.4 Event counter mode | | | 8.4.1 Setting for event counter mode | | | 8.4.2 Operation in event counter mode | | | 8.4.3 Switching between countup and countdown | | | 8.4.4 Selectable functions | | | [Precautions for event counter mode] | | | 8.5 One-shot pulse mode | | | 8.5.1 Setting for one-shot pulse mode | | | 8.5.2 Count source | | | 8.5.3 Trigger | | | 8.5.4 Operation in one-shot pulse mode | | | [Precautions for one-shot pulse mode] | | | 8.6 Pulse width modulation (PWM) mode | | | 8.6.1 Setting for PWM mode | | | 8.6.2 Count source | | | 8.6.3 Trigger | | | 8.6.4 Operation in PWM mode | | | [Precautions for PWM mode] | | | | 0-47 | | HAPTER 9 TIMER B | | | 9.1 Overview | | | 9.2 Block description | | | 9.2.1 Counter and reload register (timer Bi register) | | | 9.2.2 Count start register | | | 9.2.3 Timer Bi mode register | | | 9.2.4 Timer Bi interrupt control register | | | 9.2.5 Port P5 direction register | 9-7 | | 9.3 Timer mode | | | 9.3.1 Setting for timer mode | 9-10 | | 9.3.2 Count source | | | 9.3.3 Operation in timer mode | | | [Precautions for timer mode] | 9-13 | | 9.4 Event counter mode | 9-14 | | 9.4.1 Setting for event counter mode | 9-16 | | 9.4.2 Operation in event counter mode | 9-17 | | [Precautions for event coutner mode] | 9-18 | | - | | | 9.5 Pulse period/Pulse width measurement mode | | |---------------------------------------------------------------------------------------|------| | 9.5.1 Setting for pulse period/pulse width measurement mode | | | 9.5.2 Count source | | | 9.5.3 Operation in pulse period/pulse width measurement mode | | | [Precautions for pulse period/pulse width measurement mode] | 9-25 | | CHAPTER 10 REAL-TIME OUTPUT | | | 10.1 Overview | | | 10.2 Block description | | | 10.2.1 Real-time output control register | | | 10.2.2 Pulse output data registers 0 and 1 | | | 10.2.3 Port P6 direction register | | | 10.2.4 Timers A0 and A1 | | | 10.3 Setting of real-time output | | | | | | CHAPTER 11 SERIAL I/O | | | 11.1 Overview | | | 11.2 Block description | | | 11.2.1 UARTi transmit/receive mode register | | | 11.2.2 UARTi transmit/receive control register 0 | | | 11.2.3 UARTi transmit/receive control register 1 | | | 11.2.4 UARTi transmit register and UARTi transmit buffer register | | | 11.2.5 UARTi receive register and UARTi receive buffer register | | | 11.2.6 UARTi baud rate register (BRGi) | | | 11.2.7 UARTi transmit interrupt control and UARTi receive interrupt control registers | | | 11.2.8 Port P8 direction register | | | 11.3 Clock synchronous serial I/O mode | | | 11.3.1 Transfer clock (Synchronizing clock) | | | 11.3.2 Method of transmission | | | 11.3.3 Transmit operation | | | 11.3.4 Method of reception | | | · | | | 11.3.6 Processing on detecting overrun error | | | [Precautions for clock synchronous serial I/O mode] | | | 11.4.1 Transfer rate (Frequency of transfer clock) | | | 11.4.2 Transfer data format | | | 11.4.3 Method of transmission | | | 11.4.4 Transmit operation | | | 11.4.5 Method of reception | | | 11.4.6 Receive operation | | | 11.4.7 Processing on detecting error | | | 11.4.8 Sleep mode | | | | | | 12.1 Ove | erview | 12-2 | |-------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------| | | ock description | | | | 1 A-D control register | | | | 2 A-D sweep pin select register | | | | 3 A-D register i (i = 0 to 7) | | | 12.2. | 4 A-D conversion interrupt control register | 12-8 | | | 5 Port P7 direction register | | | | Conversion method | | | 12.4 Abs | solute accuracy and differential non-linearity error | 12-12 | | 12.4. | 1 Absolute accuracy | 12-12 | | | 2 Differential non-linearity error | | | 12.5 One | e-shot mode | 12-14 | | | 1 Settings for one-shot mode | | | 12.5. | 2 One-shot mode operation description | 12-16 | | 12.6 Rep | peat mode | 12-17 | | 12.6. | 1 Settings for repeat mode | 12-17 | | 12.6. | 2 Repeat mode operation description | 12-19 | | 12.7 Sin | gle sweep mode | 12-20 | | 12.7. | 1 Settings for single sweep mode | 12-20 | | 12.7. | 2 Single sweep mode operation description | 12-22 | | 12.8 Rep | peat sweep mode | 12-24 | | 12.8. | 1 Settings for repeat sweep mode | 12-24 | | 12.8. | 2 Repeat sweep mode operation description | 12-26 | | 12.9 Pre | ecautions for A-D converter | 12.20 | | | | 12-20 | | CHADTED | | 12-26 | | CHAPTER | 13 DMA CONTROLLER | 12-20 | | | | | | 13.1 Ove | 13 DMA CONTROLLER | 13-2 | | <b>13.1 Ove</b><br>13.1.<br>13.1. | 13 DMA CONTROLLER erview | | | <b>13.1 Ove</b><br>13.1.<br>13.1.<br>13.1. | 13 DMA CONTROLLER erview | | | 13.1 Ove<br>13.1.<br>13.1.<br>13.1.<br>13.2 Blo | 13 DMA CONTROLLER erview | | | 13.1 Ove<br>13.1.<br>13.1.<br>13.1.<br>13.2 Blo<br>13.2. | 13 DMA CONTROLLER erview | | | 13.1 Ove<br>13.1.<br>13.1.<br>13.1.<br>13.2 Blo<br>13.2. | 13 DMA CONTROLLER erview | | | 13.1 Ove<br>13.1.<br>13.1.<br>13.1.<br>13.2 Blo<br>13.2.<br>13.2.<br>13.2. | 13 DMA CONTROLLER erview | | | 13.1 Ove<br>13.1.<br>13.1.<br>13.2 Blo<br>13.2.<br>13.2.<br>13.2.<br>13.2. | 13 DMA CONTROLLER erview | | | 13.1 Ove<br>13.1.<br>13.1.<br>13.2 Blo<br>13.2.<br>13.2.<br>13.2.<br>13.2.<br>13.2. | 13 DMA CONTROLLER erview | | | 13.1 Ove<br>13.1.<br>13.1.<br>13.2 Blo<br>13.2.<br>13.2.<br>13.2.<br>13.2.<br>13.2.<br>13.2. | 13 DMA CONTROLLER erview | | | 13.1 Ove<br>13.1.<br>13.1.<br>13.2 Blo<br>13.2.<br>13.2.<br>13.2.<br>13.2.<br>13.2.<br>13.2.<br>13.2. | 13 DMA CONTROLLER erview | | | 13.1 Ove<br>13.1.<br>13.1.<br>13.2 Blo<br>13.2.<br>13.2.<br>13.2.<br>13.2.<br>13.2.<br>13.2.<br>13.2.<br>13.2. | 13 DMA CONTROLLER erview | | | 13.1 Ove<br>13.1.<br>13.1.<br>13.2 Blo<br>13.2.<br>13.2.<br>13.2.<br>13.2.<br>13.2.<br>13.2.<br>13.2.<br>13.2.<br>13.2. | 13 DMA CONTROLLER erview | | | 13.1 Ove<br>13.1.<br>13.1.<br>13.2 Blo<br>13.2.<br>13.2.<br>13.2.<br>13.2.<br>13.2.<br>13.2.<br>13.2.<br>13.2.<br>13.2. | 13 DMA CONTROLLER erview | 13-2 13-3 13-3 13-6 13-7 13-10 13-12 13-12 13-13 13-13 13-13 | | 13.1 Ove<br>13.1.<br>13.1.<br>13.2 Blo<br>13.2.<br>13.2.<br>13.2.<br>13.2.<br>13.2.<br>13.2.<br>13.2.<br>13.2.<br>13.2.<br>13.2.<br>13.2. | 13 DMA CONTROLLER erview | 13-2 | | 13.1 Ove<br>13.1.<br>13.1.<br>13.2 Blo<br>13.2.<br>13.2.<br>13.2.<br>13.2.<br>13.2.<br>13.2.<br>13.2.<br>13.2.<br>13.2.<br>13.2.<br>13.2.<br>13.2. | arview 1 Performance overview 2 Bus use priority levels 3 Modes book description 1 Bus access control circuit 2 DMAC control register L 3 DMAC control register H 4 Source address register i (SARi) 5 Destination address register i (DARi) 6 Transfer counter register i (TCRi) 7 Incrementer/Decrementer 8 Decrementer 9 DMA latch 10 DMAi mode register H 11 DMAi mode register H 12 DMAi control register | 13-2 13-3 13-3 13-6 13-12 13-13 13-13 13-13 13-14 13-15 13-15 | | 13.1 Ove<br>13.1.<br>13.1.<br>13.2 Blo<br>13.2.<br>13.2.<br>13.2.<br>13.2.<br>13.2.<br>13.2.<br>13.2.<br>13.2.<br>13.2.<br>13.2.<br>13.2.<br>13.2. | arview 1 Performance overview 2 Bus use priority levels 3 Modes 6 description 1 Bus access control circuit 2 DMAC control register L 3 DMAC control register H 4 Source address register i (SARi) 5 Destination address register i (DARi) 6 Transfer counter register i (TCRi) 7 Incrementer/Decrementer 8 Decrementer 9 DMA latch 10 DMAi mode register L 11 DMAi mode register H 12 DMAi control register 13 DMAi interrupt control register | | | 13.1 Ove<br>13.1.<br>13.1.<br>13.2 Blo<br>13.2.<br>13.2.<br>13.2.<br>13.2.<br>13.2.<br>13.2.<br>13.2.<br>13.2.<br>13.2.<br>13.2.<br>13.2.<br>13.2.<br>13.2. | arview | 13-2 13-3 13-3 13-6 13-12 13-13 13-13 13-13 13-13 13-14 13-15 13-15 13-16 13-17 | | 13.1 Ove<br>13.1.<br>13.1.<br>13.2 Blo<br>13.2.<br>13.2.<br>13.2.<br>13.2.<br>13.2.<br>13.2.<br>13.2.<br>13.2.<br>13.2.<br>13.2.<br>13.2.<br>13.2.<br>13.2. | arview 1 Performance overview 2 Bus use priority levels 3 Modes 6 description 1 Bus access control circuit 2 DMAC control register L 3 DMAC control register H 4 Source address register i (SARi) 5 Destination address register i (DARi) 6 Transfer counter register i (TCRi) 7 Incrementer/Decrementer 8 Decrementer 9 DMA latch 10 DMAi mode register L 11 DMAi mode register H 12 DMAi control register 13 DMAi interrupt control register | 13-2 13-3 13-3 13-6 13-12 13-13 13-13 13-13 13-13 13-14 13-15 13-15 13-16 13-17 | | 13.3 Control | 13-19 | |--------------------------------------------------------------------|--------| | 13.3.1 DMA enabling | 13-19 | | 13.3.2 DMA requests | 13-20 | | 13.3.3 Channel priority levels | 13-21 | | 13.3.4 Processing from DMA request until DMA transfer execution | 13-23 | | 13.3.5 Termination of DMA transfer | 13-25 | | 13.3.6 DMA transfer restart after termination | 13-28 | | 13.4 Operation | 13-30 | | 13.4.1 2-bus cycle transfer | 13-30 | | [Precautions for 2-bus cycle transfer] | 13-37 | | 13.4.2 1-bus cycle transfer | 13-38 | | [Precautions for 1-bus cycle transfer] | 13-47 | | 13.4.3 Burst transfer mode | | | [Precautions for burst transfer mode] | 13-50 | | 13.4.4 Cycle-steal transfer mode | 13-51 | | [Precautions for cycle-steal transfer mode] | 13-52 | | 13.5 Single transfer mode | | | 13.5.1 Setting of single transfer mode | | | 13.5.2 Operation in single transfer mode | | | 13.6 Repeat transfer mode | | | 13.6.1 Setting of repeat transfer mode | | | 13.6.2 Operation in repeat transfer mode | | | 13.7 Array chain transfer mode | | | 13.7.1 Transfer parameter memory in array chain transfer mode | | | 13.7.2 Setting of array chain transfer mode | | | 13.7.3 Operation in array chain transfer mode | | | [Precautions for array chain transfer mode] | | | 13.8 Link array chain transfer mode | | | 13.8.1 Transfer parameter memory in link array chain transfer mode | | | 13.8.2 Setting of link array chain transfer mode | | | 13.8.3 Operation in link array chain transfer mode | | | [Precautions for link array chain transfer mode] | | | 13.9 DMA transfer time | | | 13.9.1 Cycle-steal transfer mode | | | 13.9.2 Burst transfer mode | 13-101 | | CHAPTER 14 DRAM CONTROLLER | | | 14.1 Overview | 14-2 | | 14.2 Block description | | | 14.2.1 DRAM control register | 14-3 | | 14.2.2 Refresh timer | 14-5 | | 14.2.3 Address comparator | 14-6 | | 14.2.4 RAS and CAS generating circuit | 14-6 | | 14.2.5 Address multiplexer | 14-6 | | 14.3 Setting for DRAMC | 14-7 | | 14.4 DRAMC operation | | | 14.4.1 Waveform example of DRAM control signals | 14-8 | | 14.4.2 Refresh request | | | 14.5 Precautions for DRAMC | 14-12 | | CHAPTER 15 WATCHDOG TIMER | | |-------------------------------------------------------------------------------------------------------------------------------------|------| | 15.1 Block description | | | 15.1.2 Watchdog timer frequency select register | 15-3 | | 15.2 Operation description | | | 15.2.1 Basic operation | | | 15.2.2 Stop period | | | 15.2.3 Operation in Stop mode | | | CHAPTER 16 APPLICATION | | | 16.1 Memory connection | 16-2 | | 16.1.1 Memory connection model | 16-2 | | 16.1.2 How to calculate timing | | | 16.1.3 Example of memory connection | | | 16.1.4 Example of I/O expansion | | | 16.2 Examples of using DMA controller | | | 16.2.1 Example of Centronics interface configuration | | | 16.2.2 Example of stepping motor control | | | 16.2.3 Example of dynamic lighting for LED | | | 16.3 Comparison of sample program execution rate | | | 16.3.2 Comparison between software Wait ( $f(X_{IN}) = 20 \text{ MHz}$ ) and software Wait + Ready ( $f(X_{IN}) = 25 \text{ MHz}$ ) | | | APPENDIX | | | Appendix 1. Memory assignment of 7721 Group | | | Appendix 2. Memory assignment in SFR area | | | Appendix 3. Control registers | | | Appendix 4. Package outline | | | Appendix 5. Examples of handling unused pins Appendix 6. Machine instructions | | | Appendix 7. Hexadecimal instruction code table | | | Appendix 8. Countermeasure against noise | | | Appendix 9. 7721 Group Q & A | | | Appendix 10. Differences between 7721 Group and 7720 Group | | | Appendix 11. Electrical characteristics | | | Appendix 12. Standard characteristics | | | | | GLOSSARY | 1 | <b>-</b> | h | Δ۱ | Ωf | co | n | tο | nts | | |---|----------|---|----|-----|----|---|----|------|---| | | а | v | ıe | OI. | LU | | LE | 1115 | ١ | ## **MEMORANDUM** - 1.1 Performance overview - 1.2 Pin configuration - 1.3 Pin description - 1.4 Block diagram ## 1.1 Performance overview ## 1.1 Performance overview Table 1.1.1 lists the performance overview of the M37721. Table 1.1.1 M37721 performance overview | Parame | ters | Functions | | | | |----------------------------------------------------|--------------------------------|-------------------------------------------------------------------|---------------------------------------------------------|--|--| | Number of basic instructions | | | 103 | | | | Instruction execution time | | 160 ns (the minimum instruction at $f(X_{IN}) = 25 \text{ MHz}$ ) | | | | | External clock input frequency f(X <sub>IN</sub> ) | | | 25 MHz (maximum) | | | | Memory sizes | ROM | | External | | | | | 5444 | M37721S2BFP | 1024 bytes | | | | | RAM | M37721S1BFP | 512 bytes | | | | Programmable Input/Output | P5-P1 | 0 | 8 bits X 6 | | | | ports | P4 | | 5 bits X 1 | | | | Multifunctional timers | TA0-T | A4 | 16 bits X 5 | | | | | TB0-T | B2 | 16 bits X 3 | | | | Serial I/O | UART | ), UART1 | (UART or clock synchronous serial I/O) X 2 | | | | A-D converter | | | 8-bit successive approximation method X 1 (8 channels) | | | | Watchdog timer | | | 12 bits X 1 | | | | DMA controller | | | 4 channels | | | | | | | Maximum transfer rate: 12.5 Mbytes/sec. | | | | | | | (at f(X <sub>IN</sub> ) = 25 MHz, 1-bus cycle transfer) | | | | | | | Maximum transfer rate : 6.25 Mbytes/sec. | | | | | | | (at $f(X_{IN}) = 25$ MHz, 2-bus cycle transfer) | | | | DRAM controller | | | CAS before RAS refreshing method | | | | Real-time output | | | 4 bits X 2 channels | | | | • | | | or 6 bits X 1 channel + 2 bits X 1 channel | | | | Interrupts | | | 3 external, 20 internal (priority levels 0 to 7 can | | | | | | | be set for each interrupt with software) | | | | Clock generating circuit | | | Built-in (externally connected to a ceramic | | | | | | | resonator or a quartz-crystal oscillator) | | | | Supply voltage | | | 5 V ±10 % | | | | Power dissipation | | | 135 mW (at $f(X_{IN}) = 25 \text{ MHz}$ , typ.) | | | | Port Input/Output | Input/Output withstand voltage | | 5 V | | | | characteristics | | | 5 mA | | | | Memory expansion | • | | Maximum 16 Mbytes | | | | Operating temperature range | | | -20°C to 85°C | | | | Device structure | | | CMOS high-performance silicon gate process | | | | Package | | | 100-pin plastic molded QFP | | | | | | | | | | ## 1.2 Pin configuration Figure 1.2.1 shows the M37721S2BFP pin configuration. Fig. 1.2.1 M37721S2BFP pin configuration (top view) ## 1.3 Pin description ## 1.3 Pin description Tables 1.3.1 to 1.3.3 list the pin description. Table 1.3.1 Pin description (1) | Pin | Name | Input/Output | Functions | | | | | | | |------------------|--------------------------|--------------|------------------------------------------------------------------------------|--|--|--|--|--|--| | Vcc, Vss | Power supply | | Supply 5 V ±10 % to Vcc pin and 0 V to Vss pin. | | | | | | | | CNVss | CNVss | Input | Connect to Vss or Vcc pin. | | | | | | | | RESET | Reset input | Input | The microcomputer is reset when supplying "L" level | | | | | | | | | | | to this pin. | | | | | | | | RESETout | Reset output | Output | When input to RESET pin is "L," this pin outputs "L." | | | | | | | | | | | Output from this pin returns "H" after the release of | | | | | | | | | | | reset. When writing "1" to the software reset bit, this | | | | | | | | | | | pin outputs "L." | | | | | | | | XIN | Clock input | Input | These are I/O pins of the internal clock generating | | | | | | | | | | | circuit. Connect a ceramic resonator or quartz-crystal | | | | | | | | Хоит | Clock output | Output | oscillator between pins X <sub>IN</sub> and X <sub>OUT</sub> . When using an | | | | | | | | | | | external clock, the clock source should be input to X <sub>IN</sub> | | | | | | | | = | | Outrut | pin and Χουτ pin should be left open. | | | | | | | | Ē | Enable output | Output | Data/instruction code read or data write is performed | | | | | | | | | | Innut | when output from this pin is "L" level. | | | | | | | | BYTE | Exernal data bus width | Input | Input level to this pin determines whether the external | | | | | | | | | selection input | | data bus has a 16-bit width or an 8-bit width. The | | | | | | | | | | | width is 16 bits when the level is "L", and 8 bits when | | | | | | | | | | Output | the level is "H". | | | | | | | | ST0 | Status signal output | Output | The bus use state is output in 2-bit code. | | | | | | | | ST1 | | | ST1 ST0 Bus use state | | | | | | | | | | | 0 0 DRAM refresh | | | | | | | | | | | 0 1 Hold | | | | | | | | | | | 1 0 DMA | | | | | | | | A\/ | A salas a salas d | | 1 1 CPU | | | | | | | | AVcc | Analog supply input | | The power supply pin for the A-D converter. Connect | | | | | | | | AVss | Defendance of the second | Input | AVcc to Vcc pin. Connect AVss to Vss pin. | | | | | | | | V <sub>REF</sub> | Reference voltage input | Input | This is a reference voltage input pin for the A-D converter. | | | | | | | ## 1.3 Pin description Table 1.3.2 Pin description (2) | Pin | Name | Input/Output | Functions | |-----------------------------------|-----------------------|--------------|-----------------------------------------------------------------------------------| | $A_0/MA_0$ | Address low-order/ | Output | Low-order 8 bits (A <sub>0</sub> -A <sub>7</sub> ) of the address are output. | | $A_7/MA_7$ | DRAM address | | When the DRAM is accessed, the row and column | | | | | addresses are output with the time-sharing. | | A <sub>8</sub> /D <sub>8</sub> – | Address middle-order/ | I/O | ●External data bus width = 8 bits (When the BYTE | | A <sub>15</sub> /D <sub>15</sub> | data high-order | | pin is "H" level) | | | | | Middle-order 8 bits (A <sub>8</sub> –A <sub>15</sub> ) of the address are output. | | | | | ●External data bus width = 16 bits (When the BYTE | | | | | pin is "L" level) | | | | | Data (D <sub>8</sub> –D <sub>15</sub> ) input/output and output of the middle- | | | | | order 8 bits (A <sub>8</sub> -A <sub>15</sub> ) of the address are performed | | | | | with the time-sharing. | | A <sub>16</sub> /D <sub>0</sub> — | Address high-order/ | I/O | Data (D <sub>0</sub> –D <sub>7</sub> ) input/output and output of the high-order | | A23/D7 | data low-order | | 8 bits (A <sub>16</sub> –A <sub>23</sub> ) of the address are performed with the | | | | _ | time-sharing. | | R/W, | Memory control signal | Output | ●R/W | | BHE, | output | | The Read/Write signal indicates the data bus state. | | BLE, | | | The state is read while this signal is "H" level, and | | ALE | | | write while this signal is "L" level. BHE | | | | | "L" level is output when an odd-numbered address is | | | | | accessed. | | | | | ●BLE | | | | | "L" level is output when an even-numbered address | | | | | is accessed. | | | | | ●ALE | | | | | This is used to obtain only the address from address | | | | | and data multiplex signals. | | HOLD | Hold input | Input | The microcomputer is in Hold state while "L" level is | | | | | input to the HOLD pin. | | RDY | Ready input | Input | The microcomputer is in Ready state while "L" level is | | | 2 3.27 | | input to the RDY pin. | | <b>φ</b> 1 | Clock $\phi$ ₁ output | Output | This is the $\phi_1$ output pin. | ## 1.3 Pin description Table 1.3.3 Pin description (3) | Pin | Name | Input/Output | Functions | |------------------|--------------|--------------|-------------------------------------------------------------------------------------| | P43-P47 | I/O port P4 | I/O | Port P4 is a 5-bit CMOS I/O port. This port has an | | | | | I/O direction register and each pin can be programmed | | | | | for input or output. | | P50-P57 | I/O port P5 | I/O | Port P5 is an 8-bit I/O port with the same function as | | | | | P4. These pins can be programmed as I/O pins for | | | | | Timers A2-A4 and I/O pins for Timers B0, B1. | | P60-P67 | I/O port P6 | I/O | Port P6 is an 8-bit I/O port with the same function as | | | | | P4. These pins can be programmed as output pins for | | | | | the real-time output. | | P70-P77 | I/O port P7 | I/O | Port P7 is an 8-bit I/O port with the same function as | | | | | P4. These pins can be programmed as input pins for | | | | | A-D converter. | | P80-P87 | I/O port P8 | I/O | Port P8 is an 8-bit I/O port with the same function as | | | | | P4. These pins can be programmed as I/O pins for | | | | | Serial I/O. | | P90-P97 | I/O port P9 | I/O | Port P9 is an 8-bit I/O port with the same function as | | | | | P4. These pins can be programmed as I/O pins for | | | | | DMA controller. | | P100- | I/O port P10 | I/O | Port P10 is an 8-bit I/O port with the same function as | | P10 <sub>7</sub> | | | P4. These pins can be programmed as I/O pin for TC | | | | | and output pins for DRAM controller. | | | | | $P10_0-P10_2$ also function as input pins for $\overline{INT}_0-\overline{INT}_2$ . | ## 1.4 Block diagram Figure 1.4.1 shows the M37721 block diagram. Fig. 1.4.1 M37721 block diagram 1.4 Block diagram **MEMORANDUM** ## CHAPTER 2 # CENTRAL PROCESSING UNIT (CPU) - 2.1 Central processing unit - 2.2 Bus interface unit - 2.3 Access space - 2.4 Memory assignment - 2.5 Bus access right ## 2.1 Central processing unit ## 2.1 Central processing unit The CPU (Central Processing Unit) has the ten registers as shown in Figure 2.1.1. Fig. 2.1.1 CPU registers structure 2.1 Central processing unit #### 2.1.1 Accumulator (Acc) Accumulators A and B are available. #### (1) Accumulator A (A) Accumulator A is the main register of the microcomputer. The transaction of data such as calculation, data transfer, and input/output are performed mainly through accumulator A. It consists of 16 bits, and the low-order 8 bits can also be used separately. The data length flag (m) determines whether the register is used as a 16-bit register or as an 8-bit register. When an 8-bit register is selected, only the low-order 8 bits of accumulator A are used and the contents of the high-order 8 bits is unchanged. #### (2) Accumulator B (B) Accumulator B is a 16-bit register with the same function as accumulator A. Accumulator B can be used instead of accumulator A. The use of accumulator B, however except for some instructions, requires more instruction bytes and execution cycles than that of accumulator A. Accumulator B is also controlled by the data length flag (m) just as in accumulator A. #### 2.1.2 Index register X (X) Index register X consists of 16 bits and the low-order 8 bits can also be used separately. The index register length flag (x) determines whether the register is used as a 16-bit register or as an 8-bit register. When an 8-bit register is selected, only the low-order 8 bits of index register X are used and the contents of the high-order 8 bits is unchanged. In an addressing mode in which index register X is used as an index register, the address obtained by adding the contents of this register to the operand's contents is accessed. In the MVP or MVN instruction, a block transfer instruction, the contents of index register X indicate the low-order 16 bits of the source address. The third byte of the instruction is the high-order 8 bits of the source address. Note: Refer to "7700 Family Software Manual" for addressing modes. ## 2.1.3 Index register Y (Y) Index register Y is a 16-bit register with the same function as index register X. Just as in index register X, the index register length flag (x) determines whether this register is used as a 16-bit register or as an 8-bit register. In the MVP or MVN instruction, a block transfer instruction, the contents of index register Y indicate the low-order 16 bits of the destination address. The second byte of the instruction is the high-order 8 bits of the destination address. ## 2.1 Central processing unit #### 2.1.4 Stack pointer (S) The stack pointer (S) is a 16-bit register. It is used for a subroutine call or an interrupt. It is also used when addressing modes using the stack are executed. The contents of S indicate an address (stack area) for storing registers during subroutine calls and interrupts. Stack area is selected by the stack bank select bit described later (bit 7 at address 5E<sub>16</sub>). The stack area is specified to bank 0<sub>16</sub> when the stack bank select bit is "0," and the stack area is specified to bank FF<sub>16</sub> when it is "1." When an interrupt request is accepted, the microcomputer stores the contents of the program bank register (PG) at the address indicated by the contents of S and decrements the contents of S by 1. Then the contents of the program counter (PC) and the processor status register (PS) are stored. The contents of S after accepting an interrupt request is equal to the contents of S decremented by 5 before the accepting of the interrupt request. (Refer to "Figure 2.1.2.") When completing the process in the interrupt routine and returning to the original routine, the contents of registers stored in the stack area are restored into the original registers in the reverse sequence ( $PS \rightarrow PC \rightarrow PG$ ) by executing the **RTI** instruction. The contents of S is returned to the state before accepting an interrupt request. The same operation is performed during a subroutine call, however, the contents of PS is not automatically stored. (The contents of PG may not be stored. This depends on the addressing mode.) The user should store registers other than those described above with software when the user needs them during interrupts or subroutine calls. Additionally, initialize S at the beginning of the program because its contents are undefined at reset. The stack area changes when subroutines are nested or when multiple interrupt requests are accepted. Therefore, make sure of the subroutine's nesting depth not to destroy the necessary data. Note: Refer to "7700 Family Software Manual" for addressing modes. Fig. 2.1.2 Stored registers of the stack area ## 2.1 Central processing unit #### 2.1.5 Program counter (PC) The program counter is a 16-bit counter that indicates the low-order 16 bits of the address (24 bits) at which an instruction to be executed next (in other words, an instruction to be read out from an instruction queue buffer next) is stored. The contents of the high-order program counter ( $PC_H$ ) become " $FF_{16}$ ," and the low-order program counter ( $PC_L$ ) becomes " $FE_{16}$ " at reset. The contents of the program counter becomes the contents of the reset's vector address (addresses $FFFE_{16}$ , $FFFF_{16}$ ) immediately after reset. Figure 2.1.3 shows the program counter and the program bank register. Fig. 2.1.3 Program counter and program bank register #### 2.1.6 Program bank register (PG) The access space is divided in units of 64 Kbytes. This unit is called "bank." (Refer to section "2.3 Access space.") The program bank register is an 8-bit register. This register indicates the high-order 8 bits (bank) of the address (24 bits) at which an instruction to be executed next (in other words, an instruction to be read out from an instruction queue buffer next) is stored. These 8 bits are called bank. When a carry occurs after adding the contents of the program counter or adding the offset value to the contents of the program counter in the branch instruction and others, the contents of the program bank register is automatically incremented by 1. When a borrow occurs after subtracting the contents of the program counter, the contents of the program bank register is automatically decremented by 1. Accordingly, there is no need to consider bank boundaries in programming, usually. This register is cleared to "0016" at reset. #### 2.1.7 Data bank register (DT) The data bank register is an 8-bit register. In the following addressing modes using the data bank register, the contents of this register is used as the high-order 8 bits (bank) of a 24-bit address to be accessed. Use the **LDT** instruction to set a value to this register. This register is cleared to "0016" at reset. - Addressing modes using data bank register - Direct indirect - •Direct indexed X indirect - •Direct indirect indexed Y - Absolute - Absolute bit - •Absolute indexed X - Absolute indexed Y - Absolute bit relative - •Stack pointer relative indirect indexed Y ## 2.1 Central processing unit #### 2.1.8 Direct page register (DPR) The direct page register is a 16-bit register. The contents of this register indicate the direct page area which is allocated in bank $0_{16}$ or in the space across banks $0_{16}$ and $1_{16}$ . The following addressing modes use the direct page register. The contents of the direct page register indicate the base address (the lowest address) of the direct page area. The space which extends to 256 bytes above that address is specified as a direct page. The direct page register can contain a value from "000016" to "FFFF16." When it contains a value equal to or more than "FF0116," the direct page area spans the space across banks 016 and 116. When the contents of low-order 8 bits of the direct page register is "00<sub>16</sub>," the number of cycles required to generate an address is 1 cycle smaller than the number when its contents are not "00<sub>16</sub>." Accordingly, the access efficiency can be enhanced in this case. This register is cleared to "000016" at reset. Figure 2.1.4 shows a setting example of the direct page area. - Addressing modes using direct page register - Direct - Direct bit - Direct indexed X - Direct indexed Y - Direct indirect - Direct indexed X indirect - •Direct indirect indexed Y - Direct indirect long - •Direct indirect long indexed Y - Direct bit relative Fig. 2.1.4 Setting example of direct page area 2.1 Central processing unit #### 2.1.9 Processor status register (PS) The processor status register is an 11-bit register. Figure 2.1.5 shows the structure of the processor status register. | b15 | b14 | b13 | b12 | b11 | b10 | b9 | b8 | b7 | b6 | b5 | b4 | b3 | b2 | b1 | b0 | | |-----|-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|--------------------------------| | 0 | 0 | 0 | 0 | 0 | | IPL | | Ν | > | m | х | D | - | Z | С | Processor status register (PS) | Note: Bits 11-15 is always "0" at reading. Fig. 2.1.5 Processor status register structure ## (1) Bit 0: Carry flag (C) It retains a carry or a borrow generated in the arithmetic and logic unit (ALU) during an arithmetic operation. This flag is also affected by shift and rotate instructions. When the **BCC** or **BCS** instruction is executed, this flag's contents determine whether the program causes a branch or not. Use the **SEC** or **SEP** instruction to set this flag to "1," and use the **CLC** or **CLP** instruction to clear it to "0." #### (2) Bit 1: Zero flag (Z) It is set to "1" when a result of an arithmetic operation or data transfer is "0," and cleared to "0" when otherwise. When the **BNE** or **BEQ** instruction is executed, this flag's contents determine whether the program causes a branch or not. Use the SEP instruction to set this flag to "1," and use the CLP instruction to clear it to "0." Note: This flag is invalid in the decimal mode addition (the ADC instruction). #### (3) Bit 2: Interrupt disable flag (I) It disables all maskable interrupts (interrupts other than watchdog timer, the **BRK** instruction, and zero division). Interrupts are disabled when this flag is "1." When an interrupt request is accepted, this flag is automatically set to "1" to avoid multiple interrupts. Use the **SEI** or **SEP** instruction to set this flag to "1," and use the **CLI** or **CLP** instruction to clear it to "0." This flag is set to "1" at reset. #### (4) Bit 3: Decimal mode flag (D) It determines whether addition and subtraction are performed in binary or decimal. Binary arithmetic is performed when this flag is "0." When it is "1," decimal arithmetic is performed with 8 bits treated as two digits decimal (the data length flag (m) = "1") or 16 bits treated as four digits decimal (the data length flag (m) = "0"). Decimal adjust is automatically performed. Decimal operation is possible only with the **ADC** and **SBC** instructions. Use the **SEP** instruction to set this flag to "1," and use the **CLP** instruction to clear it to "0." This flag is cleared to "0" at reset. #### (5) Bit 4: Index register length flag (x) It determines whether each of index register X and index register Y is used as a 16-bit register or an 8-bit register. That register is used as a 16-bit register when this flag is "0," and as an 8-bit register when it is "1." Use the **SEP** instruction to set this flag to "1," and use the **CLP** instruction to clear it to "0." This flag is cleared to "0" at reset. Note: When transferring data between registers which are different in bit length, the data is transferred with the length of the destination register, but except for the TXA, TYA, TXB, TYB, and TXS instructions. Refer to "7700 Family Software Manual" for details. ## 2.1 Central processing unit #### (6) Bit 5: Data length flag (m) It determines whether to use a data as a 16-bit unit or as an 8-bit unit. A data is treated as a 16-bit unit when this flag is "0," and as an 8-bit unit when it is "1." Use the **SEM** or **SEP** instruction to set this flag to "1," and use the **CLM** or **CLP** instruction to clear it to "0." This flag is cleared to "0" at reset. Note: When transferring data between registers which are different in bit length, the data is transferred with the length of the destination register, but except for the TXA, TYA, TXB, TYB, and TXS instructions. Refer to "7700 Family Software Manual" for details. ## (7) Bit 6: Overflow flag (V) It is used when adding or subtracting with a word regarded as signed binary. When the data length flag (m) is "0," the overflow flag is set to "1" when the result of addition or subtraction exceeds the range between -32768 and +32767, and cleared to "0" in all other cases. When the data length flag (m) is "1," the overflow flag is set to "1" when the result of addition or subtraction exceeds the range between -128 and +127, and cleared to "0" in all other cases. The overflow flag is also set to "1" when a result of division exceeds the register length to be stored in a division instruction **DIV**. When the **BVC** or **BVS** instruction is executed, this flag's contents determine whether the program causes a branch or not. Use the SEP instruction to set this flag to "1," and use the CLV or CLP instruction to clear it to "0." Note: This flag is invalid in the decimal mode. #### (8) Bit 7: Negative flag (N) It is set to "1" when a result of arithmetic operation or data transfer is negative. (Bit 15 of the result is "1" when the data length flag (m) is "0," or bit 7 of the result is "1" when the data length flag (m) is "1.") It is cleared to "0" in all other cases. When the **BPL** or **BMI** instruction is executed, this flag determines whether the program causes a branch or not. Use the **SEP** instruction to set this flag to "1," and use the **CLP** instruction to clear it to "0." Note: This flag is invalid in the decimal mode. #### (9) Bits 10 to 8: Processor interrupt priority level (IPL) These three bits can determine the processor interrupt priority level to one of levels 0 to 7. The interrupt is enabled when the interrupt priority level of a required interrupt, which is set in each interrupt control register, is higher than IPL. When an interrupt request is accepted, IPL is stored in the stack area, and IPL is replaced by the interrupt priority level of the accepted interrupt request. There are no instruction to directly set or clear the bits of IPL. IPL can be changed by storing the new IPL into the stack area and updating the processor status register with the **PUL** or **PLP** instruction. The contents of IPL is cleared to "0002" at reset. 2.2 Bus interface unit #### 2.2 Bus interface unit A bus interface unit (BIU) is built-in between the central processing unit (CPU) and memory•I/O devices. BIU's function and operation are described below. When externally connecting devices, refer to "CHAPTER 3. CONNECTION WITH EXTERNAL DEVICES." #### 2.2.1 Overview Transfer operation between the CPU and memory•I/O devices is always performed via the BIU. - ① The BIU reads an instruction from the memory before the CPU executes it. - ② When the CPU reads data from the memory•I/O device, the CPU first specifies the address from which data is read to the BIU. The BIU reads data from the specified address and passes it to the CPU. - ③ When the CPU writes data to the memory•I/O device, the CPU first specifies the address to which data is written to the BIU and write data. The BIU writes the data to the specified address. - To perform the above operations ① to ③, the BIU inputs and outputs the control signals, and control the bus. Figure 2.2.1 shows the bus and bus interface unit (BIU). ## 2.2 Bus interface unit Fig. 2.2.1 Bus and bus interface unit (BIU) 2.2 Bus interface unit ## 2.2.2 Functions of bus interface unit (BIU) The bus interface unit (BIU) consists of four registers shown in Figure 2.2.2. Table 2.2.1 lists the functions of each register. Fig. 2.2.2 Register structure of bus interface unit (BIU) Table 2.2.1 Functions of each register | Name | Functions | | | | | | | |--------------------------|--------------------------------------------------------------------------------|--|--|--|--|--|--| | Program address register | Indicates the storage address for the instruction which is next taken into the | | | | | | | | | instruction queue buffer. | | | | | | | | Instruction queue buffer | Temporarily stores the instruction which has been taken in. | | | | | | | | Data address register | Indicates the address for the data which is next read from or written to. | | | | | | | | Data buffer | Temporarily stores the data which is read from the memory•I/O device by the | | | | | | | | | BIU or which is written to the memory•I/O device by the CPU. | | | | | | | ## 2.2 Bus interface unit The CPU and the bus send or receive data via BIU because each operates based on different clocks (Note). The BIU allows the CPU to operate at high speed without waiting for access to the memory $\cdot$ I/O devices that require a long access time. The BIU's functions are described bellow. **Note:** The CPU operates based on $\phi$ CPU. The period of $\phi$ CPU is normally the same as that of $\phi$ . The internal bus operates based on the $\overline{E}$ signal. The period of the $\overline{E}$ signal is twice that of $\phi$ at a minimum. #### (1) Reading out instruction (Instruction prefetch) When the CPU does not require to read or write data, that is, when the bus is not in use, the BIU reads instructions from the memory and stores them in the instruction queue buffer. This is called instruction prefetch. The CPU reads instructions from the instruction queue buffer and executes them, so that the CPU can operate at high speed without waiting for access to the memory which requires a long access time. When the instruction queue buffer becomes empty or contains only 1 byte of an instruction, the BIU performs instruction prefetch. The instruction queue buffer can store instructions up to 3 bytes. The contents of the instruction queue buffer is initialized when a branch or jump instruction is executed, and the BIU reads a new instruction from the destination address. When instructions in the instruction queue buffer are insufficient for the CPU's needs, the BIU extends the pulse duration of clock $\phi$ CPU in order to keep the CPU waiting until the BIU fetches the required number of instructions or more. ## (2) Reading data from memory•I/O device The CPU specifies the storage address of data to be read to the BIU's data address register, and requires data. The CPU waits until data is ready in the BIU. The BIU outputs the address received from the CPU onto the address bus, reads contents at the specified address, and takes it into the data buffer. The CPU continues processing, using data in the data buffer. However, if the BIU uses the bus for instruction prefetch when the CPU requires to read data, the BIU keeps the CPU waiting. #### (3) Writing data to memory•I/O device The CPU specifies the address of data to be written to the BIU's data address register. Then, the CPU writes data into the data buffer. The BIU outputs the address received from the CPU onto the address bus and writes data in the data buffer into the specified address. The CPU advances to the next processing without waiting for completion of BIU's write operation. However, if the BIU uses the bus for instruction prefetch when the CPU requires to write data, the BIU keeps the CPU waiting. ## (4) Bus control To perform the above operations (1) to (3), the BIU inputs and outputs the control signals, and controls the address bus and the data bus. The cycle in which the BIU controls the bus and accesses the memory•I/O device is called the bus cycle. Refer to "CHAPTER 3. CONNECTION WITH EXTERNAL DEVICES" about the bus cycle at accessing the external devices. 2.2 Bus interface unit #### 2.2.3 Operation of bus interface unit (BIU) Figure 2.2.3 shows the basic operating waveforms of the bus interface unit (BIU). About signals which are input/output externally when accessing external devices, refer to "CHAPTER 3. CONNECTION WITH EXTERNAL DEVICES." #### (1) When fetching instructions into the instruction queue buffer - ① When the instruction which is next fetched is located at an even address, the BIU fetches 2 bytes at a time with the timing of waveform (a). - However, when accessing an external device which is connected with the 8-bit external data bus width (BYTE = "H"), only 1 byte of the instruction is fetched. - When the instruction which is next fetched is located at an odd address, the BIU fetches only 1 byte with the timing of waveform (a). The contents at the even address are not taken into the instruction queue buffer. #### (2) When reading or writing data to and from the memory•I/O device - ① When accessing a 16-bit data which begins at an even address, waveform (a) is applied. The 16 bits of data are accessed at a time. - When accessing a 16-bit data which begins at an odd address, waveform (b) is applied. The 16 bits of data are accessed separately in 2 operations, 8 bits at a time. Invalid data is not fetched into the data buffer. - ③ When accessing an 8-bit data at an even address, waveform (a) is applied. The data at the odd address is not fetched into the data buffer. - 4 When accessing an 8-bit data at an odd address, waveform (a) is applied. The data at the even address is not fetched into the data buffer. For instructions that are affected by the data length flag (m) and the index register length flag (x), operation 1 or 2 is applied when flag m or x = "0"; operation 3 or 4 is applied when flag m or x = "1." # 2.2 Bus interface unit Fig. 2.2.3 Basic operating waveforms of bus interface unit (BIU) 2.3 Access space ## 2.3 Access space Figure 2.3.1 shows the M37721's access space. By combination of the program counter (PC), which is 16 bits of structure, and the program bank register (PG), a 16-Mbyte space from addresses 0<sub>16</sub> to FFFFFF<sub>16</sub> can be accessed. For details about access of an external area, refer to "CHAPTER 3. CONNECTION WITH EXTERNAL DEVICES." The memory and I/O devices are assigned in the same access space. Accordingly, it is possible to perform transfer and arithmetic operations using the same instructions without discrimination of the memory from I/O devices. Fig. 2.3.1 M37721's access space ## 2.3 Access space #### 2.3.1 Banks The access space is divided in units of 64 Kbytes. This unit is called "bank." The high-order 8 bits of address (24 bits) indicate a bank, which is specified by the program bank register (PG) or data bank register (DT). Each bank can be accessed efficiently by using an addressing mode that uses the data bank register (DT). If the program counter (PC) overflows at a bank boundary, the contents of the program bank register (PG) is incremented by 1. If a borrow occurs in the program counter (PC) as a result of subtraction, the contents of the program bank register (PG) is decremented by 1. Normally, accordingly, the user can program without concern for bank boundaries. SFR (Special Function Register) and internal RAM are assigned in bank 016. For details, refer to section "2.4 Memory assignment." #### 2.3.2 Direct page A 256-byte space specified by the direct page register (DPR) is called "direct page." A direct page is specified by setting the base address (the lowest address) of the area to be specified as a direct page into the direct page register (DPR). By using a direct page addressing mode, a direct page can be accessed with less instruction cycles than otherwise. Note: Refer also to section "2.1 Central processing unit." 2.4 Memory assignment ## 2.4 Memory assignment This section describes the internal area's memory assignment. For more information about the external area, refer also to "CHAPTER 3. CONNECTION WITH EXTERNAL DEVICES." Figure 2.4.1 shows the memory assignment. #### 2.4.1 Memory assignment in internal area SFR (Special Function Register) and internal RAM are assigned in the internal area. #### (1) SFR area The registers for setting internal peripheral devices are assigned at addresses 0<sub>16</sub> to 7F<sub>16</sub> and 1FC0<sub>16</sub> to 1FFF<sub>16</sub>. This area is called SFR. Figures 2.4.2 and 2.4.3 show the SFR area's memory assignment. For each register in the SFR area, refer to each functional description in this manual. For the state of the SFR area immediately after reset, refer to section "4.1.2 State of CPU, SFR area, and internal RAM area." #### (2) Internal RAM area The M37721S2BFP (**Note 1**) assigns the 1024-byte static RAM at addresses 80<sub>16</sub> to 47F<sub>16</sub>. 512 bytes of that can be selected either it is used as the internal RAM or it is used as the external area. (**Note 2**) The internal RAM area is used as a stack area (Note 3), as well as an area to store data. Accordingly, note that set the nesting depth of a subroutine and multiple interrupts' level not to destroy the necessary data. - Notes 1: The M37721S1BFP assigns the 512-byte static RAM at addresses 80<sub>16</sub> to 27F<sub>16</sub>. - 2: The internal RAM area becomes 512 bytes after reset because the internal RAM area select bit is "0." - **3:** Either bank $0_{16}$ or bank FF<sub>16</sub> can be selected as the stack area by the stack bank select bit (bit 7 at address $5E_{16}$ ). Figure 2.4.4 shows the structure of the processor mode registers 0, 1. ## 2.4 Memory assignment #### 2.4.2 External area Table 2.4.1 lists the external area. When connecting the external device, follow the procedure described bellow: - •Connect the ROM to addresses FFCE<sub>16</sub> to FFFF<sub>16</sub> because they are interrupt vector table. - •Stack area can be assigned to bank 0<sub>16</sub> or bank FF<sub>16</sub>. Select the stack area by the stack bank select bit (bit 7 at address 5E<sub>16</sub>). (Refer to "Figure 2.4.4.") - •When using the DRAM controller, DRAM area can be selected from address FFFFFF<sub>16</sub> toward the low-order address in a unit of 1 Mbytes. (Refer to "CHAPTER 14. DRAM CONTROLLER.") In the case connecting an external device to the area where overlaps the internal area, when reading out the overlapping area, the central processing unit (CPU) take in data of the internal area and do not take in data of the external area. When writing to the overlapping area, data is written to the internal area. The signal is output to the external at the same timing when data is written to the internal area. Table 2.4.1 External area | Type name | M37721S2BFP | | M37721S1BFP | |------------------------------|------------------------------------------|--|------------------------------------------| | Internal RAM area select bit | 1 0 | | "0" (Fix this bit to "0.") | | | 216-916 | | 216-916 | | External area | 480 <sub>16</sub> –1FBF <sub>16</sub> | | 280 <sub>16</sub> –1FBF <sub>16</sub> | | | 2000 <sub>16</sub> –FFFFFF <sub>16</sub> | | 2000 <sub>16</sub> —FFFFFF <sub>16</sub> | Internal RAM area select bit: bit 1 at address 5F16 Fig. 2.4.1 Memory assignment | A -1 -1 | | A -l -l | _ | | |-----------------------|-------------------------------------------|-----------------------|-------------------------------------------|--| | Addres | iS | Address | Count start register | | | 00000016<br>00000116 | | 00004016<br>00004116 | Count start register | | | 00000116 | | 00004116 | One-shot start register | | | 00000216 | | 00004216 | One-shot start regions | | | 00000316 | | 00004316 | Up-down register | | | 00000416 | | 00004416 | Op demirogister | | | 00000316 | | 00004516 | | | | 00000016 | | 00004616 | Timer A0 register | | | 00000716 | ĺ | 00004716 | | | | 00000016 | ſ | 00004916 | Timer A1 register | | | 00000316<br>00000A16 | Port P4 register | 00004A16 | | | | 000007116<br>00000B16 | Port P5 register | 00004B16 | Timer A2 register | | | 00000C16 | Port P4 direction register | 00004C16 | Time of AQ and sinter | | | 00000D16 | Port P5 direction register | 00004D16 | Timer A3 register | | | 00000E16 | Port P6 register | 00004E16 | Time of A.A. and sinted | | | 00000E16 | Port P7 register | 00004F16 | Timer A4 register | | | 00000116 | Port P6 direction register | 00005016 | Ti un Do un ninter | | | 00001016 | Port P7 direction register | 00005116 | Timer B0 register | | | 00001216 | Port P8 register | 00005216 | T D4 sisters | | | 00001216 | Port P9 register | 00005316 | Timer B1 register | | | 00001416 | Port P8 direction register | 00005416 | T. Do services | | | 00001516 | Port P9 direction register | 00005516 | Timer B2 register | | | 00001616 | Port P10 register | 00005616 | Timer A0 mode register | | | 00001716 | 1 | 00005716 | Timer A1 mode register | | | 00001716 | Port P10 direction register | 00005816 | Timer A2 mode register | | | 00001916 | | 00005916 | Timer A3 mode register | | | 00001A16 | Pulse output data register 0 | 00005A16 | Timer A4 mode register | | | 00001B16 | , | 00005B16 | Timer B0 mode register | | | 00001C16 | Pulse output data register 1 | 00005C16 | Timer B1 mode register | | | 00001D16 | | 00005D16 | Timer B2 mode register | | | 00001E16 | A-D control register | 00005E16 | Processor mode register 0 | | | 00001E16 | A-D sweep pin select register | 00005E16 | Processor mode register 1 | | | 00001116 | A-D register 0 | 00006016 | Watchdog timer register | | | 00002016 | 1 | 0000616 | Watchdog timer frequency select register | | | 00002116 | A-D register 1 | 00006116 | Real-time output control register | | | 00002216 | | 00006316 | | | | 00002416 | A-D register 2 | 00006416 | DRAM control register | | | 00002116 | | 00006516 | | | | 00002616 | A-D register 3 | 00006616 | Refresh timer | | | 00002716 | | 00006716 | | | | 00002716 | A-D register 4 | 00006816 | DMAC control register L | | | 00002916 | | 00006916 | DMAC control register H | | | | A-D register 5 | 00006A16 | | | | 00002F116 | 1 | 00006B16 | | | | 00002C16 | A-D register 6 | 00006C16 | DMA0 interrupt control register | | | 00002D16 | 1 | 00006D16 | DMA1 interrupt control register | | | 00002E16 | A-D register 7 | 00006E16 | DMA2 interrupt control register | | | 00002F16 | 1 | 00006F16 | DMA3 interrupt control register | | | 00003016 | UART0 transmit/receive mode register | 00007016 | A-D conversion interrupt control register | | | 00003116 | UART0 baud rate register (BRG0) | 00007116 | UART0 transmit interrupt control register | | | 00003216 | 3 Lutter and 1 Lutter | 00007216 | UART0 receive interrupt control register | | | 00003316 | UART0 transmit buffer register | 00007316 | UART1 transmit interrupt control register | | | 00003416 | UART0 transmit/receive control register 0 | 00007416 | UART1 receive interrupt control register | | | 00003516 | UART0 transmit/receive control register 1 | 00007516 | Timer A0 interrupt control register | | | 00003616 | | 00007616 | Timer A1 interrupt control register | | | 00003716 | UART0 receive buffer register | 00007716 | Timer A2 interrupt control register | | | 00003816 | UART1 transmit/receive mode register | 00007816 | Timer A3 interrupt control register | | | 00003916 | UART1 baud rate register (BRG1) | 00007916 | Timer A4 interrupt control register | | | 00003A16 | , | 00007A16 | Timer B0 interrupt control register | | | 00003B16 | UART1 transmit buffer register | 000077116<br>00007B16 | Timer B1 interrupt control register | | | 00003C16 | UART1 transmit/receive control register 0 | 00007C16 | Timer B2 interrupt control register | | | 00003D16 | UART1 transmit/receive control register 1 | 00007D16 | INTo interrupt control register | | | 00003E16 | | 00007E16 | INT1 interrupt control register | | | 00003F16 | UART1 receive buffer register | 00007F16 | INT2 interrupt control register | | Fig. 2.4.2 SFR area's memory map (1) | Address | | | | |---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|--------------------------------|-----------------------------------------| | OO1FC216 | | | | | Mathematics | | Source address register 0 | | | O01FC316 | | Ü | | | Material Content Co | 001FC3 <sub>16</sub> | | | | Material Process Pr | | | | | O01FC716 O01FC816 O01FC916 O01FC916 O01FC916 O01FC916 O01FC916 O01FC916 O01FC916 O01FC916 O01FC916 O01FD916 O01FE916 | | Destination address register 0 | | | O01FC816 O01FCA16 O01FCA16 O01FCC16 DMA0 mode register L O01FCD16 O01FCD16 O01FCD16 O01FCD16 O01FD016 | | | Н | | March Marc | | | | | MAD mode register L DMAD mode register L DMAD mode register H DMAD control 1 M DMAD control register 2 M DMAD control register 2 M DMAD control register 3 M DMAD control register 4 DMAD control register 2 M DMAD control register 3 M DMAD control register 4 DMAD control register 4 DMAD control register 5 DMAD control register 6 DMAD control register 8 DMAD control register 9 DMAD control register 9 DMAD control register 1 2 M DMAD control register 3 M DMAD control register 3 M DMAD control register 3 M DMAD control register 3 M DMAD control register 3 M DMAD control register 4 DMAD control register 5 DMAD control register 6 DMAD control register 8 DMAD control register 9 DMAD control register 9 DMAD control register 1 reg | | Transfer counter register 0 | | | O01FCB16 | | Transier counter register o | | | OUTFCC16 | | | | | O01FCD16 | | DMA0 mode register L | | | O01FCE16 | | | | | O01FD016 O01FE016 | | | | | 001FD116 Source address register 1 M 001FD216 Un1FD316 L 001FD316 Destination address register 1 M 001FD316 Destination address register 1 M 001FD316 Un1FD316 L 001FD316 Un1FD316 L 001FD316 Un1FD316 L 001FD316 Un1FD316 H 001FD316 Un1FD316 L 001FD316 Un1FD316 L 001FD316 Un1FD316 L 001FD316 Un1FD316 L 001FD316 Un1FD316 L 001FD316 Un1FD316 L 001FED416 Un1FED416 L 001FE316 Un1FE316 L 001FE316 Un1FE316 L 001FE316 Un1FE316 L 001FE316 Un1FE316 H 001FE316 Un1FE316 H 001FE316 Un1FE316 H 001FF316 Un1FF316 H | | | | | Note | 001FD016 | | | | Destination address register 1 | 001FD1 <sub>16</sub> | Source address register 1 | | | 001FD416<br>001FD516<br>001FD616<br>001FD716<br>001FD716<br>001FD716<br>001FD416<br>001FD016<br>001FD016<br>001FD016<br>001FD016<br>001FD016<br>001FD16<br>001FE016<br>001FE16<br>001FE216<br>001FE216<br>001FE216<br>001FE216<br>001FE316<br>001FE316<br>001FE316<br>001FE316<br>001FE316<br>001FE316<br>001FE316<br>001FE316<br>001FE316<br>001FE316<br>001FE316<br>001FE316<br>001FE316<br>001FE316<br>001FE316<br>001FE316<br>001FE316<br>001FE316<br>001FE316<br>001FE316<br>001FE316<br>001FE316<br>001FE316<br>001FE316<br>001FE316<br>001FE316<br>001FE316<br>001FE316<br>001FE316<br>001FE316<br>001FE316<br>001FE316<br>001FE316<br>001FE316<br>001FE316<br>001FE316<br>001FE316<br>001FE316<br>001FE316<br>001FE316<br>001FE316<br>001FE3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF3316<br>001FF | | | Н | | Destination address register 1 M | | | | | Mathematical Content | | | | | O01FD716 | | Destination address register 1 | | | DMA1 mode register L | | | Н | | Transfer counter register 1 | | | | | DMA1 mode register L | | | | | DMA1 mode register L | | I ransfer counter register 1 | | | 001FDC16 DMA1 mode register L 001FDD16 DMA1 mode register H 001FD16 DMA1 control register 001FD16 DMA1 control register 001FD16 DMA1 control register 001FE016 L 001FE216 H 001FE216 Destination address register 2 M 001FE316 Destination address register 2 M 001FE316 Destination address register 2 M 001FE316 Destination address register 2 M 001FE316 DMA2 mode register L DMA2 mode register L 001FE316 DMA2 mode register H DMA2 control register 001FE316 DMA2 control register M 001FF316 Destination address register 3 M 001FF316 Destination address register 3 M 001FF316 Destination address register 3 M 001FF316 Destination address register 3 M 001FF316 Destination address register 3 M 001FF316 Destination address register 3 M 001FF316 | | | Н | | DMA1 mode register H | | DMAA mada madatan l | | | 001FDE16<br>001FD16<br>001FE216<br>001FE216<br>001FE316<br>001FE416<br>001FE516<br>001FE516<br>001FE616<br>001FE616<br>001FE616<br>001FE616<br>001FE616<br>001FE616<br>001FE616<br>001FE616<br>001FE616<br>001FE616<br>001FE616<br>001FE616<br>001FE616<br>001FE616<br>001FE616<br>001FE616<br>001FE616<br>001FE616<br>001FF616<br>001FF616<br>001FF616<br>001FF616<br>001FF616<br>001FF616<br>001FF616<br>001FF616<br>001FF616<br>001FF616<br>001FF616<br>001FF616<br>001FF616<br>001FF616<br>001FF616<br>001FF616<br>001FF616<br>001FF616<br>001FF616<br>001FF616<br>001FF616<br>001FF616<br>001FF616<br>001FF616<br>001FF616<br>001FF616<br>001FF616<br>001FF616<br>001FF616<br>001FF616<br>001FF616<br>001FF616<br>001FF616<br>001FF616<br>001FF616<br>001FF616<br>001FF616<br>001FF616<br>001FF616<br>001FF616<br>001FF616 L<br>DMA2 mode register L<br>DMA2 control register 3 M<br>M<br>M<br>H 001FF616<br>001FF616<br>001FF616 Destination address register 3 M<br>M<br>H 001FF616<br>001FF616 Destination address register 3 M<br>M<br>H 001FF616<br>001FF616 Destination address register 3 M<br>M<br>H 001FF616<br>001FF616 DMA3 mode register L<br>DMA3 mode register H DMA3 mode register H | | | | | 001FD16 001FE016 001FF016 001FFD16 | | | | | D01FE016 | | DIVIAT CONTROL TEGISTER | | | 001FE116 Source address register 2 M 001FE216 001FE316 L 001FE316 Destination address register 2 M 001FE316 Destination address register 2 M 001FE316 D01FE316 H 001FE316 DMA2 mode register L M 001FE316 DMA2 mode register H DMA2 control register 001FE316 D01FE316 H 001FF316 Source address register 3 M 001FF316 Destination address register 3 M 001FF316 Destination address register 3 M 001FF316 Destination address register 3 M 001FF316 D01FF316 H H | | | | | 001FE216 H 001FE316 Destination address register 2 M 001FE516 Destination address register 2 M 001FE516 Destination address register 2 M 001FE316 D01FE316 L 001FE016 DMA2 mode register L M 001FE16 DMA2 mode register H DMA2 control register 001FE16 D01FE16 M 001FF316 Source address register 3 M 001FF316 Destination address register 3 M 001FF316 Destination address register 3 M 001FF316 Destination address register 3 M 001FF316 D01FF316 L 001FF316 D01FF316 L 001FF316 D01FF316 L 001FF316 D01FF316 H 001FF316 D01FF316 H 001FF316 D01FF316 H 001FF316 D01FF316 H 001FF316 D01FF316 H 001FF316 D01FF316 H | | Source address register 2 | | | 001FE316 001FE416 001FE516 | | Source address register 2 | | | 001FE416 001FE516 L M 001FE516 001FE616 H M 001FE716 001FE716 L L 001FE316 Transfer counter register 2 M M 001FE316 DMA2 mode register L M 001FE016 DMA2 mode register H DMA2 control register 001FE16 DMA2 control register M 001FF16 Source address register 3 M 001FF316 Destination address register 3 M 001FF316 Destination address register 3 M 001FF316 Destination address register 3 M 001FF316 Destination address register 3 M 001FF316 Destination address register 3 M 001FF316 Transfer counter register 3 M 001FF316 DMA3 mode register L DMA3 mode register L 001FF016 DMA3 mode register H DMA3 control register | | | | | 001FE516<br>001FE616<br>001FE716<br>001FE716<br>001FE816<br>001FE816<br>001FEB16<br>001FED16<br>001FED16<br>001FE16<br>001FE16<br>001FF16<br>001FF16<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316 L Destination address register 3 M M M Destination address register 3 M Destination address register 3 M Destination address register 3 M Destination address register 3 M Destination address register 3 M Desti | | | | | 001FE616 H 001FE716 L 001FE816 M 001FE916 Transfer counter register 2 M 001FE916 DMA2 mode register L 001FE16 DMA2 mode register H 001FE16 DMA2 control register 001FF116 Source address register 3 001FF216 H 001FF316 Destination address register 3 001FF316 H 001FF316 Destination address register 3 001FF316 H < | | Destination address register 2 | | | 001FE716 001FE816 L 001FE916 Transfer counter register 2 M 001FE316 DMA2 mode register L M 001FE016 DMA2 mode register H DMA2 control register 001FE16 DMA2 control register M 001FE16 Source address register 3 M 001FF316 H M 001FF316 Destination address register 3 M 001FF316 H M 001FF316 Destination address register 3 M 001FF316 H H 001FF316 Destination address register 3 M 001FF316 H H <td></td> <td>Dodination address register 2</td> <td></td> | | Dodination address register 2 | | | 001FE816<br>001FE916<br>001FEA16<br>001FEB16<br>001FED16<br>001FED16<br>001FE16<br>001FF16<br>001FF16<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316 L Destination address register 3 M M L Destination address register 3 M M H Destination address register 3 M M H D01FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316 DMA3 mode register L DMA3 mode register L DMA3 mode register H DMA3 mode register H DMA3 control register | | | • • • • • • • • • • • • • • • • • • • • | | 001FE916<br>001FEA16<br>001FEB16<br>001FEC16<br>001FED16<br>001FE16<br>001FF16<br>001FF16<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316<br>001FF316 L M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M | | | | | 001FEA16 H 001FEB16 DMA2 mode register L 001FED16 DMA2 mode register H 001FE16 DMA2 control register 001FF16 DMA2 control register 001FF116 Source address register 3 M 001FF216 H 001FF316 Destination address register 3 M 001FF516 H 001FF616 H 001FF716 H 001FF316 | | Transfer counter register 2 | | | 001FEB16 001FEC16 DMA2 mode register L 001FED16 DMA2 mode register H 001FE16 DMA2 control register 001FF016 DMA2 control register 001FF016 Description 001FF216 Description 001FF316 Destination address register 3 001FF316 Destination address register 3 001FF316 H 001FF316 Destination address register 3 001FF316 H | | | | | 001FEC16 DMA2 mode register L 001FED16 DMA2 mode register H 001FE16 DMA2 control register 001FF016 DMA2 control register 001FF016 M 001FF216 M 001FF316 M 001FF516 Destination address register 3 M 001FF316 Destination address register 3 M 001FF316 Destination address register 3 M 001FF316 Transfer counter register 3 M 001FF316 D01FF316 | | | • | | 001FED16 DMA2 mode register H 001FE16 DMA2 control register 001FF016 001FF016 001FF116 Source address register 3 001FF216 H 001FF316 Destination address register 3 001FF316 H 001FF | | DMA2 mode register L | | | 001FEE16 DMA2 control register 001FF016 001FF016 001FF116 Source address register 3 M 001FF216 H 001FF316 Destination address register 3 M 001FF516 Destination address register 3 M 001FF716 H H 001FF816 Transfer counter register 3 M 001FF816 H H 001FF816 H H 001FF816 H H 001FF816 H H 001FF816 H H 001FF816 DMA3 mode register L DMA3 mode register H 001FF816 DMA3 control register DMA3 control register | | | | | 001FEF16 001FF016 001FF116 Source address register 3 001FF216 H 001FF316 L 001FF316 Destination address register 3 001FF316 H 001FF716 H 001FF816 Destination address register 3 001FF816 H D | | | | | 001FF116 Source address register 3 M 001FF216 H H 001FF316 Destination address register 3 M 001FF316 Destination address register 3 M 001FF316 H H 001FF316 Double address register 3 M 001FF316 H H 001FF316 H H 001FF316 H H 001FF316 H H 001FF316 H H 001FF316 DMA3 mode register L DMA3 mode register H 001FF316 DMA3 control register DMA3 control register | | , | | | 001FF116 Source address register 3 M 001FF216 H H 001FF316 Destination address register 3 M 001FF316 Destination address register 3 M 001FF316 H H 001FF316 Double address register 3 M 001FF316 H H 001FF316 H H 001FF316 H H 001FF316 H H 001FF316 H H 001FF316 DMA3 mode register L DMA3 mode register H 001FF316 DMA3 control register DMA3 control register | 001FF016 | | L | | 001FF216 H 001FF316 L 001FF416 Destination address register 3 M 001FF516 H 001FF716 H 001FF816 Destination address register 3 M 001FF816 H 001FF316 001FF31 | | Source address register 3 | M | | 001FF316 L 001FF516 Destination address register 3 M/H 001FF616 H 001FF716 H 001FF816 001FF816 001FF416 H 001FF416 H 001FF816 H 001FF816 H 001FF816 DMA3 mode register L 001FF016 DMA3 mode register H 001FF16 DMA3 control register | | Ü | | | 001FF416 Destination address register 3 M/H 001FF616 H 001FF716 H 001FF816 Transfer counter register 3 M/H 001FF316 H 001FF316 H 001FF316 H 001FF316 DMA3 mode register L 001FF316 DMA3 mode register H 001FF316 DMA3 control register | | | - | | 001FF516 Destination address register 3 M H 001FF616 H 001FF716 H 001FF816 Transfer counter register 3 M H 001FF316 H 001FF316 H 001FF316 DMA3 mode register L 001FF016 DMA3 mode register H 001FF516 DMA3 control register | | | | | 001FF616 H 001FF716 H 001FF816 Transfer counter register 3 M 001FF316 H 001FF316 H 001FF316 DMA3 mode register L 001FF016 DMA3 mode register H 001FF16 DMA3 control register | | Destination address register 3 | | | 001FF716 L 001FF816 M 001FF316 M 001FF316 H 001FF316 M 001FF316 M 001FF016 DMA3 mode register L 001FF016 DMA3 mode register H 001FF516 DMA3 control register | | Decimation address register s | | | 001FF816 001FF916 L 001FF316 M H 001FF316 H H 001FF316 DMA3 mode register L DMA3 mode register H 001FF316 DMA3 control register | | | - '' | | 001FF916 Transfer counter register 3 M 001FFA16 H 001FFB16 DMA3 mode register L 001FFD16 DMA3 mode register H 001FFE16 DMA3 control register | | | 1 | | 001FFA16 H 001FFB16 DMA3 mode register L 001FFD16 DMA3 mode register H 001FFE16 DMA3 control register | | Transfer counter register 3 | | | 001FFB16 DMA3 mode register L 001FFD16 DMA3 mode register H 001FFE16 DMA3 control register | | | | | 001FFC16 DMA3 mode register L 001FFD16 DMA3 mode register H 001FFE16 DMA3 control register | | | П | | 001FFD16 DMA3 mode register H 001FFE16 DMA3 control register | | DMA3 mode register I | | | 001FFE16 DMA3 control register | | | | | | | | | | VV 11 11 10 [ | UU1FFE16 | | | | | | | | Fig. 2.4.3 SFR area's memory map (2) Fig. 2.4.4 Structure of processor mode registers 0, 1 2.5 Bus access right # 2.5 Bus access right The M37721's bus is used for DRAMC, Hold function, and DMAC besides CPU. When the bus requests of two or more source are detected at the same timing, the highest bus access priority levels get the access right. The bus priority levels are fixed by hardware. Additionally the bus use state is output from the status signal output pins ST0 and ST1. Table 2.5.1 lists the bus use priority levels and the status signals depending on the bus use state. Table 2.5.1 Bus use priority levels and status signals depending on bus use state | Bus use priority levels | Due use state | Status signal | | |-------------------------|-------------------------------------------------------|---------------|-----| | | Bus use state | ST1 | ST0 | | 1 (Highest) | DRAM refresh | 0 | 0 | | 2 | Hold | 0 | 1 | | 3 | DMAC | 1 | 0 | | 4 (Lowest) | CPU (Including the term that CPU does not use the bus | 1 | 1 | | | during calculation etc.) | | | For details, refer to section "13.2.1 Bus access control circuit" and chapter for each peripheral devices. 2.5 Bus access right **MEMORANDUM** # CHAPTER 3 CONNECTION WITH **EXTERNAL DEVICES** - 3.1 Signals required for accessing external devices - 3.2 Software Wait - 3.3 Ready function - 3.4 Hold function [Precautions for Hold function] ## 3.1 Signals required for accessing external devices # 3.1 Signals required for accessing external devices The functions and operations of the signals which are required for accessing the external devices are described below. When connecting an external device that requires long access time, refer to sections "3.2 Software Wait," "3.3 Ready function," and "3.4 Hold function," as well as this section. When the external DRAM is controlled by using DRAM controller, refer to "CHAPTER 14. DRAM CONTROLLER." #### 3.1.1 Descriptions of signals Figure 3.1.1 shows the pin configurations when the external data bus width is 16 bits and 8 bits. #### (1) External buses $(A_0-A_7, A_8/D_8-A_{15}/D_{15}, A_{16}/D_0-A_{23}/D_7)$ The external area is specified by the address (A<sub>0</sub>-A<sub>23</sub>) output. The $A_8$ – $A_{23}$ pins of the external address bus and the $D_0$ – $D_{15}$ pins of the external data bus are assigned to the same pins. When the BYTE pin level, described later, is "L" (external data bus width is 16 bits), the $A_8/D_8-A_{15}/D_{15}$ and $A_{16}/D_0-A_{23}/D_7$ pins perform address output and data input/output with time-sharing. When the BYTE pin level is "H" (external data bus width is 8 bits), the $A_{16}/D_0-A_{23}/D_7$ pins perform address output and data input/output with time-sharing, and the $A_8-A_{15}$ pins output the address. #### (2) External data bus width switching signal (BYTE pin level) This signal is used to select the external data bus width from 8 bits and 16 bits. The width is 16 bits when the level is "L," and 8 bits when the level is "H." Fix this signal to either "H" or "L" level. This signal is valid only for the external area. (When accessing the internal area, the data bus width is always 16 bits.) #### (3) Enable signal (E) This signal becomes "L" level while reading or writing data from and to the data bus. (Refer to "Table 3.1.1.") #### (4) Read/Write signal (R/W) This signal indicates the state of the data bus. This signal becomes "L" level while writing data to the data bus. Table 3.1.1 lists the state of the data bus indicated with the $\overline{E}$ and $R/\overline{W}$ signals. Table 3.1.1 State of data bus indicated with E and R/W signals | | N/W Signais | | | | |---|-------------|-------------------|--|--| | E | R/W | State of data bus | | | | Н | Н | Not used | | | | | L | | | | | L | Н | Read data | | | | | L | Write data | | | 3.1 Signals required for accessing external devices Fig. 3.1.1 Pin configurations when external data bus width is 16 bits and 8 bits (top view) ## 3.1 Signals required for accessing external devices #### (5) Byte low enable signal (BLE), Byte high enable signal (BHE) The BLE signal indicates the access to an even address. This signal becomes "L" level when accessing only an even address or when simultaneously accessing both an even and an odd address. The BHE signal indicates the access to an odd address. This signal becomes "L" level when accessing only an odd address or when simultaneously accessing both an odd and an even address. These signals are used to connect memories or I/O devices of which data bus width is 8 bits when the external data bus width is 16 bits. Table 3.1.2 lists levels of the BLE and BHE signals and access addresses. Table 3.1.2 Levels of BLE and BHE signals and access addresses | Access address | Even and odd addresses | Even address | Odd address | |----------------|------------------------------|-----------------|-----------------| | | (Simultaneous 2-byte access) | (1-byte access) | (1-byte access) | | BLE | L | L | Н | | BHE | L | Н | L | #### (6) Address latch enable signal (ALE) This signal is used to latch the address from the multiplexed signal, which consists of the address and data. (This multiplexed signal is input to or output from the $A_8/D_8-A_{15}/D_{15}$ and $A_{16}/D_0-A_{23}/D_7$ pins.) When the ALE signal is "H," latch the address and simultaneously output the addresses. When this signal is "L," retain the latched address. #### (7) Ready function-related signal (RDY) This is the signal to use Ready function (Refer to section "3.3 Ready function.") #### (8) Hold function-related signal (HOLD) This is the signal to use Hold function. (Refer to section "3.4 Hold function.") #### (9) Status signals (ST0, ST1) These signals indicate the bus use status. Table 3.1.3 lists the bus use status indicated by the ST0 and ST1 signals. #### (10) Clock $\phi_1$ This signal has the same period as $\phi$ . Table 3.1.3 Bus use status indicated by ST0 and ST1 signals | | 3.1 o.ga.o | | | | | |-----|------------|----------------|--|--|--| | ST1 | ST0 | Bus use status | | | | | L | L | DRAM refresh | | | | | L | Н | Hold | | | | | Н | L | DMA | | | | | Н | Н | CPU | | | | ## 3.1 Signals required for accessing external devices #### 3.1.2 Operation of bus interface unit (BIU) Figures 3.1.2 and 3.1.3 show the examples of operating waveforms of the signals input from or output to the external when accessing external devices. The following explains these waveforms, being compared with the basic operating waveform. (Refer to section "2.2.3 Operation of bus interface unit (BIU).") #### (1) When fetching instructions into instruction queue buffer - ① When the instruction which is next fetched is located at an even address When the external data bus width is 16 bits, the BIU fetches 2 bytes of the instruction at a time with waveform (a). When the external data bus width is 8 bits, the BIU fetches only 1 byte of the instruction with the first half of waveform (e). - When the instruction which is next fetched is located at an odd address. When the external data bus width is 16 bits, the BIU fetches only 1 byte of the instruction with waveform (d). When the external data bus width is 8 bits, the BIU fetches only 1 byte of the instruction with the first half of waveform (f). When a branch to an odd address is caused by a branch instruction etc. with the 16-bit external data bus width, the BIU first fetches 1 byte of the instruction with waveform (d), and after that, fetches instructions in a unit of 2 bytes with waveform (a). #### (2) When reading or writing data from and to memories or I/O devices - ① When accessing 16-bit data which begins at an even address, waveform (a) or (e) is applied. - 2 When accessing 16-bit data which begins at an odd address, waveform (b) or (f) is applied. - 3 When accessing 8-bit data at an even address, waveform (c) or the first half of (e) is applied. - 4 When accessing 8-bit data at an odd address, waveform (d) or the first half of (f) is applied. For instructions that are affected by the data length flag (m) and the index register length flag (x), operation 3 or 4 is applied when flag m or x = "0"; operation 3 or 4 is applied when flag m or x = "1" The setup of flags m and x and the selection of the external data bus width do not affect each other. 3.1 Signals required for accessing external devices Fig. 3.1.2 Examples of operating waveforms of signals input from or output to the external (1) 3.1 Signals required for accessing external devices Fig. 3.1.3 Examples of operating waveforms of signals input from or output to the external (2) #### 3.2 Software Wait ## 3.2 Software Wait Software Wait provides a function to facilitate access to external devices that require long access time. To select the software Wait, use the wait bit (bit 2 at address 5E<sub>16</sub>). Figure 3.2.1 shows the structure of processor mode register 0 (address 5E<sub>16</sub>). Figure 3.2.2 shows examples of bus timing when software Wait is used. Software Wait is valid only for the eternal area. The internal area is always accessed with no Wait. Fig. 3.2.1 Structure of processor mode register 0 3.2 Software Wait Fig. 3.2.2 Examples of bus timing when software Wait is used (BYTE = "L") # 3.3 Ready function # 3.3 Ready function Ready function provides the function to facilitate access to external devices that require long access time. The microcomputer enters Ready state by input of "L" level to the $\overline{RDY}$ pin and retains this state while the level of the $\overline{RDY}$ pin is at "L." Table 3.3.1 lists the microcomputer's state in Ready state. In Ready state, the oscillator's oscillation does not stop. Accordingly, the internal peripheral devices can operate. Ready function is valid for the internal and external areas. Table 3.3.1 Microcomputer's state in Ready state | Item | State | |-------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------| | Oscillation | Operating | | <b>ф</b> СРU, <b>ф</b> | Stopped at "L" | | Pins $A_0$ to $A_7$ , $A_8/D_8$ to $A_{15}/D_{15}$ , $A_{16}/D_0$ to $A_{23}/D_7$ , $\overline{E}$ , $R/\overline{W}$ , | Retain the state when Ready request was accepted. | | BHE, BLE, ST0, ST1, ALE | | | Pins P4 <sub>3</sub> to P4 <sub>7</sub> , P5 to P10 (Note) | | | Pin $\phi_1$ | Outputs clock φ <sub>1</sub> . | | Watchdog timer | Operating | Note: This applies when this functions as a programmable I/O port. 3.3 Ready function #### 3.3.1 Operation description The input level of the $\overline{RDY}$ pin is judged at the falling edge of clock $\phi_1$ . When "L" level is detected at this point, the microcomputer enters Ready state. (This is called "Acceptance of Ready request.") In Ready state, the input level of the $\overline{RDY}$ pin is judged at every falling edge of clock $\phi_1$ . When "H" level is detected at this point, the microcomputer terminates Ready state at the next rising edge of clock $\phi_1$ . Figure 3.3.1 shows timing of acceptance of Ready request and termination of Ready state. Refer also to section "16.1 Memory connection" for usage of Ready function. Fig. 3.3.1 Timing of acceptance of Ready request and termination of Ready state #### 3.4 Hold function #### 3.4 Hold function When composing the external circuit which accesses the bus without using the central processing unit (CPU), Hold function is used to generate a timing for transferring the right to use the bus from the CPU to the external circuit. The microcomputer enters Hold state by input of "L" level to the HOLD pin and retains this state while the level of the HOLD pin is at "L." Table 3.4.1 lists the microcomputer's state in Hold state. In Hold state, the oscillation of the oscillator does not stop. Accordingly, the internal peripheral devices can operate. However, Watchdog timer stops operating. Table 3.4.1 Microcomputer's state in Hold state | Item | State | |--------------------------------------------------------------------------------------------------------|--------------------------------------------------| | Oscillation | Operating | | $\overline{\phi}$ | Operating | | <i>φ</i> CPU | Stopped at "L" | | Ē | Stopped at "H" | | Pins $A_0$ to $A_7$ , $A_8/D_8$ to $A_{15}/D_{15}$ , $A_{16}/D_0$ to $A_{23}/D_7$ , $R/\overline{W}$ , | Floating | | BHE, BLE | | | Pins ALE, ST1 | Output "L" level. | | Pin ST0 | Outputs "H" level. | | Pin φ <sub>1</sub> | Outputs clock $\phi_1$ . | | Pins P4 <sub>3</sub> to P4 <sub>7</sub> , P5 to P10 (Note) | Retain the state when Hold request was accepted. | | Watchdog timer | Stopped | Note: This applies when this functions as a programmable I/O port. #### 3.4.1 Operation description Judgment of the HOLD pin input level is performed at every falling edge of $\phi_1$ . When "L" level is detected at judgment of the input level, bus request (Hold) becomes "1," when "H" level is detected, bus request (Hold) becomes "0." Bus request (Hold) is sampled within a period when the bus request sampling signal is "1" and bus request is accepted when there is no bus request (DRAMC). (This is called "Acceptance of Hold request.") For bus request, refer to section "13.2.1 Bus access control circuit." When Hold request is accepted, $\phi_{\text{CPU}}$ stops at "L" level at the next rising edge of $\phi$ and the ST0 pin's level becomes "H," the ST1 pin's level becomes "L." When 1 cycle of $\phi$ has passed after the levels of the ST0 and ST1 pins are changed, the R/W, $\overline{\text{BHE}}$ , $\overline{\text{BLE}}$ pins and the external bus enter the floating state. In Hold state, when the $\overline{\text{HOLD}}$ pin's input level becomes "H," the ST0 and ST1 pins' levels are changed at the next rising edge of $\phi$ . When 1 cycle of $\phi$ has passed after the levels of the ST0 and ST1 pins are changed, the microcomputer terminates Hold state. Figures 3.4.1 to 3.4.3 show timing of acceptance of Hold request and termination of Hold state. **Note:** $\phi$ has the same polarity and the same frequency as clock $\phi_1$ . However, $\phi$ stops by acceptance of Ready request, or executing the **STP** or **WIT** instruction. Accordingly, judgment of the input level of the $\overline{\text{HOLD}}$ pin is not performed during Ready state. <When inputting "L" level to HOLD pin while bus is unused> #### State when inputting "L" level to HOLD pin | External data bus | Data length | External data bus width | |-------------------|-------------|-------------------------| | Unused | 8 | 8, 16 | | Siladea | 16 | 8, 16 | This is the period in which the bus is not used, so that not a new address but the address which was output immediately before is output again. **Notes 1:** Clock $\phi_1$ has the same polarity and the same frequency as $\phi$ . Timing of signals to be input from or output to the external is ordained on the basis of clock $\phi_1$ . 2: Bus request (Hold) and bus request sampling are internal signals. Fig. 3.4.1 Timing of acceptance of Hold request and termination of Hold state (1) #### 3.4 Hold function <When inputting "L" level to HOLD pin while bus is used; when data access is completed with 1-bus cycle> ## ● State when inputting "L" level to HOLD pin | External data bus | Data length | External data bus width | |-------------------|-------------|---------------------------------------| | | 8 | 8, 16 | | Used | 16 | 16 (Access beginning at even address) | ① When a Hold request is accepted, not a new address but the address which was output immediately before is output again. **Notes 1:** The above diagram shows the case of no Wait. - **2:** Clock φ1 has the same polarity and the same frequency as φ. Timing of signals to be input from or output to the external is ordained on the basis of clock φ1. - **3**: Bus request (Hold) and bus request sampling are internal signals. Fig. 3.4.2 Timing of acceptance of Hold request and termination of Hold state (2) <When inputting "L" level to HOLD pin while bus is used; when data access is completed with continuous 2-bus cycle> #### ● State when inputting "L" level to HOLD pin | External data bus | Data length | External data bus width | |-------------------|-------------|--------------------------------------| | Head 16 | 8 | | | Used | 16 | 16 (Access beginning at odd address) | - ① When a Hold request is accepted, not a new address but the address which was output immediately before is output again. - Notes 1: The above diagram shows the case of 2-\$\phi\$ access in low-speed running. - 2: Clock φ1 has the same polarity and the same frequency as φ. Timing of signals to be input from or output to the external is ordained on the basis of clock φ1. - 3: Bus request (Hold) and bus request sampling are internal signals. Fig. 3.4.3 Timing of acceptance of Hold request and termination of Hold state (3) ## 3.4 Hold function # [Precautions for Hold function] When a DRAM refresh request occurs in Hold state, DRAM refresh is performed immediately because the bus use priority level of DRAM refresh is higher than that of Hold function. - 4.1 Hardware reset - 4.2 Software reset #### 4.1 Hardware reset ## 4.1 Hardware reset When the power source voltage satisfies the microcomputer's recommended operating conditions, the microcomputer is reset by supplying "L" level to the RESET pin. This is called a hardware reset. Figure 4.1.1 shows an example of hardware reset timing. Fig. 4.1.1 Example of hardware reset timing The following explains how the microcomputer operates in periods ① to ④ above. - ① After supplying "L" level to the RESET pin, the microcomputer initializes pins within a period of several ten ns. (Refer to "Table 4.1.1.") - While the RESET pin is "L" level and within a period of 4 to 5 cycles of $\phi$ after the RESET pin goes from "L" to "H," the microcomputer initializes the central processing unit (CPU) and SFR area. At this time, the contents of the internal RAM area become undefined (except when Stop or Wait mode is terminated). (Refer to "Figures 4.1.3 to 4.1.9.") - 3 After 2, the microcomputer performs "Internal processing sequence after reset." (Refer to "Figure 4.1.10.") - ④ The microcomputer executes a program beginning with the address set into the reset vector addresses (FFFE₁6 and FFFF₁6). #### 4.1.1 Pin state Table 4.1.1 lists the microcomputer's pin state while $\overline{\text{RESET}}$ pin is at "L" level. Figure 4.1.2 shows the $\overline{\text{RESET}_{\text{OUT}}}$ output retaining timing. Table 4.1.1 Pin state while RESET pin is at "L" level | Pin (Bus, Port) name | Pin state | |-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------| | A <sub>0</sub> /MA <sub>0</sub> –A <sub>7</sub> /MA <sub>7</sub> , A <sub>8</sub> /D <sub>8</sub> –A <sub>15</sub> /D <sub>15</sub> , A <sub>16</sub> /D <sub>0</sub> –A <sub>23</sub> /D <sub>7</sub> , BHE, BLE | Outputs "H" or "L" level. | | $R/\overline{W}$ , $\overline{E}$ , ST0, ST1 | Outputs "H" level. | | ALE, RESETout | Outputs "L" level. | | $\phi$ 1 | Outputs $\phi_1$ . | | HOLD, RDY, P43–P47, P5–P10 | Floating. | Fig. 4.1.2 RESETουτ output retaining timing ## RESET #### 4.1 Hardware reset #### 4.1.2 State of CPU, SFR area, and internal RAM area Figure 4.1.3 shows the state of the CPU registers immediately after reset. Figures 4.1.4 to 4.1.9 show the state of the SFR and internal RAM areas immediately after reset. Fig. 4.1.3 State of CPU registers immediately after reset # ●SFR area (016 to 7F16, 1FC016 to 1FFF16) #### **Access characteristics** RW: It is possible to read the bit state at reading. The written value becomes valid. RO: It is possible to read the bit state at reading. The written value becomes invalid. WO: The written value becomes valid. It is impossible to read the bit state. : Nothing is assigned. It is impossible to read the bit state. The written value becomes invalid. ## State immediately after reset - 0: "0" immediately after reset. - 1 : "1" immediately after reset. - ?: Underfined immediately after reset. 0 : Always "0" at reading. 1 : Always "1" at reading. ? : Always undefined at reading. : "0" immediately after reset. Fix this bit to "0." | Addre | ess Register name | Access characteristics | State immediately after reset b7 | | | | | | | | |------------------|-------------------------------|------------------------|----------------------------------|--|--|--|--|--|--|--| | | Tregister name | b7 b0 | b7 ? | | | | | | | | | 016 | | | ? | | | | | | | | | 116 | | | ? | | | | | | | | | 216 | | | ? | | | | | | | | | 316 | | | | | | | | | | | | <b>4</b> 16 | | | ? | | | | | | | | | 516 | | | ? | | | | | | | | | <b>6</b> 16 | | | ? | | | | | | | | | 716 | | | | | | | | | | | | 816 | | | ? | | | | | | | | | 916 | | | ? | | | | | | | | | A16 | Port P4 register | RW | ? 0000 | | | | | | | | | B16 | Port P5 register | RW | ? | | | | | | | | | C16 | Port P4 direction register | RW | 0 0 0 0 0 0 0 0 0 | | | | | | | | | D16 | Port P5 direction register | RW | 0016 | | | | | | | | | E16 | Port P6 register | RW | ? | | | | | | | | | F16 | Port P7 register | RW | ? | | | | | | | | | 1016 | Port P6 direction register | RW | 0016 | | | | | | | | | <b>11</b> 16 | Port P7 direction register | RW | 0016 | | | | | | | | | 1216 | Port P8 register | RW | ? | | | | | | | | | 1316 | Port P9 register | RW | ? | | | | | | | | | <b>14</b> 16 | Port P8 direction register | RW | 0016 | | | | | | | | | 1516 | Port P9 direction register | RW | 0016 | | | | | | | | | <b>16</b> 16 | Port P10 register | RW | ? | | | | | | | | | <b>17</b> 16 | | | ? | | | | | | | | | 1816 | Port P10 direction register | RW | 0016 | | | | | | | | | 1916 | | | ? | | | | | | | | | 1A16 | Pulse output data register 0 | WO WO | ? | | | | | | | | | 1B <sub>16</sub> | | | ? | | | | | | | | | 1C <sub>16</sub> | Pulse output data register 1 | WO | ? | | | | | | | | | 1D16 | | | ? | | | | | | | | | 1E16 | A-D control register | RW | 0 0 0 0 0 ? ? ? | | | | | | | | | 1F16 | A-D sweep pin select register | RW | ? ? ? ? ? ? ? 1 1 | | | | | | | | Fig. 4.1.4 State of SFR and internal RAM areas immediately after reset (1) # **RESET** # 4.1 Hardware reset | Address | Register name | Access characteristics b0 | State immediately after reset b0 | |--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|-----------------------------------------------------------------------------------------| | 2016 | A-D register 0 | RO | ? | | 2116 | | | ? | | 2216 | A-D register 1 | RO | ? | | 2316 | | | ? | | 2416 | A-D register 2 | RO | ? | | 2516 | | | ? | | 2616 | A-D register 3 | RO | ? | | 2716 | | | ? | | 2816 | A-D register 4 | RO | ? | | 2916 | | | ? | | 2A16 | A-D register 5 | RO | ? | | 2B16 | | | ? | | 2C16 | A-D register 6 | RO | ? | | 2D16 | | | ? | | 2E16 | A-D register 7 | RO | ? | | 2F16 | | | ? | | 3016 | UART0 transmit/receive mode register | RW | 0016 | | 3116 | UART0 baud rate register | WO | ? | | 3216 | UART0 transmit buffer register | WO | ? | | 3316 | | WO | ? | | | JART0 transmit/receive control register 0 | RO RW | ? ? ? ? 1 0 0 0 | | | JART0 transmit/receive control register 1 | RO RW RO RW | 0 0 0 0 0 0 1 0 | | 3616 | UART0 receive buffer register | RO | ? | | 3716 | | RO | 0 0 0 0 0 0 0 ? | | 3816 | UART1 transmit/receive mode register | RW | 0016<br>? | | 3916 | UART1 baud rate register | WO | ? | | 3A16 | UART1 transmit buffer register | WO | ? | | 3B16 | LIADTA transportation and transportation of the control con | RO RW | | | | UART1 transmit/receive control register 0 | RO RW RORW | ? ? ? ? 1 0 0 0 0 0 0 0 0 1 0 | | 3D16<br>3E16 | UART1 transmit/receive control register 1 | | ? | | 3E16<br>3F16 | UART1 receive buffer register | RO RO | 0 0 0 0 0 0 0 ? | | J. 10 | | 1.0 | | Fig. 4.1.5 State of SFR and internal RAM areas immediately after reset (2) **Notes 1:** The access characteristics at addresses 4A<sub>16</sub> to 4F<sub>16</sub> vary according to Timer A's operating mode. (Refer to "**CHAPTER 8. TIMER A.**") - 2: The access characteristics at addresses 5016 to 5316 vary according to Timer B's operating mode. (Refer to "CHAPTER 9. TIMER B.") - 3: The access characteristics for bit 5 at addresses 5B16 and 5C16 vary according to Timer B's operating mode. Bit 5 at address 5D16 is invalid. (Refer to "CHAPTER 9. TIMER B.") - 4: Bit 1 at address 5F16 becomes "0" immediately after reset. For the M37721S1BFP, fix this bit to "0" Fig. 4.1.6 State of SFR and internal RAM areas immediately after reset (3) # 4.1 Hardware reset | Addres | s Register name | b7 | Acces | s cha | aracte | eristics b0 | b | Sta | ate i | mme | ediat | ely a | after | rese | et<br>b0 | |--------------|---------------------------------------------|----|----------|-------|-----------|-------------|---|-----|-------|-----|-------|-------|-------|------|----------| | 6016 | Watchdog timer register | | | (No | te 5) | | | | | | ?(No | ote 6 | ) | | | | <b>61</b> 16 | Watchdog timer frequency select register | | | | | RW | | | | | ? | | | | 0 | | 6216 | Real-time output control register | | | | | RW | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 6316 | | | | | | | | | | | | ? | | | | | 6416 | DRAM control register | RW | | | | RW | L | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | <b>65</b> 16 | | | | | | | | | | | | ? | | | | | <b>66</b> 16 | Refresh timer | | | V | <b>/O</b> | | | | | | | ? | | | | | <b>67</b> 16 | | | | | | | | | | | | ? | | | | | <b>68</b> 16 | DMAC control register L | | (Note 7) | ) | | RW | | 0 | 0 | 0 | 0 | ? | ? | 0 | 0 | | <b>69</b> 16 | DMAC control register H | | RW | | | WO | L | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 6A16 | | | | | | | | | | | | ? | | | | | 6B16 | | | | | | | | | | | | ? | | | | | 6C16 | DMA0 interrupt control register | | | | | RW | | | | ? | | 0 | 0 | 0 | 0 | | 6D16 | DMA1 interrupt control register | | | | | RW | | | | ? | | 0 | 0 | 0 | 0 | | 6E16 | DMA2 interrupt control register | | | | | RW | | | | ? | | 0 | 0 | 0 | 0 | | 6F16 | DMA3 interrupt control register | | | | | RW | | | | ? | | 0 | 0 | 0 | 0 | | 7016 | A-D conversion interrupt control register | | | | | RW | | | | ? | | 0 | 0 | 0 | 0 | | <b>71</b> 16 | UART0 transmit interrupt control register | | | | | RW | | | | ? | | 0 | 0 | 0 | 0 | | 7216 | UART0 receive interrupt control register | | | | | RW | | | | ? | | 0 | 0 | 0 | 0 | | 7316 | UART1 transmit interrupt control register | | | | | RW | | | | ? | | 0 | 0 | 0 | 0 | | 7416 | UART1 receive interrupt control register | | | | | RW | | | | ? | | 0 | 0 | 0 | 0 | | 7516 | Timer A0 interrupt control register | | | | | RW | | | | ? | | 0 | 0 | 0 | 0 | | <b>76</b> 16 | Timer A1 interrupt control register | | | | | RW | | | | ? | | 0 | 0 | 0 | 0 | | 7716 | Timer A2 interrupt control register | | | | | RW | | | | ? | | 0 | 0 | 0 | 0 | | 7816 | Timer A3 interrupt control register | | | | | RW | | | | ? | | 0 | 0 | 0 | 0 | | 7916 | Timer A4 interrupt control register | | | | | RW | | | | ? | | 0 | 0 | 0 | 0 | | 7A16 | Timer B0 interrupt control register | | | | | RW | | | | ? | | 0 | 0 | 0 | 0 | | 7B16 | Timer B1 interrupt control register | | | | | RW | | | | ? | | 0 | 0 | 0 | 0 | | 7C16 | Timer B2 interrupt control register | | | | | RW | | | | ? | | 0 | 0 | 0 | 0 | | 7D16 | INTo interrupt control register | | | | R۷ | ٧ | | | ? | 0 | 0 | 0 | 0 | 0 | 0 | | 7E16 | INT <sub>1</sub> interrupt control register | | | | R۷ | | | | ? | 0 | 0 | 0 | 0 | 0 | 0 | | 7F16 | INT2 interrupt control register | | | | R۷ | V | | | ? | 0 | 0 | 0 | 0 | 0 | 0 | **Notes 5:** By writing dummy data to address 6016, the value "FFF16" is set to the watchdog timer. The dummy data is not retained anywhere. Fig. 4.1.7 State of SFR and internal RAM areas immediately after reset (4) <sup>6:</sup> The value "FFF16" is set to the watchdog timer. (Refer to "CHAPTER 15. WATCHDOG TIMER.") <sup>7:</sup> It is possible to read the bit state at reading. When writing "0" to this bit, this bit becomes "0." But when writing "1" to this bit, this bit does not change. | Address | Register name | Access characteristics b0 | State immediately after reset b0 | |--------------------|--------------------------------|---------------------------|----------------------------------| | 1FC016 | | RW | ? | | 1FC116 | Source address register 0 | RW | ? | | 1FC216 | | RW | ? | | 1FC316 | | | ? | | 1FC416 | | RW | ? | | 1FC516 | Destination address register 0 | RW | ? | | 1FC616 | | RW | ? | | 1FC716 | | | ? | | 1FC816 | | RW | ? | | 1FC916 | Transfer counter register 0 | RW | ? | | 1FCA <sub>16</sub> | | RW | ? | | 1FCB <sub>16</sub> | | | ? | | 1FCC <sub>16</sub> | DMA0 mode register L | RW | 0 0 0 0 0 0 0 0 | | 1FCD <sub>16</sub> | DMA0 mode register H | RW | 0 0 0 0 0 0 0 0 | | 1FCE <sub>16</sub> | DMA0 control register | RW | ? ? 0 0 0 0 0 0 | | 1FCF <sub>16</sub> | | | ? | | 1FD016 | | RW | ? | | 1FD116 | Source address register 1 | RW | ? | | 1FD216 | | RW | ? | | 1FD316 | | | ? | | 1FD416 | | RW | ? | | 1FD516 | Destination address register 1 | RW | ? | | 1FD616 | | RW | ? | | 1FD7 <sub>16</sub> | | | ? | | 1FD816 | | RW | ? | | 1FD916 | Transfer counter register 1 | RW | ? | | 1FDA <sub>16</sub> | | RW | ? | | 1FDB <sub>16</sub> | | | ? | | 1FDC <sub>16</sub> | DMA1 mode register L | RW | 0 0 0 0 0 0 0 | | 1FDD <sub>16</sub> | DMA1 mode register H | RW | 0 0 0 0 0 0 0 0 | | 1FDE <sub>16</sub> | DMA1 control register | RW | ? ? 0 0 0 0 0 0 | | 1FDF16 | | | ? | Fig. 4.1.8 State of SFR and internal RAM areas immediately after reset (5) # 4.1 Hardware reset | 1FE016<br>1FE116 | Register name | Access characteristics b0 | State immediately after reset b0 | |--------------------|--------------------------------|---------------------------|----------------------------------| | 1FE116 | 1 | RW | ? | | | Source address register 2 | RW | ? | | 1FE216 | - | RW | ? | | 1FE316 | | | ? | | 1FE416 | 1 | RW | ? | | 1FE516 | Destination address register 2 | RW | ? | | 1FE616 | - | RW | ? | | 1FE7 <sub>16</sub> | | | ? | | 1FE816 | 1 | RW | ? | | 1FE916 | Transfer counter register 2 | RW | ? | | 1FEA <sub>16</sub> | 3 | RW | ? | | 1FEB <sub>16</sub> | · · | | ? | | 1FEC <sub>16</sub> | DMA2 mode register L | RW | 0 0 0 0 0 0 0 0 | | 1FED <sub>16</sub> | DMA2 mode register H | RW | 0 0 0 0 0 0 0 | | 1FEE <sub>16</sub> | DMA2 control register | RW | ? ? 0 0 0 0 0 0 | | 1FEF16 | 2 <u>12 00</u> 0 | | ? | | 1FF016 | ( | RW | ? | | 1FF1 <sub>16</sub> | Source address register 3 | RW | ? | | 1FF2 <sub>16</sub> | | RW | ? | | 1FF3 <sub>16</sub> | · | | ? | | 1FF416 | 1 | RW | ? | | 1FF516 | Destination address register 3 | RW | ? | | 1FF616 | J | RW | ? | | 1FF7 <sub>16</sub> | | | ? | | 1FF8 <sub>16</sub> | ſ | RW | ? | | 1FF9 <sub>16</sub> | Transfer counter register 3 | RW | ? | | 1FFA <sub>16</sub> | | RW | ? | | 1FFB <sub>16</sub> | | | ? | | 1FFC <sub>16</sub> | DMA3 mode register L | RW | 0 0 0 0 0 0 0 0 | | 1FFD <sub>16</sub> | DMA3 mode register H | RW | 0 0 0 0 0 0 0 0 | | 1FFE <sub>16</sub> | DMA3 control register | RW | ? ? 0 0 0 0 0 0 | | 1FFF16 | | | ? | Fig. 4.1.9 State of SFR and internal RAM areas immediately after reset (6) #### 4.1.3 Internal processing sequence after reset Figure 4.1.10 shows the internal processing sequence after reset. Fig. 4.1.10 Internal processing sequence after reset #### 4.1 Hardware reset #### 4.1.4 Time supplying "L" level to RESET pin Time supplying "L" level to the RESET pin varies according to the state of the clock oscillation circuit. - •When the oscillator is stably oscillating or a stable clock is input from the XIN pin, supply "L" level for 2 $\mu$ s or more. - •When the oscillator is not stably oscillating (including the case at power-on reset or in Stop mode), supply "L" level until the oscillation is stabilized. The time required for stabilizing oscillation varies according to the oscillator. For details, contact the oscillator manufacturer. Figure 4.1.11 shows the power-on reset conditions. Figure 4.1.12 shows an example of a power-on reset circuit. \* For details about Stop mode, refer to section "5.3 Stop mode." For details about clocks, refer to "CHAPTER 5. CLOCK GENERATING CIRCUIT." Fig. 4.1.11 Power-on reset conditions Fig. 4.1.12 Example of power-on reset circuit #### 4.2 Software reset When the power source voltage satisfies the microcomputer's recommended operating conditions, the microcomputer is reset by writing "1" to the software reset bit (bit 3 at address 5E<sub>16</sub>). (This is called "Software reset.") In this case, the microcomputer initializes pins, CPU, and SFR area just as in the case of a hardware reset. However, the microcomputer retains the contents of the internal RAM area. (Refer to "Table 4.1.1" and "Figures 4.1.3 to 4.1.9.") Figure 4.2.1 shows the structure of the processor mode register 0 (address 5E<sub>16</sub>). After completing initialization, the microcomputer performs "internal processing sequence after reset." (Refer to "Figure 4.1.10.") After that, it executes a program beginning from the address set into the reset vector addresses (FFFE<sub>16</sub> and FFFF<sub>16</sub>). Fig. 4.2.1 Structure of processor mode register 0 # RESET #### 4.2 Software reset When the software reset bit is set to "1," the $\overline{\text{RESET}_{\text{OUT}}}$ pin's output level becomes "L." In a period of 4.5 cycles of clock $\phi_1$ after the software reset bit is set to "1," the $\overline{\text{RESET}_{\text{OUT}}}$ pin's output level is "L." Figure 4.2.2 shows the $\overline{\text{RESET}_{\text{OUT}}}$ output timing at software reset. Fig. 4.2.2 RESETout output timing # CHAPTER 5 CLOCK GENERATING CIRCUIT - 5.1 Oscillation circuit examples - 5.2 Clocks - 5.3 Stop mode [Precautions for Stop mode] 5.4 Wait mode [Precautions for Wait mode] #### 5.1 Oscillation circuit examples #### 5.1 Oscillation circuit examples To the oscillation circuit, a ceramic resonator or a quartz-crystal oscillator can be connected, or the clock which is externally generated can be input. Oscillation circuit examples are shown below. #### 5.1.1 Connection example using resonator/oscillator Figure 5.1.1 shows an example when connecting a ceramic resonator/quartz-crystal oscillator between pins $X_{IN}$ and $X_{OUT}$ . The circuit constants such as Rf, Rd, $C_{IN}$ , and $C_{OUT}$ (shown in "Figure 5.1.1") depend on the resonator/oscillator. These values shall be set to the values recommended by the resonator/oscillator manufacturer. #### 5.1.2 Externally generated clock input example Figure 5.1.2 shows an input example of the clock which is externally generated. The external clock must be input from the $X_{\text{IN}}$ pin, and the $X_{\text{OUT}}$ pin must be left open. Fig. 5.1.1 Connection example using resonator/oscillator Fig. 5.1.2 Externally generated clock input example #### 5.2 Clocks Figure 5.2.1 shows the clock generating circuit block diagram. Fig. 5.2.1 Clock generating circuit block diagram #### 5.2 Clocks #### 5.2.1 Clocks generated in clock generating circuit **(1)** φ It is the operation clock of BIU. It is also the clock source of $\phi_{\text{CPU}}$ . $\phi$ stops by acceptance of Ready request or execution of the **STP** or **WIT** instruction. It is not stopped by acceptance of bus request. (2) $\phi_{CPU}$ It is the operation clock of CPU. $\phi_{CPU}$ stops by the following: - •Execution of the STP or WIT instruction, - •Acceptance of Ready request; "L" level input to the RDY pin - •CPU wait request from BIU; Acceptance of bus request is included. #### (3) Clock $\phi_1$ It has the same period as $\phi$ and is output to the external from the $\phi_1$ pin. Clock $\phi_1$ stops by execution of the **STP** instruction. It is not stopped by acceptance of Ready or bus request, or execution of the WIT instruction. #### (4) f<sub>2</sub> to f<sub>512</sub> Each of them is the internal peripheral devices' operation clock. Note: Refer to each functional description for details: •Execution of STP instruction ...... "5.3 Stop mode" •Execution of WIT instruction ...... "5.4 Wait mode" •Ready ......"3.3 Ready function" •Bus request ......"13.2.1 Bus access control circuit" 5.3 Stop mode #### 5.3 Stop mode Stop mode is used to stop oscillation when there is no need to operate the central processing unit (CPU). The microcomputer enters Stop mode when the **STP** instruction is executed. Stop mode can be terminated by an interrupt request occurrence or the hardware reset. #### 5.3.1 Stop mode When the **STP** instruction is executed, the oscillator stops oscillating. This state is called "Stop mode." In Stop mode, the contents of the internal RAM can be retained intact when Vcc (power source voltage) is 2 V or more. Additionally, the microcomputer's power consumption is lowered. It is because the CPU and all internal peripheral devices using clocks $f_2$ to $f_{512}$ stop the operation. Table 5.3.1 lists the microcomputer's state and operation in and after Stop mode. Table 5.3.1 Microcomputer's state and operation in and after Stop mode | Item | | Item | State and Operation | | |-------------------|------------------------------|-----------------|-----------------------------------------------------------------------------------|--| | State in | Oscillation | | | | | Stop mode | $\phi$ CPU, $\phi$ | | Stopped | | | | Clock $\phi$ 1, f2 to f512 | | | | | | | Timers A, B | Can operate only in event counter mode | | | | <u>ra</u> | Serial I/O | Can operate only when an external clock is selected | | | | peripheral | A-D converter | Ctannad | | | | peri | DMA controller | Stopped | | | | | DRAM controller | Stopped (Note) | | | | Internal<br>devices | Watchdog timer | Stopped | | | | <u>ہ</u> ہ | Pins | Retains the same state in which the STP instruction was executed | | | Operation | By interrupt request | | Supply of $\phi_{ exttt{CPU}}$ and $\phi$ starts after a certain time measured by | | | after terminating | after terminating occurrence | | Watchdog timer has passed. | | | Stop mode | By hardware reset | | Operates in the same way as hardware reset | | Note: DRAM refresh is not performed because the refresh timer also stops. #### 5.3 Stop mode #### (1) Termination by interrupt request occurrence When terminating Stop mode by interrupt request occurrence, instructions are executed after a certain time measured by the watchdog timer has passed. - ① When an interrupt request occurs, the oscillator starts oscillating. Simultaneously, supply of clock $\phi_1$ , $f_2$ to $f_{512}$ starts. - ② The watchdog timer starts counting owing to the oscillation start. The watchdog timer counts f<sub>32</sub> regardless of the watchdog timer frequency select bit's (bit 0 at address 61<sub>16</sub>) contents. - ③ When the watchdog timer's MSB becomes "0," supply of $\phi_{\text{CPU}}$ and $\phi$ starts. At the same time, the watchdog timer's count source returns to $f_{32}$ or $f_{512}$ that is selected by the watchdog timer frequency select bit. - ④ The interrupt request which occurred in ① is accepted. Table 5.3.2 lists the interrupts used to terminate Stop mode. Table 5.3.2 Interrupts used to terminate Stop mode | Interrupt | Conditions for using each function to generate interrupt request | | |-------------------------------------|------------------------------------------------------------------|--| | INTi interrupt (i = 0 to 2) | | | | Timer Ai interrupt (i = 2 to 4) | In event counter mode | | | Timer Bi interrupt (i = 0, 1) | | | | UARTi transmit interrupt (i = 0, 1) | When external clock is selected | | | UARTi receive interrupt (i = 0, 1) | | | - **Notes 1:** Since the oscillator has stopped oscillating, interrupts not listed above cannot be used. Also, even the interrupts listed above cannot be used when the above conditions are not satisfied. The A-D converter does not operate, also. - 2: When multiple interrupts listed above are enabled, Stop mode is terminated by the interrupt request which occurs first. - **3:** Refer to "CHAPTER 7. INTERRUPTS" and the description of each internal peripheral device for details about each interrupt. Before executing the **STP** instruction, interrupts used to terminate Stop mode must be enabled. In addition, the interrupt priority level of the interrupt used to terminate Stop mode must be higher than the processor interrupt priority level (IPL) of the routine where the **STP** instruction is executed. When multiple interrupts in Table 5.3.2 are enabled, Stop mode is terminated by the first interrupt request. There is a possibility that any of all interrupt requests occurs after the oscillation starts in 1 and until supply of $\phi_{\text{CPU}}$ and $\phi$ starts in 3. The interrupt requests which occur during this period are accepted in order of priority after the watchdog timer's MSB becomes "0." For interrupts not to be accepted, set their interrupt priority levels to level 0 (interrupt disabled) before executing the **STP** instruction. 5.3 Stop mode Fig. 5.3.1 Stop mode terminating sequence by interrupt request occurrence #### (2) Termination by hardware reset Supply "L" level to the $\overline{\text{RESET}}$ pin by using the external circuit until the oscillation of the oscillator is stabilized. The CPU and the SFR area are initialized in the same way as system reset. However, the internal RAM area retains the same contents as that before executing the **STP** instruction. The terminating sequence is the same as the internal processing sequence which is performed after reset. Refer to "CHAPTER 4. RESET" for details about reset. #### 5.3 Stop mode #### [Precautions for Stop mode] When executing the **STP** instruction after writing to an internal area or an external area, three **NOP** instructions must be inserted to complete the write operation before the **STP** instruction is executed. (Refer to "Figure 5.3.2.") STA A, XXXX; Write instruction NOP : NOP instruction inserted NOP ; STP ; STP instruction Fig. 5.3.2 NOP instruction insertion example 5.4 Wait mode #### 5.4 Wait mode Wait mode is used to stop $\phi_{\text{CPU}}$ and $\phi$ when there is no need to operate the central processing unit (CPU). The microcomputer enters Wait mode when the **WIT** instruction is executed. Wait mode can be terminated by an interrupt request occurrence or the hardware reset. #### 5.4.1 Wait mode When the **WIT** instruction is executed, $\phi_{CPU}$ and $\phi$ stop. The oscillator's oscillation is not stopped. This state is called "Wait mode." In Wait mode, the microcomputer's power consumption is lowered though Vcc (power source voltage) is maintained. Table 5.4.1 lists the microcomputer's state and operation in and after Wait mode. Table 5.4.1 Microcomputer's state and operation in and after Wait mode | Item | | Item | State and Operation | | |--------------------------|---------------------------------|-----------------|--------------------------------------------------------------------|--| | State in | Oscillation | | Operating | | | Wait mode | ait mode $\phi$ CPU, $\phi$ | | Stopped | | | | Clock $\phi_1$ , f2 to f512 | | Operating | | | | peripheral devices | Timer A | | | | | | Timer B | Operating | | | | | Serial I/O | | | | | | A-D converter | | | | | eripl | DMA controller | Stopped | | | | | DRAM controller | Stopped (Note) | | | | Internal | Watchdog timer | Operating | | | | | Pins | Retains the same state in which the WIT instruction was executed | | | Operation after | By interrupt request occurrence | | Supply of $\phi$ CPU and $\phi$ starts just after the termination. | | | terminating<br>Wait mode | By hardware reset | | Operates in the same way as hardware reset. | | Note: The refresh timer operates, but DRAM refresh is not performed because the bus request (DRAMC) does not occur. (Refer to section "Appendix 9. 7721 Group Q & A.") #### 5.4 Wait mode #### (1) Termination by interrupt request occurrence - ① When an interrupt request occurs, supply of $\phi_{CPU}$ and $\phi$ starts. - 2 The interrupt request which occurred in 1 is accepted. The following interrupts are used to terminate Wait mode. When a watchdog timer interrupt request occurs, Wait mode is also terminated. ``` •INT: interrupt (i = 0 to 2) •Timer Ai interrupt (i = 0 to 4) •Timer Bi interrupt (i = 0 to 2) •UARTi transmit interrupt (i = 0, 1) •UARTi receive interrupt (i = 0, 1) •A-D converter interrupt ``` Note: Refer to "CHAPTER 7. INTERRUPTS" and each functional description about interrupts. Before executing the **WIT** instruction, interrupts used to terminate Wait mode must be enabled. In addition, the interrupt priority level of the interrupt used to terminate Wait mode must be higher than the processor interrupt priority level (IPL) of the routine where the **WIT** instruction is executed. When multiple interrupts listed above are enabled, Wait mode is terminated by the interrupt request which occurs first. #### (2) Termination by hardware reset The CPU and the SFR area are initialized in the same way as system reset. However, the internal RAM area retains the same contents as that before executing the **WIT** instruction. The terminating sequence is the same as the internal processing sequence which is performed after reset. Refer to "CHAPTER 4. RESET" for details about reset. 5.4 Wait mode #### [Precautions for Wait mode] When executing the **WIT** instruction after writing to an internal area or an external area, three **NOP** instructions must be inserted to complete the write operation before the **WIT** instruction is executed. (Refer to "Figure 5.4.1.") **STA A,** XXXX; Write instruction NOP ; NOP instruction inserted NOP ; NOP ; WIT ; WIT instruction Fig. 5.4.1 NOP instruction insertion example 5.4 Wait mode **MEMORANDUM** # CHAPTER 6 INPUT/OUTPUT PINS - 6.1 Overview - 6.2 Programmable I/O ports - 6.3 Examples of handling unused pins #### 6.1 Overview, 6.2 Programmable I/O ports #### 6.1 Overview Input/output pins (hereafter called I/O pins) have functions as programmable I/O ports, internal peripheral devices's I/O pins, external buses, etc. For the basic functions of each I/O pin, refer to section "1.3 Pin description." For the I/O functions of the internal peripheral devices, refer to relevant sections of each internal peripheral device. For the external address bus, external data bus, bus control signals, etc., refer to "CHAPTER 3. CONNECTION WITH EXTERNAL DEVICES." This chapter describes the programmable I/O ports and examples of handling unused pins. #### 6.2 Programmable I/O ports The programmable I/O ports have direction registers and port registers in the SFR area. Figure 6.2.1 shows the memory map of direction registers and port registers. | Addresses | 1 | I | |-----------------|-----------------------------|---| | A16 | Port P4 register | - | | B <sub>16</sub> | Port P5 register | - | | C <sub>16</sub> | Port P4 direction register | 1 | | D16 | Port P5 direction register | 1 | | E16 | Port P6 register | | | F16 | Port P7 register | | | 1016 | Port P6 direction register | | | 1116 | Port P7 direction register | | | 1216 | Port P8 register | | | 1316 | Port P9 register | | | 1416 | Port P8 direction register | | | <b>15</b> 16 | Port P9 direction register | | | <b>16</b> 16 | Port P10 register | | | 1716 | | | | 1816 | Port P10 direction register | | | | | | | | | ] | | | | | Fig. 6.2.1 Memory map of direction registers and port registers #### 6.2 Programmable I/O ports #### 6.2.1 Direction register This register determines the I/O direction of programmable I/O ports. Each bit of this register corresponds one for one to each pin of the microcomputer. Figure 6.2.2 shows the structure of port Pi (i = 4 to 10) direction register. Fig. 6.2.2 Structure of port Pi (i = 4 to 10) direction register #### 6.2 Programmable I/O ports #### 6.2.2 Port register Data is input from or output to the external by writing/reading data to/from a port register. A port register consists of a port latch which holds the output data and a circuit which reads the pin state. Each bit of the port register corresponds one for one to each pin of the microcomputer. Figure 6.2.3 shows the structure of the port Pi (i = 4 to 10) register. #### • When outputting data from programmable I/O port set to output mode - ① By writing data to the corresponding bit of the port register, the data is written into the port latch. - ② The data is output from the pin according to the contents of the port latch. By reading the port register of a port set to the output mode, the contents of the port latch is read out, instead of the pin state. Accordingly, the output data is correctly read without being affected by an external load, etc. (Refer to "Figures 6.2.4 and 6.2.5.") #### ● When inputting data from programmable I/O port set to input mode - ① A pin which is set to the input mode enters the floating state. - ② By reading the corresponding bit of the port register, the data which is input from the pin can be read out. By writing data to the port register of a programmable I/O port set to the input mode, the data is written only into the port latch and is not output to the external (Note). The pin remains floating. Note: When executing a read-modify-write instruction (CLB, SEB, INC, DEC, ASL, ASR, LSR, ROL, ROR) to the port register of a programmable I/O port set to the input mode, the instruction is executed to the data which is input from the pin and the result is written into the port register. Fig. 6.2.3 Structure of port Pi (i = 4 to 10) register Figures 6.2.4 and 6.2.5 show the port peripheral circuits. Fig. 6.2.4 Port peripheral circuits (1) # 6.2 Programmable I/O ports Fig. 6.2.5 Port peripheral circuits (2) #### 6.3 Examples of handling unused pins #### 6.3 Examples of handling unused pins When unusing an I/O pin, some handling is necessary for the pin. Examples of handling unused pins are described below. The following are just examples. The user shall modify them according to the user's actual application and test them. Table 6.3.1 Examples of handling unused pins | Pin name | Handling example | | |------------------------------------------------|--------------------------------------------------------------|--| | P4 <sub>3</sub> to P4 <sub>7</sub> , P5 to P10 | Set these pins to the input mode and connect each | | | | pin to Vcc or Vss via a resistor; or set these pins to | | | | the output mode and leave them open (Notes 1 and 2). | | | BLE, BHE, ALE, $\phi_1$ , ST0, ST1 | Leave them open. | | | Xout (Note 3) | | | | HOLD, RDY | Connect these pins to Vcc via a resistor (pull-up) (Note 2). | | | CNVss | Connect this pin to Vcc or Vss. | | | AVcc | Connect this pin to Vcc. | | | AVSS, VREF | Connect these pins to Vss. | | - **Notes 1:** When leaving these pins open after they are set to the output mode, note the following: these pins function as input ports from reset until they are switched to the output mode by software. Therefore, voltage levels of these pins are undefined and the power source current may increase while these pins function as input ports. After reset, immediately set these ports to the output mode. Software reliability can be enhanced by setting the contents of the above ports' direction registers periodically. This is because these contents may be changed by noise, a program runaway which occurs owing to noise, etc. - 2: For unused pins, use the shortest possible wiring (within 20 mm from the microcomputer's pins). - 3: This applies when a clock externally generated is input to the X<sub>IN</sub> pin. Fig. 6.3.1 Examples of handling unused pins 6.3 Examples of handling unused pins **MEMORANDUM** # CHAPTER 7 INTERRUPTS - 7.1 Overview - 7.2 Interrupt sources - 7.3 Interrupt control - 7.4 Interrupt priority level - 7.5 Interrupt priority level detection circuit - 7.6 Interrupt priority level detection time - 7.7 Sequence from acceptance of interrupt request until execution of interrupt routine - 7.8 Return from interrupt routine - 7.9 Multiple interrupts - 7.10 External interrupts (INT: interrupt) - 7.11 Precautions for interrupts # **INTERRUPTS** #### 7.1 Overview #### 7.1 Overview The M37721 provides 23 interrupt sources to generate interrupt requests. Figure 7.1.1 shows the interrupt processing sequence. When an interrupt request is accepted, a branch is made to the start address of the interrupt routine set in the interrupt vector table (addresses FFCE<sub>16</sub> to FFFF<sub>16</sub>). Set the start address of each interrupt routine to the corresponding interrupt vector address in the interrupt vector table. Fig. 7.1.1 Interrupt processing sequence When an interrupt request is accepted, the following registers' contents just before acceptance of an interrupt request are automatically pushed onto the stack area $0\rightarrow 2\rightarrow 3$ in that order. - ① Program bank register (PG) - 2 Program counter (PCL, PCH) - 3 Processor status register (PSL, PSH) Figure 7.1.2 shows the state of the stack area just before entering the interrupt routine. Execute the RTI instruction at the end of this interrupt routine to return to the routine that the microcomputer was executing before the interrupt request was accepted. By executing the RTI instruction, the register contents pushed onto the stack area are pulled $3\rightarrow 2\rightarrow 1$ in that order. Then, the suspended processing is resumed from where it left off. Fig. 7.1.2 State of stack area just before entering interrupt routine ### **INTERRUPTS** #### 7.2 Interrupt sources #### 7.2 Interrupt sources Table 7.2.1 lists the interrupt sources and the interrupt vector addresses. When programming, set the start address of each interrupt routine at the vector addresses listed in this table. Table 7.2.1 Interrupt sources and interrupt vector addresses | Interrupt source | Interrupt vect | or addresses | Remarks | Reference | |------------------------|--------------------|--------------------|---------------------------------|--------------------------| | | High-order | Low-order | | | | | address | address | | | | Reset | FFFF <sub>16</sub> | FFFE <sub>16</sub> | Non-maskable | 4. RESET | | Zero division | FFFD <sub>16</sub> | FFFC <sub>16</sub> | Non-maskable software interrupt | 7700 Family Software | | <b>BRK</b> instruction | FFFB <sub>16</sub> | FFFA <sub>16</sub> | Non-maskable software interrupt | Manual | | DBC (Note) | FFF9 <sub>16</sub> | FFF8 <sub>16</sub> | Do not use. | | | Watchdog timer | FFF7 <sub>16</sub> | FFF6 <sub>16</sub> | Non-maskable interrupt | 15. WATCHDOG TIMER | | ĪNT <sub>0</sub> | FFF5 <sub>16</sub> | FFF4 <sub>16</sub> | Maskable external interrupts | 7.10 External interrupts | | ĪNT <sub>1</sub> | FFF3 <sub>16</sub> | FFF2 <sub>16</sub> | | (INTi interrupt) | | ĪNT <sub>2</sub> | FFF1 <sub>16</sub> | FFF0 <sub>16</sub> | | | | Timer A0 | FFEF <sub>16</sub> | FFEE <sub>16</sub> | Maskable internal interrupts | 8. TIMER A | | Timer A1 | FFED <sub>16</sub> | FFEC <sub>16</sub> | | | | Timer A2 | FFEB <sub>16</sub> | FFEA <sub>16</sub> | | | | Timer A3 | FFE9 <sub>16</sub> | FFE8 <sub>16</sub> | | | | Timer A4 | FFE7 <sub>16</sub> | FFE6 <sub>16</sub> | | | | Timer B0 | FFE5 <sub>16</sub> | FFE4 <sub>16</sub> | Maskable internal interrupts | 9. TIMER B | | Timer B1 | FFE3 <sub>16</sub> | FFE2 <sub>16</sub> | | | | Timer B2 | FFE1 <sub>16</sub> | FFE0 <sub>16</sub> | | | | UART0 receive | FFDF <sub>16</sub> | FFDE <sub>16</sub> | Maskable internal interrupts | 11. SERIAL I/O | | UART0 transmit | FFDD <sub>16</sub> | FFDC <sub>16</sub> | | | | UART1 receive | FFDB <sub>16</sub> | FFDA <sub>16</sub> | | | | UART1 transmit | FFD9 <sub>16</sub> | FFD8 <sub>16</sub> | | | | A-D conversion | FFD7 <sub>16</sub> | FFD6 <sub>16</sub> | Maskable internal interrupt | 12. A-D CONVERTER | | DMA0 | FFD5 <sub>16</sub> | FFD4 <sub>16</sub> | Maskable internal interrupts | 13. DMA CONTROLLER | | DMA1 | FFD3 <sub>16</sub> | FFD2 <sub>16</sub> | | | | DMA2 | FFD1 <sub>16</sub> | FFD0 <sub>16</sub> | | | | DMA3 | FFCF <sub>16</sub> | FFCE <sub>16</sub> | | | **Note:** The DBC interrupt is used exclusively for debugger control. - Maskable interrupt: An interrupt of which request's acceptance can be disabled by software. - ●Non-maskable interrupt (including Zero division, BRK instruction, Watchdog timer interrupts): An interrupt which is certain to be accepted when its request occurs. These interrupts do not have their interrupt control registers and are not affected by the interrupt disable flag (I). #### 7.3 Interrupt control •Interrupt disable flag (I) The maskable interrupts are controlled by the following: •Interrupt request bit •Interrupt priority level select bits •Processor interrupt priority level (IPL) Assigned to the interrupt control register of each interrupt. Assigned to the processor status register (PS). Figure 7.3.1 shows the memory assignment of the interrupt control registers, and Figure 7.3.2 shows their structures. | Address | 1 | |-------------------------|-------------------------------------------| | 6C <sub>16</sub> | DMA0 interrupt control register | | 6D <sub>16</sub> | DMA1 interrupt control register | | 6E <sub>16</sub> | DMA2 interrupt control register | | 6F <sub>16</sub> | DMA3 interrupt control register | | 7016 | A-D conversion interrupt control register | | <b>71</b> 16 | UART0 transmit interrupt control register | | 7216 | UART0 receive interrupt control register | | 7316 | UART1 transmit interrupt control register | | <b>74</b> 16 | UART1 receive interrupt control register | | <b>75</b> 16 | Timer A0 interrupt control register | | <b>76</b> 16 | Timer A1 interrupt control register | | <b>77</b> 16 | Timer A2 interrupt control register | | <b>78</b> 16 | Timer A3 interrupt control register | | 7916 | Timer A4 interrupt control register | | <b>7A</b> 16 | Timer B0 interrupt control register | | <b>7B</b> 16 | Timer B1 interrupt control register | | <b>7C</b> 16 | Timer B2 interrupt control register | | 7D <sub>16</sub> | INT₀ interrupt control register | | <b>7E</b> 16 | INT₁ interrupt control register | | <b>7F</b> <sub>16</sub> | INT2 interrupt control register | | | | Fig. 7.3.1 Memory assignment of interrupt control registers ### **INTERRUPTS** #### 7.3 Interrupt control Fig. 7.3.2 Structures of interrupt control register #### 7.3.1 Interrupt disable flag (I) All maskable interrupts can be disabled by this flag. When this flag is set to "1," all maskable interrupts are disabled; when this flag is cleared to "0," those interrupts are enabled. Because this flag is set to "1" at reset, clear this flag to "0" when enabling interrupts. #### 7.3.2 Interrupt request bit When an interrupt request occurs, this bit is set to "1." This bit remains set to "1" until the interrupt request is accepted; it is cleared to "0" when the interrupt request is accepted. This bit can also be set to "0" or "1" by software. The INT; interrupt request bit (i = 0 to 2) is ignored when the INT; interrupt is used with level sense. #### 7.3.3 Interrupt priority level select bits and processor interrupt priority level (IPL) The interrupt priority level select bits are used to determine the priority level of each interrupt. When an interrupt request occurs, its interrupt priority level is compared with the processor interrupt priority level (IPL). The requested interrupt is enabled only when the comparison result meets the following condition. Accordingly, an interrupt can be disabled by setting its interrupt priority level to 0. Each interrupt priority level > Processor interrupt priority level (IPL) Table 7.3.1 lists the setting of interrupt priority level, and Table 7.3.2 lists the interrupt enabled level corresponding to IPL contents. The interrupt disable flag (I), interrupt request bit, interrupt priority level select bits, and processor interrupt priority level (IPL) are independent of one another; they do not affect one another. Interrupt requests are accepted only when the following conditions are satisfied. - •Interrupt disable flag (I) = "0" - •Interrupt request bit = "1" - •Interrupt priority level > Processor interrupt priority level (IPL) # **INTERRUPTS** # 7.3 Interrupt control Table 7.3.1 Setting of interrupt priority level | Interrupt priority level select bits | | select bits | Interrupt priority level | Priority | |--------------------------------------|----|-------------|------------------------------|----------| | b2 | b1 | b0 | | | | 0 | 0 | 0 | Level 0 (Interrupt disabled) | _ | | 0 | 0 | 1 | Level 1 | Low | | 0 | 1 | 0 | Level 2 | | | 0 | 1 | 1 | Level 3 | | | 1 | 0 | 0 | Level 4 | | | 1 | 0 | 1 | Level 5 | | | 1 | 1 | 0 | Level 6 | Ψ | | 1 | 1 | 1 | Level 7 | High | Table 7.3.2 Interrupt enabled level corresponding to IPL contents | IPL <sub>1</sub> | IPL₀ | Enabled interrupt priority level | |------------------|-----------------------|----------------------------------------| | 0 | 0 | Enable level 1 and above interrupts. | | 0 | 1 | Enable level 2 and above interrupts. | | 1 | 0 | Enable level 3 and above interrupts. | | 1 | 1 | Enable level 4 and above interrupts. | | 0 | 0 | Enable level 5 and above interrupts. | | 0 | 1 | Enable level 6 and level 7 interrupts. | | 1 | 0 | Enable only level 7 interrupt. | | 1 | 1 | Disable all maskable interrupts. | | | 0<br>0<br>1<br>1<br>0 | 0 0 0 1 1 1 0 1 0 0 0 0 0 1 | IPLo: Bit 8 in processor status register (PS) IPL1: Bit 9 in processor status register (PS) #### 7.4 Interrupt priority level When the interrupt disable flag (I) = "0" (interrupts enabled) and more than one interrupt request is detected at the same sampling timing, which means a timing to check whether an interrupt request exists or not, they are accepted in order of priority levels. In other words, the interrupt request with the highest priority level is accepted first. Among a total of 23 interrupt sources, the user can set the desired priority levels for 20 interrupt sources except software interrupts (zero division and **BRK** instruction interrupts) and the watchdog timer interrupt. Use the interrupt priority level select bits to set their priority levels. Priority levels of reset, which is handled as the interrupt request with the highest priority, and the watchdog timer interrupt are set by hardware. Figure 7.4.1 shows the interrupt priority set by hardware. Note that software interrupts are not affected by the interrupt priority levels. Whenever the instruction is executed, a program certainly branches to the interrupt routine. Fig. 7.4.1 Interrupt priority level set by hardware # **INTERRUPTS** #### 7.5 Interrupt priority level detection circuit #### 7.5 Interrupt priority level detection circuit The interrupt priority level detection circuit selects the interrupt with the highest priority level when more than one interrupt request occurs at the same sampling timing. Figure 7.5.1 shows the interrupt priority level detection circuit. Fig. 7.5.1 Interrupt priority level detection circuit The following explains the operation of the interrupt priority detection circuit using Figure 7.5.2. The interrupt priority level of a requested interrupt (Y in Figure 7.5.2) is compared with the resultant priority level which is sent from the preceding comparator (X in Figure 7.5.2); the interrupt with the higher priority level is sent to the next comparator (Z in Figure 7.5.2). (Initial comparison value of "X" is "0.") For an interrupt which is not requested, the comparison is not performed and the priority level which is sent from the preceding comparator is forwarded to the next comparator as it is. When the two priority levels are found the same by comparison, the priority level which is sent from the preceding comparator is forwarded to the next comparator. Accordingly, when the same priority level is set by software, the interrupt priority levels are handled as follows: DMA3 > DMA2 > DMA1 > DMA0 > A-D conversion > UART1 transmit > UART1 receive > UART0 transmit > UART0 receive > Timer B2 > Timer B1 > Timer B0 > Timer A4 > Timer A3 > Timer A2 > Timer A1 > Timer A0 > $\overline{INT_2}$ > $\overline{INT_1}$ > $\overline{INT_0}$ Among the multiple interrupt requests sampled at the same time, one request with the highest priority level is detected by the above comparison. Then, this highest interrupt priority level is compared with the processor interrupt priority level (IPL). When this interrupt priority level is higher than the processor interrupt priority level (IPL) and the interrupt disable flag (I) is "0," the interrupt request is accepted. A interrupt request which is not accepted here is held until it is accepted or its interrupt request bit is cleared to "0" by software. The interrupt priority is detected when the CPU fetches an op code, which is called the CPU's op-code fetch cycle. However, when an op-code fetch cycle starts during detection of an interrupt priority, a new interrupt priority detection does not start. (Refer to "Figure 7.6.1.") Since the state of the interrupt request bit and interrupt priority levels are latched during the interrupt priority detection, even if they change, the interrupt priority detection is performed for the previous state before the change occurred. The interrupt priority level is detected when the CPU fetches an op code. Therefore, in the following execution or states, after the execution or state is terminated, no interrupt request is accepted until the CPU fetches the op code of the next instruction. - •Execution of an instruction which requires many cycles, such as the MVN or MVP instruction - During DRAM refreshment - During Hold state - During DMA transfer Fig. 7.5.2 Interrupt priority level detection model # 7.6 Interrupt priority level detection time When the interrupt priority level detection time has passed after sampling starts, an interrupt request is accepted. The interrupt priority level detection time can be selected by software. Figure 7.6.1 shows the interrupt priority level detection time. Usually, select "2 cycles of $\phi$ " as the interrupt priority level detection time. Fig. 7.6.1 Interrupt priority level detection time #### 7.7 Sequence from acceptance of interrupt request until execution of interrupt routine # 7.7 Sequence from acceptance of interrupt request until execution of interrupt routine The sequence from the acceptance of interrupt request until the execution of the interrupt routine is described below. When an interrupt request is accepted, the interrupt request bit of the accepted interrupt is cleared to "0." And then, the interrupt processing starts from the cycle just after the completion of the instruction which was executed at accepting the interrupt request. Figure 7.7.1 shows the sequence from acceptance of interrupt request to execution of interrupt routine. After execution of an instruction at accepting the interrupt request is completed, an INTACK (Interrupt Acknowledge) sequence is executed, and a branch is made to the start address of the interrupt routine allocated in addresses $0_{16}$ to FFFF<sub>16</sub>. The INTACK sequence is automatically performed in the following order. - ① The contents of the program bank register (PG) just before performing the INTACK sequence are pushed onto stack. - ② The contents of the program counter (PC) just before performing the INTACK sequence are pushed onto stack. - The contents of the processor status register (PS) just before performing the INTACK sequence is pushed onto stack. - 4 The interrupt disable flag (I) is set to "1." - ⑤ The interrupt priority level of the accepted interrupt is set into the processor interrupt priority level (IPL). - © The contents of the program bank register (PG) are cleared to "00<sub>16</sub>," and the contents of the interrupt vector address are set into the program counter (PC). Performing the INTACK sequence requires at least 13 cycles of internal clock $\phi$ . Figure 7.7.2 shows the INTACK sequence timing. After the INTACK sequence is completed, the instruction execution starts from the start address of the interrupt routine. Fig. 7.7.1 Sequence from acceptance of interrupt request until execution of interrupt routine ### 7.7 Sequence from acceptance of interrupt request until execution of interrupt routine Fig. 7.7.2 INTACK sequence timing (at minimum) #### 7.7.1 Change in IPL at acceptance of interrupt request When an interrupt request is accepted, the processor interrupt priority level (IPL) is replaced with the interrupt priority level of the accepted interrupt. This results in easy control of the processing for multiple interrupts. (Refer to section "7.9 Multiple interrupts.") At reset or when a watchdog timer interrupt or a software interrupt is accepted, a value listed in Table 7.7.1 is set into the IPL. Table 7.7.1 Change in IPL at acceptance of interrupt request | Interrupts | Change in IPL | |------------------|-------------------------------------------| | Reset | Level 0 ("000 <sub>2</sub> ") is set. | | Watchdog timer | Level 7 ("111 <sub>2</sub> ") is set. | | Zero division | Not changed. | | BRK instruction | Not changed. | | Other interrupts | Accepted interrupt priority level is set. | #### 7.7 Sequence from acceptance of interrupt request until execution of interrupt routine #### 7.7.2 Push operation for registers The push operation for registers performed in the INTACK sequence depends on whether the contents of the stack pointer (S) at acceptance of an interrupt request are even or odd. When the contents of the stack pointer (S) are even, the contents of the program counter (PC) and the processor status register (PS) are simultaneously pushed in a unit of 16 bits. When the contents of the stack pointer (S) are odd, each of these registers is pushed in a unit of 8 bits. Figure 7.7.3 shows the push operation for registers. In the INTACK sequence, only the contents of the program bank register (PG), program counter (PC), and processor status register (PS) are pushed onto the stack area. The other necessary registers must be pushed by software at the start of the interrupt routine. By using the PSH instruction, all CPU registers except the stack pointer (S) can be pushed. Fig. 7.7.3 Push operation for registers #### 7.8 Return from interrupt routine, 7.9 Multiple interrupts # 7.8 Return from interrupt routine When the RTI instruction is executed at the end of the interrupt routine, the contents of the program bank register (PG), program counter (PC), and processor status register (PS) which were pushed onto the stack area just before the INTACK sequence, are automatically pulled. After this, the control returns to the original routine. And then, the suspended processing, which was in progress before the acceptance of the interrupt request, is resumed. Before the RTI instruction is executed, pull registers which were pushed by software in the interrupt routine, using the PUL instruction, etc. # 7.9 Multiple interrupts Just after a branch is made to an interrupt routine, the following occur: - •Interrupt disable flag (I) = "1" (Interrupts are disabled) - •Interrupt request bit of accepted interrupt = "0" - •Processor interrupt priority level (IPL) = Interrupt priority level of accepted interrupt Accordingly, as long as the IPL remains unchanged, an interrupt request whose priority level is higher than that of the interrupt which is in progress can be accepted by clearing the interrupt disable flag (I) to "0" in an interrupt routine. In this way, multiple interrupts are processed. Figure 7.9.1 shows the processing for multiple interrupts. An interrupt request which has not been accepted because its priority level is lower is held. When the RTI instruction is executed, the interrupt priority level of the routine which was in progress at acceptance of an interrupt request is pulled into the IPL. Therefore, if the following relationship is satisfied when interrupt priority level detection is performed next, the held interrupt request is accepted. Held interrupt request's priority level > Processor interrupt priority level (IPL) Fig. 7.9.1 Processing for multiple interrupts # 7.10 External interrupts (INT: interrupt) # 7.10 External interrupts (INT: interrupt) An external interrupt request occurs by an input signal to the $\overline{\text{INT}_i}$ (i = 0 to 2) pin. The occurrence factor of the interrupt request can be selected by the level sense/edge sense select bit and the polarity select bit (bits 5 and 4 at addresses $7D_{16}$ to $7F_{16}$ ) shown in Figure 7.10.1. Table 7.10.1 lists the occurrence factor of $\overline{\text{INT}_i}$ interrupt request. When using P10<sub>0</sub>/INT<sub>0</sub> to P10<sub>2</sub>/INT<sub>2</sub> pins as input pins of external interrupts, set the corresponding bits at address 18<sub>16</sub> (port P10 direction register) to "0." (Refer to "Figure 7.10.2.") The signals input to the INT<sub>i</sub> pin require "H"- or "L"- level width of 250 ns or more, independent of $f(X_{IN})$ . Additionally, even when using the pins $P10_0/INT_0$ to $P10_2/INT_2$ as the input pins of external interrupts, the user can obtain the pin's state by reading bits 0 to 2 at address $16_{16}$ (port P10 register). **Note:** When selecting an input signal's falling or "L" level as the occurrence factor of an interrupt request, make sure that the input signal is held "L" for 250 ns or more. When selecting an input signal's rising or "H" level as that, make sure that the input signal is held "H" for 250 ns or more. Table 7.10.1 Occurrence factor of INT: interrupt request | b5 | b4 | INT: interrupt request occurrence factor | |----|----|------------------------------------------------------------------------------------------| | 0 | 0 | Interrupt request occurs at the falling edge of a signal input to pin INT; (Edge sense). | | 0 | 1 | Interrupt request occurs at the rising edge of a signal input to pin INT: (Edge sense). | | 1 | 0 | Interrupt request occurs when pin INT; is at "H" level (Level sense). | | 1 | 1 | Interrupt request occurs when pin INT; is at "L" level (Level sense). | The INT<sub>i</sub> interrupt request occurs by detecting the state of pin INT<sub>i</sub> all the time. Therefore, when the user does not use the $\overline{INT_i}$ interrupt, set the $\overline{INT_i}$ interrupt's priority level to level 0. Fig. 7.10.1 Structure of INT: (i=0 to 2) interrupt control register Fig. 7.10.2 Relationship between port P10 direction register and input pins of external interrupt ## 7.10 External interrupts (INT: interrupt) #### 7.10.1 Functions of INT; interrupt request bit #### (1) Functions when edge sense is selected The interrupt request bit has the same functions as that of an internal interrupt. That is, when an interrupt request occurs, the interrupt request bit is set to "1" and retains this state until the interrupt request is accepted. When this bit is cleared to "0" by software, the interrupt request is cancelled; when this bit is set to "1" by software, the interrupt request can be generated. #### (2) Functions when level sense is selected The INT interrupt request bit is ignored. Interrupt requests continuously occur while the level of the INT<sub>i</sub> pin is the valid level\*1; when the INT<sub>i</sub> pin's level changes from the valid level to the invalid level\*2 before the INT<sub>i</sub> interrupt request is accepted, this interrupt request is not retained. (Refer to "Figure 7.10.4.") **Valid level\***<sup>1</sup>: This means the level selected by the polarity select bit (bit 4 at addresses 7D<sub>16</sub> to 7F<sub>16</sub>) **Invalid level\***<sup>2</sup>: This means the reversed level of "valid level" Fig. 7.10.3 INT: Interrupt request Fig. 7.10.4 Occurrence of INT; interrupt request when level sense is selected #### 7.10.2 Switching of INT; interrupt request occurrence factor When the INT<sub>i</sub> interrupt request occurrence factor is switched in one of the following ways, the interrupt request bit may be set to "1": - •Switching the level sense to the edge sense - Switching polarity Therefore, after this switching, make sure to clear the interrupt request bit to "0." Figure 7.10.5 shows an example of the switching procedure for the INT<sub>i</sub> interrupt request occurrence factor. Fig. 7.10.5 Example of switching procedure for INT; interrupt request occurrence factor # 7.11 Precautions for interrupts # 7.11 Precautions for interrupts When changing the interrupt priority level select bits (bits 0 to 2 at addresses $6C_{16}$ to $7F_{16}$ ), 2 to 7 cycles of $\phi$ are required until the interrupt priority level is changed. Therefore, when the interrupt priority level of a certain interrupt source is repeatedly changed in a very short time, which consists of a few instructions, it is necessary to reserve the time required for the change by software. Figure 7.11.1 shows a program example to reserve the time required for the change. Note that the time required for the change depends on the contents of the interrupt priority detection time select bits (bits 4 and 5 at address $5E_{16}$ ). Table 7.11.1 lists the correspondence between the number of instructions inserted in Figure 7.11.1 and the interrupt priority detection time select bits. LDM.B #0XH, 00XXH; Write instruction for the interrupt priority level select bits NOP ; Inserted NOP instruction (Note) NOP ; NOP ; LDM.B #0XH, 00XXH; Write instruction for the interrupt priority level select bits Note: Except the write instruction for address XX16, any instruction which has the same cycles as the **NOP** instruction can also be inserted. For the number of inserted NOP instructions, refer to "Table 7.11.1." XX: any of 6C to 7F Fig. 7.11.1 Program example to reserve time required for change of interrupt priority level Table 7.11.1 Correspondence between number of instructions to be inserted in Figure 7.11.1 and interrupt priority detection time select bits | Interrupt priority detection | n time select bits (Note) | Interrupt priority level | Number of inserted | |------------------------------|---------------------------|--------------------------|--------------------| | b5 | b4 | detection time | NOP instructions | | 0 | 0 | 7 cycles of $\phi$ | 4 or more | | 0 | 1 | 4 cycles of $\phi$ | 2 or more | | 1 | 0 | 2 cycles of $\phi$ | 1 or more | | 1 | 1 | Do not select. | | Note: We recommend [b5 = "1", b4 = "0"]. # CHAPTER 8 # TIMER A - 8.1 Overview - 8.2 Block description - 8.3 Timer mode [Precautions for timer mode] 8.4 Event counter mode [Precautions for event counter mode] 8.5 One-shot pulse mode [Precautions for one-shot pulse mode] 8.6 Pulse width modulation (PWM) mode [Precautions for pulse width modulation (PWM) mode] #### 8.1 Overview #### 8.1 Overview Timer A consists of five counters, Timers A0 to A4, each equipped with a 16-bit reload function. Timers A0 to A4 operate independently of one another. Timer A has four operating modes listed below. Timers A0 and A1 operate in the timer mode only. Timers A2 to A4 have selective four operating modes listed below. #### (1) Timer mode (Timers A0 to A4) The timer counts an internally generated count source. For Timers A2 to A4, the following functions can be used in this mode: - •Gate function - •Pulse output function #### (2) Event counter mode (Timers A2 to A4) The timer counts an external signal. The following functions can be used in this mode: - •Pulse output function - •Two-phase pulse signal processing function #### (3) One-shot pulse mode (Timers A2 to A4) The timer outputs a pulse which has an arbitrary width once. #### (4) Pulse width modulation (PWM) mode (Timers A2 to A4) Timer outputs pulses which have an arbitrary width in succession. The counter functions as one of the following pulse width modulators: - •16-bit pulse width modulator - •8-bit pulse width modulator In this chapter, Timer Ai (i = 0 to 4) indicates Timers A0 to A4. Timer Aj (j = 2 to 4) indicates Timers A2 to A4; this is applies when the timer A's input/output pins are used etc. (Hereafter, input/output pins are called I/O pins.) # 8.2 Block description Figure 8.2.1 shows the block diagram of Timer A. Explanation of registers relevant to Timer A is described below. Fig. 8.2.1 Block diagram of Timer A ## 8.2 Block description #### 8.2.1 Counter and reload register (timer Ai register) Each of timer Ai counter and reload register consists of 16 bits. Countdown in the counter is performed each time the count source is input. In the event counter mode, it can also function as an up-counter. The reload register is used to store the initial value of the counter. When a counter underflow or overflow occurs, the reload register's contents are reloaded into the counter. A value is set to the counter and reload register by writing the value to the timer Ai register. Table 8.2.1 lists the memory assignment of the timer Ai register. The value written into the timer Ai register while counting is not in progress is set to the counter and reload register. The value written into the timer Ai register while counting is in progress is set only to the reload register. In this case, the reload register's updated contents are transferred to the counter at the next reload time. The value obtained when reading out the timer Ai register varies according to the operating mode. Table 8.2.2 lists reading from and writing to the timer Ai register. Table 8.2.1 Memory assignment of timer Ai register | Timer Ai register | High-order byte | Low-order byte | |-------------------|--------------------------|--------------------------| | Timer A0 register | Address 47 <sub>16</sub> | Address 46 <sub>16</sub> | | Timer A1 register | Address 49 <sub>16</sub> | Address 48 <sub>16</sub> | | Timer A2 register | Address 4B <sub>16</sub> | Address 4A <sub>16</sub> | | Timer A3 register | Address 4D <sub>16</sub> | Address 4C <sub>16</sub> | | Timer A4 register | Address 4F <sub>16</sub> | Address 4E <sub>16</sub> | **Note:** At reset, the contents of the timer Ai register are undefined. Table 8.2.2 Reading from and writing to timer Ai register | Operating mode | Read | Write | |-----------------------------------|------------------------------|--------------------------------------------------------| | Timer mode | Counter value is read out. | <while counting=""></while> | | Event counter mode | (Note 1) | Written only to reload register. < While not counting> | | One-shot pulse mode | Undefined value is read out. | Written to both of the counter | | Pulse width modulation (PWM) mode | | and reload register. | Notes 1: Also refer to "[Precautions for timer mode]" and "[Precautions for event counter mode]." <sup>2:</sup> When reading from and writing to the timer Ai register, perform it in a unit of 16 bits. #### 8.2.2 Count start register This register is used to start and stop counting. Each bit of this register corresponds to each timer. Figure 8.2.2 shows the structure of the count start register. Fig. 8.2.2 Structure of count start register ## 8.2 Block description #### 8.2.3 Timer Ai mode register Figure 8.2.3 shows the structure of the timer Ai mode register. The operating mode select bits are used to select the operating mode of Timer Ai. Bits 2 to 7 have different functions according to the operating mode. These bits are described in the paragraph of each operating mode. Fig. 8.2.3 Structure of timer Ai mode register #### 8.2.4 Timer Ai interrupt control register Figure 8.2.4 shows the structure of the timer Ai interrupt control register. For details about interrupts, refer to "CHAPTER 7. INTERRUPTS." Fig. 8.2.4 Structure of timer Ai interrupt control register #### (1) Interrupt priority level select bits (bits 2 to 0) These bits select a timer Ai interrupt's priority level. When using timer Ai interrupts, select one of the priority levels (1 to 7). When a timer Ai interrupt request occurs, its priority level is compared with the processor interrupt priority level (IPL). The requested interrupt is enabled only when its priority level is higher than the IPL. (However, this applies when the interrupt disable flag (I) = "0.") To disable timer Ai interrupts, set these bits to "0002" (level 0). #### (2) Interrupt request bit (bit 3) This bit is set to "1" when a timer Ai interrupt request occurs. This bit is automatically cleared to "0" when the timer Ai interrupt request is accepted. This bit can be set to "1" or cleared to "0" by software. ## 8.2 Block description #### 8.2.5 Port P5 direction register The I/O pins of Timers A2 to A4 are multiplexed with port P5. When using these pins as Timer Aj's input pins, set the corresponding bits of the port P5 direction register to "0" to set these port pins for the input mode. When used as Timer Aj's output pins, these pins are forcibly set to the output pins of Timer Aj regardless of the direction registers's contents. Figure 8.2.5 shows the relationship between the port P5 direction register and the Timer Aj's I/O pins. | b7 b6 | b5 | b4 | b3 | b2 | b1 | bo | _ | ort | P5 di | rection register (Address Da | 6) | | | |-------|----------|----|----|------------|----|----|---|-----|-------|------------------------------|-----------------------------------------------------------------------|----------|----| | | | | - | | - | : | | | Bit | Bit name | Functions | At reset | RW | | | | | | | | | | | 0 | TA2оит pin | 0 : Input mode | 0 | RW | | | | | | | Ł. | | | - | 1 | TA2 <sub>IN</sub> pin | 1 : Output mode | 0 | RW | | | į | | - | <u>:</u> - | | | | - | 2 | TA3out pin | When using these pins as Timer Aj s input pins, set the corresponding | 0 | RW | | | - | | Ĺ. | | | | | - | 3 | TA3 <sub>IN</sub> pin | bits to "0." | 0 | RW | | | - | į. | | | | | | - | 4 | TA4out pin | | 0 | RW | | | <u>.</u> | | | | | | | | 5 | TA4 <sub>IN</sub> pin | | 0 | RW | | L | | | | | | | | - | 6 | TB0 <sub>IN</sub> pin | | 0 | RW | | L | | | | | | | | | 7 | TB1 <sub>IN</sub> pin | | 0 | RW | | | | | | | | | | | : Bit | s 6 and 7 are not used for T | imer A. | | _ | Fig. 8.2.5 Relationship between port P5 direction register and Timer Aj's I/O pins # 8.3 Timer mode In this mode, the timer counts an internally generated count source. (Refer to "**Table 8.3.1.**") Figure 8.3.1 shows the structures of the timer Ai mode register and timer Ai register in the timer mode. Table 8.3.1 Specifications of timer mode | Item | Specifications | |-------------------------------------|-----------------------------------------------------------------------------| | Count source | f <sub>2</sub> , f <sub>16</sub> , f <sub>64</sub> , or f <sub>512</sub> | | Count operation | Countdown | | | • When a counter underflow occurs, reload register's contents are reloaded, | | | and counting continues. | | Division ratio | 1 | | | (n + 1) n : Timer Ai register's set value | | Count start condition | When the count start bit is set to "1." | | Count stop condition | When the count start bit is cleared to "0." | | Interrupt request occurrence timing | When a counter underflow occurs. | | TAjıN pin's function | Programmable I/O port or gate input | | TAjout pin's function | Programmable I/O port or pulse output | | Read from timer Ai register | Counter value can be read out. | | Write to timer Ai register | ■ While counting is stopped | | | When a value is written to the timer Ai register, it is written to both | | | of the reload register and counter. | | | While counting is in progress | | | When a value is written to the timer Ai register, it is written only to | | | the reload register. (Transferred to the counter at the next reload | | | timing.) | #### 8.3 Timer mode Fig. 8.3.1 Structures of timer Ai mode register and timer Ai register in timer mode #### 8.3.1 Setting for timer mode Figures 8.3.2 and 8.3.3 show an initial setting example for registers relevant to the timer mode. Note that when using interrupts, set up to enable the interrupts. For details, refer to section "CHAPTER 7. INTERRUPTS." Fig. 8.3.2 Initial setting example for registers relevant to timer mode (1) ## 8.3 Timer mode Fig. 8.3.3 Initial setting example for registers relevant to timer mode (2) #### 8.3.2 Count source In the timer mode, the count source select bits (bits 6 and 7 at addresses $56_{16}$ to $5A_{16}$ ) select the count source. Table 8.3.2 lists the count source frequency. Table 8.3.2 Count source frequency | Count source select bits | | Count<br>source | ( | Count source frequency | , | |--------------------------|----|-------------------------|---------------------|------------------------------|------------------------------| | b7 | b6 | | $f(X_{IN}) = 8 MHz$ | f(X <sub>IN</sub> ) = 16 MHz | f(X <sub>IN</sub> ) = 25 MHz | | 0 | 0 | f <sub>2</sub> | 4 MHz | 8 MHz | 12.5 MHz | | 0 | 1 | <b>f</b> <sub>16</sub> | 500 kHz | 1 MHz | 1.5625 MHz | | 1 | 0 | <b>f</b> 64 | 125 kHz | 250 kHz | 390.625 kHz | | 1 | 1 | <b>f</b> <sub>512</sub> | 15625 Hz | 31250 Hz | 48.8281 kHz | #### 8.3 Timer mode #### 8.3.3 Operation in timer mode - ① When the count start bit is set to "1," the counter starts counting of the count source. - 2 When a counter underflow occurs, the reload register's contents are reloaded, and counting continues. - ③ The timer Ai interrupt request bit is set to "1" at the underflow in ②. The interrupt request bit remains set to "1" until the interrupt request is accepted or the interrupt request bit is cleared to "0" by software. Figure 8.3.4 shows an example of operation in the timer mode. Fig. 8.3.4 Example of operation in timer mode (without pulse output and gate functions) #### 8.3.4 Selectable functions The following describes the selectable gate function for Timers A2 to A4 and pulse output function. #### (1) Gate function The gate function is selected by setting the gate function select bits (bits 4 and 3 at addresses $58_{16}$ to $5A_{16}$ ) to " $10_2$ " or " $11_2$ ." The gate function makes it possible to start or stop counting depending on the $TA_{jiN}$ pin's input signal. Table 8.3.3 lists the count valid levels. Figure 8.3.5 shows an example of operation with the gate function selected. When selecting the gate function, set the port P5 direction registers' bits which correspond to the TAj<sub>IN</sub> pin for the input mode. Additionally, make sure that the TAj<sub>IN</sub> pin's input signal has a pulse width equal to or more than two cycles of the count source. Table 8.3.3 Count valid levels | Gate function | n select bits | Count valid level (Duration while counter counts) | |---------------|---------------|------------------------------------------------------------| | b4 | b3 | Count valid level (Duration write counter counts) | | 1 | 0 | While TAj <sub>IN</sub> pin's input signal is at "L" level | | 1 | 1 | While TAj৷ pin's input signal is at "H" level | Note: The counter does not count while the TAjiN pin's input signal is not at the count valid level. Fig. 8.3.5 Example of operation selecting gate function ### 8.3 Timer mode #### (2) Pulse output function The pulse output function is selected by setting the pulse output function select bit (bit 2 at addresses $58_{16}$ to $5A_{16}$ ) to "1." When this function is selected, the TAjout pin is forcibly set for the pulse output pin regardless of the corresponding bits of the port P5 direction register. The TAjout pin outputs pulses of which polarity is inverted each time a counter underflow occurs. When the count start bit (address 40<sub>16</sub>) is "0" (count stopped), the TAjout pin outputs "L" level. Figure 8.3.6 shows an example of operation with the pulse output function selected. Fig. 8.3.6 Example of operation selecting pulse output function ## [Precautions for timer mode] By reading the timer Ai register, the counter value can be read out at any timing. However, if the timer Ai register is read at the reload timing shown in Figure 8.3.7, the value "FFFF16" is read out. If reading is performed in the period from when a value is set into the timer Ai register with the counter stopped until the counter starts counting, the set value is correctly read out. Fig. 8.3.7 Reading timer Ai register ### 8.4 Event counter mode ### 8.4 Event counter mode In this mode, the timer counts an external signal. (Refer to "**Tables 8.4.1 and 8.4.2.**") Timers A2 to A4 can be used in this mode. Figure 8.4.1 shows the structures of the timer Aj mode register and timer Aj register in the event counter mode. Table 8.4.1 Specifications of event counter mode (when not using two-phase pulse signal processing function) | ltem | Specifications | |-------------------------------------|------------------------------------------------------------------------------------------| | Count source | ■ External signal input to the TAj <sub>IN</sub> pin | | | ● The count source's valid edge can be selected from the falling edge | | | and the rising edge by software. | | Count operation | <ul> <li>Countup or countdown can be switched by external signal or software.</li> </ul> | | | ● When a counter overflow or underflow occurs, reload register's contents | | | are reloaded, and counting continues. | | Division ratio | ● For countdown 1 | | | (n + 1) n : Timer Aj register's set value | | | $\bullet$ For countup $\frac{1}{\sqrt{FFFF}}$ | | | $\frac{1}{(FFF_{16}-n+1)}$ | | Count start condition | When the count start bit is set to "1." | | Count stop condition | When the count start bit is cleared to "0." | | Interrupt request occurrence timing | When a counter overflow or underflow occurs. | | TAjıN pin's function | Count source input | | TAjout pin's function | Programmable I/O port, pulse output, or countup/countdown switch signal | | | input | | Read from timer Aj register | Counter value can be read out. | | Write to timer Aj register | While counting is stopped | | | When a value is written to the timer Aj register, it is written to both | | | of the reload register and counter. | | | ■ While counting is in progress | | | When a value is written to the timer Aj register, it is written only to | | | the reload register. (Transferred to the counter at the next reload | | | time.) | # 8.4 Event counter mode Table 8.4.2 Specifications of event counter mode (when using two-phase pulse signal processing function) | Item | Specifications | |-------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------| | Count source | External signal (two-phase pulse) input to the TAjın or TAjout pin | | Count operation | <ul> <li>Countup or countdown can be switched by external signal (two-<br/>phase pulse).</li> </ul> | | | <ul> <li>When a counter overflow or underflow occurs, reload register's contents<br/>are reloaded, and counting continues.</li> </ul> | | Division ratio | | | | $ \begin{array}{c} \bullet \text{ For countup} \\ \hline $ | | Count start condition | When the count start bit is set to "1." | | Count stop condition | When the count start bit is cleared to "0." | | Interrupt request occurrence timing | When a counter overflow or underflow occurs. | | TAjın, TAjout pin function | Two-phase pulse input | | Read from timer Aj register | Counter value can be read out. | | Write to timer Aj register | While counting is stopped | | | When a value is written to the timer Aj register, it is written to both | | | of the reload register and counter. | | | While counting is in progress | | | When a value is written to the timer Aj register, it is written only to | | | the reload register. (Transferred to the counter at the next reload | | | time.) | ## 8.4 Event counter mode Fig. 8.4.1 Structures of timer Aj mode register and timer Aj register in event counter mode #### 8.4.1 Setting for event counter mode Figures 8.4.2 and 8.4.3 show an initial setting example for registers relevant to the event counter mode. Note that when using interrupts, set up to enable the interrupts. For details, refer to "CHAPTER 7. INTERRUPTS." Fig. 8.4.2 Initial setting example for registers relevant to event counter mode (1) ### 8.4 Event counter mode Fig. 8.4.3 Initial setting example for registers relevant to event counter mode (2) #### 8.4.2 Operation in event counter mode - ① When the count start bit is set to "1," the counter starts counting of the count source's valid edges. - ② When a counter underflow or overflow occurs, the reload register's contents are reloaded, and counting continues. - ③ The timer Aj interrupt request bit is set to "1" at the underflow or overflow in ②. The interrupt request bit remains set to "1" until the interrupt request is accepted or the interrupt request bit is cleared to "0" by software. Figure 8.4.4 shows an example of operation in the event counter mode. Fig. 8.4.4 Example of operation in event counter mode (without pulse output and two-phase pulse signal processing functions) #### 8.4 Event counter mode #### 8.4.3 Switching between countup and countdown The up-down register (address $44_{16}$ ) or the input signal from the TAjout pin is used to switch countup from and to countdown. This switching is performed by the up-down bit when the up-down switching factor select bit (bit 4 at addresses $58_{16}$ to $5A_{16}$ ) is "0," and by the input signal from the TAjout pin when the up-down switching factor select bit is "1." When the switching between countup and countdown is set while counting is in progress, this switching is actually performed when the count source's next valid edge is input. #### (1) Switching by up-down bit Countdown is performed when the up-down bit is "0," and countup is performed when the up-down bit is "1." Figure 8.4.5 shows the structure of the up-down register. #### (2) Switching by TAjout pin's input signal Countdown is performed when the TAjout pin's input signal is at "L" level, and countup is performed when the TAjout pin's input signal is at "H" level. When using the TAjout pin's input signal to switch countup from and to countdown, set the port P5 direction register's bit which corresponds to the TAjout pin for the input mode. Fig. 8.4.5 Structure of up-down register #### 8.4.4 Selectable functions The following describes the selectable pulse output, and two-phase pulse signal processing functions. #### (1) Pulse output function The pulse output function is selected by setting the pulse output function select bit (bit 2 at addresses 58<sub>16</sub> to 5A<sub>16</sub>) to "1." When this function is selected, the TAjout pin is forcibly set for the pulse output pin regardless of the corresponding bit of the port P5 direction register. The TAjout pin outputs pulses of which polarity is inverted each time a counter underflow or overflow occurs. (Refer to "**Figure 8.3.6.**") When the count start bit (address 40<sub>16</sub>) is "0" (count stopped), the TAjout pin outputs "L" level. ### 8.4 Event counter mode ### (2) Two-phase pulse signal processing function The two-phase pulse signal processing function is selected by setting the two-phase pulse signal processing select bits (bits 5 to 7 at address 44<sub>16</sub>) to "1." (Refer to "**Figure 8.4.5.**") Figure 8.4.6 shows the timer Aj mode registers when the two-phase pulse signal processing function is selected. For timers with the two-phase pulse signal processing function selected, the timer counts two kinds of pulses of which phases differ by 90 degrees. There are two types of the two-phase pulse signal processing: normal processing and quadruple processing. In Timers A2 and A3, normal processing is performed; in timer A4, quadruple processing is performed. For some bits of the port P5 direction register correspond to pins used for two-phase pulse input, set these bits for the input mode. Fig. 8.4.6 Timer Aj mode registers when two-phase pulse signal processing function is selected ### Normal processing Countup is performed at the rising edges input to the TAk<sub>IN</sub> pin when the phase has the relationship that the TAk<sub>IN</sub> pin's input signal level goes from "L" to "H" while the TAk<sub>OUT</sub> (k = 2 and 3) pin's input signal is at "H" level. Countdown is performed at the falling edges input to the TAk<sub>IN</sub> pin when the phase has the relationship that the TAk<sub>IN</sub> pin's input signal level goes from "H" to "L" while the TAk<sub>OUT</sub> pin's input signal is at "H" level. (Refer to "Figure 8.4.7.") Fig. 8.4.7 Normal processing ### ■Quadruple processing Countup is performed at all rising and falling edges input to the TA4out and TA4in pins when the phase has the relationship that the TA4in pin's input signal level goes from "L" to "H" while the TA4out pin's input signal is at "H" level. Countdown is performed at all rising and falling edges input to the TA4out and TA4in pins when the phase has the relationship that the TA4in pin's input signal level goes from "H" to "L" while the TA4out pin's input signal is at "H" level. (Refer to "Figure 8.4.8.") Table 8.4.3 lists the relationship between the input signals to the TA4out and TA4in pins and count operation when the quadruple processing is selected. Fig. 8.4.8 Quadruple processing Table 8.4.3 Relationship between input signals to TA4<sub>0UT</sub> and TA4<sub>IN</sub> pins and count operation when quadruple processing is selected | | Input signal to TA4out pin | Input signal to TA4IN pin | | |------------|----------------------------|---------------------------|--| | Up-count | "H" level | Rising edge | | | | "L" level | Falling edge | | | | Rising edge | "L" level | | | | Falling edge | "H" level | | | Down-count | "H" level | Falling edge | | | | "L" level | Rising edge | | | | Rising edge | "H" level | | | - | Falling edge | "L" level | | ## 8.4 Event counter mode ### [Precautions for event counter mode] 1. While counting is in progress, by reading the timer Aj register, the counter value can be read out at any timing. However, if the timer Aj register is read at the reload timing shown in Figure 8.4.9, the value "FFFF16" (at an underflow) or "000016" (at an overflow) is read out. If reading is performed in the period from when a value is set into the timer Aj register with the counter stopped until the counter starts counting, the set value is correctly read out. Fig. 8.4.9 Reading timer Aj register - 2. The TAjout pin is used for all functions listed below. Accordingly, only one of these functions can be selected for each timer. - •Switching between countup and countdown by TAjout pin's input signal - •Pulse output function - •Two-phase pulse signal processing function # 8.5 One-shot pulse mode In this mode, the timer outputs a pulse which has an arbitrary width once. (Refer to "**Table 8.5.1.**") Timers A2 to A4 can be used in this mode. When a trigger occurs, the timer outputs "H" level from the TAjout pin for an arbitrary time. Figure 8.5.1 shows the structures of the timer Aj mode register and timer Aj register in the one-shot pulse mode. Table 8.5.1 Specifications of one-shot pulse mode | Item | Specifications | | | | |-------------------------------------|-------------------------------------------------------------------------------|--|--|--| | Count source | f2, f16, f64, or f512 | | | | | Count operation | ● Countdown | | | | | | ● When the counter value becomes "000016," reload register's con- | | | | | | tents are reloaded, and counting stops. | | | | | | • If a trigger occurs during counting, reload register's contents are | | | | | | reloaded, and counting continues. | | | | | Output pulse width ("H") | $\frac{n}{f_i}$ [S] n: Timer Aj register's set value | | | | | Count start condition | ● When a trigger occurs. (Note) | | | | | | <ul> <li>Internal or external trigger can be selected by software.</li> </ul> | | | | | Count stop condition | ● When the counter value becomes "000016" | | | | | | When the count start bit is cleared to "0" | | | | | Interrupt request occurrence timing | When counting stops. | | | | | TAjın pin's function | Programmable I/O port or trigger input | | | | | TAjout pin's function | One-shot pulse output | | | | | Read from timer Aj register | An undefined value is read out. | | | | | Write to timer Aj register | While counting is stopped | | | | | | When a value is written to the timer Aj register, it is written to both | | | | | | of the reload register and counter. | | | | | | While counting is in progress | | | | | | When a value is written to the timer Aj register, it is written only to | | | | | | the reload register. (Transferred to the counter at the next reload | | | | | | time.) | | | | **Note:** The trigger is generated with the count start bit = "1." # 8.5 One-shot pulse mode Fig. 8.5.1 Structures of timer Aj mode register and timer Aj register in one-shot pulse mode ### 8.5.1 Setting for one-shot pulse mode Figures 8.5.2 and 8.5.3 show an initial setting example for registers relevant to the one-shot pulse mode. Note that when using interrupts, set up to enable the interrupts. For details, refer to "CHAPTER 7. INTERRUPTS." Fig. 8.5.2 Initial setting example for registers relevant to one-shot pulse mode (1) # 8.5 One-shot pulse mode Fig. 8.5.3 Initial setting example for registers relevant to one-shot pulse mode (2) ## 8.5.2 Count source In the one-shot pulse mode, the count source select bits (bits 6 and 7 at addresses $58_{16}$ to $5A_{16}$ ) select the count source. Table 8.5.2 lists the count source frequency. Table 8.5.2 Count source frequency | | source<br>et bits | Count<br>source | Count source frequency | | , | |----|-------------------|-------------------------|------------------------|------------------------------|------------------------------| | b7 | b6 | | $f(X_{IN}) = 8 MHz$ | f(X <sub>IN</sub> ) = 16 MHz | $f(X_{IN}) = 25 \text{ MHz}$ | | 0 | 0 | f <sub>2</sub> | 4 MHz | 8 MHz | 12.5 MHz | | 0 | 1 | <b>f</b> <sub>16</sub> | 500 kHz | 1 MHz | 1.5625 MHz | | 1 | 0 | <b>f</b> 64 | 125 kHz | 250 kHz | 390.625 kHz | | 1 | 1 | <b>f</b> <sub>512</sub> | 15625 Hz | 31250 Hz | 48.8281 kHz | # TIMER A ### 8.5 One-shot pulse mode ### 8.5.3 Trigger The counter is enabled for counting when the count start bit (address 40<sub>16</sub>) is set to "1." <u>The counter starts counting when a trigger is generated</u> after counting has been enabled. An internal or external trigger can be selected as that trigger. An internal trigger is selected when the trigger select bits (bits 4 and 3 at addresses 58<sub>16</sub> to 5A<sub>16</sub>) are "00<sub>2</sub>" or "01<sub>2</sub>"; an external trigger is selected when the bits are "10<sub>2</sub>" or "11<sub>2</sub>." If a trigger is generated during counting, the reload register's contents are reloaded and the counter continues counting. If generating a trigger during counting, make sure that a certain time which is equivalent to one cycle of the timer's count source or more has passed between the previously generated trigger and a new trigger. ## (1) When selecting internal trigger A trigger is generated when writing "1" to the one-shot start bit (bits 2 to 4 at address 42<sub>16</sub>). Figure 8.5.4 shows the structure of the one-shot start register. ### (2) When selecting external trigger A trigger is generated at the falling edge of the $TAj_{IN}$ pin's input signal when bit 3 at addresses $58_{16}$ to $5A_{16}$ is "0," or at its rising edge when bit 3 is "1." When using an external trigger, set the port P5 direction registers' bits which correspond to the TAjıN pins for the input mode. Fig. 8.5.4 Structure of one-shot start register ### 8.5.4 Operation in one-shot pulse mode - When the one-shot pulse mode is selected with the operating mode select bits, the TAjou pin outputs "L" level. - ② When the count start bit is set to "1," the counter is enabled for counting. After that, counting starts when a trigger is generated. - ③ When the counter starts counting, the TAjou⊤ pin outputs "H" level. - When the counter value becomes "0000₁6," the output from the TAjouT pin becomes "L" level. Additionally, the reload register's contents are reloaded and the counter stops counting there. - ⑤ Simultaneously with ④, the timer Aj interrupt request bit is set to "1." This interrupt request bit remains set to "1" until the interrupt request is accepted or the interrupt request bit is cleared to "0" by software. Figure 8.5.5 shows an example of operation in the one-shot pulse mode. When a trigger is generated after ④ above, the counter and TAjouT pin perform the same operations beginning from ② again. Furthermore, if a trigger is generated during counting, the counter performs countdown once after this new trigger is generated, and it continues counting with the reload register's contents reloaded. If generating a trigger during counting, make sure that a certain time which is equivalent to one cycle of the timer's count source or more has passed between the previously generated trigger and a new trigger. The one-shot pulse output from the TAjout pin can be disabled by clearing the timer Aj mode register's bit 2 to "0." Accordingly, Timer Aj can be also used as an internal one-shot timer that does not perform the pulse output. In this case, the TAjout pin functions as a programmable I/O port. # 8.5 One-shot pulse mode Fig. 8.5.5 Example of operation in one-shot pulse mode (selecting external trigger) ### [Precautions for one-shot pulse mode] - 1. If the count start bit is cleared to "0" during counting, the counter becomes as follows: - •The counter stops counting, and the reload register's contents are reloaded into the counter. - •The TAjouT pin's output level becomes "L." - •The timer Aj interrupt request bit is set to "1." - 2. A one-shot pulse is output synchronously with an internally generated count source. Accordingly, when selecting an external trigger, there will be a delay equivalent to one cycle of the count source at maximum from when a trigger is input to the TAjin pin until a one-shot pulse is output. Fig. 8.5.6 Output delay in one-shot pulse output - 3. When the timer's operating mode is set by one of the following procedures, the timer Aj interrupt request bit is set to "1." - •When the one-shot pulse mode is selected after reset - ●When the operating mode is switched from the timer mode to the one-shot pulse mode - ●When the operating mode is switched from the event counter mode to the one-shot pulse mode Accordingly, when using the timer Aj interrupt (interrupt request bit), be sure to clear the timer Aj interrupt request bit to "0" after the above setting. 4. Don not set " $0000_{16}$ " to the timer Aj register. # TIMER A # 8.6 Pulse width modulation (PWM) mode # 8.6 Pulse width modulation (PWM) mode In this mode, the timer continuously outputs pulses which have an arbitrary width. (Refer to "**Table 8.6.1.**") Timers A2 to A4 can be used in this mode. Figure 8.6.1 shows the structures of the timer Aj mode registers and timer Aj registers in the PWM mode. Table 8.6.1 Specifications of PWM mode | Item | Specifications | | | | |---------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Count source | f <sub>2</sub> , f <sub>16</sub> , f <sub>64</sub> , or f <sub>512</sub> | | | | | Count operation | Countdown (operating as an 8-bit or 16-bit pulse width modulator) | | | | | | <ul> <li>Reload register's contents are reloaded at rising edge of PWM pulse</li> </ul> | | | | | | and counting continues. | | | | | | <ul> <li>A trigger generated during counting does not affect the counting.</li> </ul> | | | | | PWM period/"H" level width | <16-bit pulse width modulator> | | | | | | Period = $\frac{(2^{16}-1)}{fi}$ [s] n : Timer Aj register's set value "H" level width = $\frac{n}{fi}$ [s] | | | | | | <pre>&lt;8-bit pulse width modulator&gt; Period = <math>\frac{(m+1)(2^8-1)}{fi}</math> [s] "H" level width = <math>\frac{n(m+1)}{fi}</math> [s] m : Timer Aj register low-order 8 bits' set value n : Timer Aj register high-order 8 bits' set value</pre> | | | | | Count start condition | When a trigger is generated. (Note) | | | | | | Internal or external trigger can be selected by software. | | | | | Count stop condition | When the count start bit is cleared to "0." | | | | | Interrupt request occurrence timing | At falling edge of PWM pulse | | | | | TAjıN pin's function | Programmable I/O port or trigger input | | | | | TAjout pin's function | PWM pulse output | | | | | Read from timer Aj register | r An undefined value is read out. | | | | | Write to timer Aj register | While counting is stopped | | | | | | When a value is written to the timer Aj register, it is written to both | | | | | | of the reload register and counter. | | | | | | While counting is in progress | | | | | When a value is written to the timer Aj register, it is | | | | | | | the reload register. (Transferred to the counter at the next reload | | | | | | time.) | | | | **Note:** The trigger is generated with the count start bit = "1." Fig. 8.6.1 Structures of timer Aj mode registers and timer Aj registers in PWM mode # 8.6 Pulse width modulation (PWM) mode ### 8.6.1 Setting for PWM mode Figures 8.6.2 and 8.6.3 show an initial setting example for registers relevant to the PWM mode. Note that when using interrupts, set up to enable the interrupts. For details, refer to "CHAPTER 7. INTERRUPTS." Fig. 8.6.2 Initial setting example for registers relevant to PWM mode (1) Fig. 8.6.3 Initial setting example for registers relevant to PWM mode (2) # TIMER A # 8.6 Pulse width modulation (PWM) mode #### 8.6.2 Count source In the PWM mode, the count source select bits (bits 6 and 7 at addresses $58_{16}$ to $5A_{16}$ ) select the count source. Table 8.6.2 lists the count source frequency. **Table 8.6.2 Count source frequency** | | source<br>et bits | Count<br>source | Count source frequency | | | |----|-------------------|-------------------------|------------------------|------------------------------|------------------------------| | b7 | b6 | | $f(X_{IN}) = 8 MHz$ | $f(X_{IN}) = 16 \text{ MHz}$ | $f(X_{IN}) = 25 \text{ MHz}$ | | 0 | 0 | f <sub>2</sub> | 4 MHz | 8 MHz | 12.5 MHz | | 0 | 1 | <b>f</b> <sub>16</sub> | 500 kHz | 1 MHz | 1.5625 MHz | | 1 | 0 | <b>f</b> <sub>64</sub> | 125 kHz | 250 kHz | 390.625 kHz | | 1 | 1 | <b>f</b> <sub>512</sub> | 15625 Hz | 31250 Hz | 48.8281 kHz | ### 8.6.3 Trigger When a trigger is generated, the TAjout pin starts outputting PWM pulses. An internal or an external trigger can be selected as that trigger. An internal trigger is selected when the trigger select bits (bits 4 and 3 at addresses $58_{16}$ to $5A_{16}$ ) are " $00_2$ " or " $01_2$ "; an external trigger is selected when the bits are " $10_2$ " or " $11_2$ ." A trigger generated during outputting of PWM pulses is invalid and it does not affect the pulse output operation. ### (1) When selecting internal trigger A trigger is generated when "1" is written to the count start bit (address 40<sub>16</sub>). ### (2) When selecting external trigger A trigger is generated at the falling edge of the $TAj_{IN}$ pin's input signal when bit 3 at addresses $58_{16}$ to $5A_{16}$ is "0," or at its rising edge when bit 3 is "1." <u>However, the trigger input is accepted only when the count start bit is "1."</u> When using an external trigger, set the port P5 direction registers' bits which correspond to the TAjıN pins for the input mode. ### 8.6.4 Operation in PWM mode - ① When the PWM mode is selected with the operating mode select bits, the TAjouT pin outputs "L" level. - ② When a trigger is generated, the counter (pulse width modulator) starts counting and the TAjou⊤ pin outputs a PWM pulse (**Notes 1 and 2**). - The timer Aj interrupt request bit is set to "1" each time the PWM pulse level goes from "H" to "L." The interrupt request bit remains set to "1" until the interrupt request is accepted or the interrupt request bit is cleared to "0" by software. - Each time a PWM pulse has been output for one period, the reload register's contents are reloaded and the counter continues counting. The following explains operations of the pulse width modulator. # (1) 16-bit pulse width modulator When the 16/8-bit PWM mode select bit is set to "0," the counter operates as a 16-bit pulse width modulator. Figures 8.6.4 and 8.6.5 show operation examples of the 16-bit pulse width modulator. ### (2) 8-bit pulse width modulator When the 16/8-bit PWM mode select bit is set to "1," the counter is divided into 8-bit halves. Then, the high-order 8 bits operate as an 8-bit pulse width modulator, and the low-order 8 bits operate as an 8-bit prescaler. Figures 8.6.6 and 8.6.7 show operation examples of the 8-bit pulse width modulator. - Notes 1: If a value "000016" is set into the timer Aj register when the counter operates as a 16-bit pulse width modulator, the pulse width modulator does not operate and the output from the TAjout pin remains "L" level. The timer Aj interrupt request does not occur. Similarly, if a value "0016" is set into the high-order 8 bits of the timer Aj register when the counter operates as an 8-bit pulse width modulator, the same is performed. - 2: When the counter operates as an 8-bit pulse width modulator, after a trigger is generated, the TAjouτ pin outputs "L" level which has the same width as "H" level width of the PWM pulse, which was set. After that, the PWM pulse output starts from the TAjouτ pin. # 8.6 Pulse width modulation (PWM) mode Fig. 8.6.4 Operation example of 16-bit pulse width modulator Fig. 8.6.5 Operation example of 16-bit pulse width modulator (when counter value is updated during pulse output) Fig. 8.6.6 Operation example of 8-bit pulse width modulator Fig. 8.6.7 Operation example of 8-bit pulse width modulator (when counter value is updated during pulse output) # [Precautions for PWM mode] - 1. If the count start bit is cleared to "0" while outputting PWM pulses, the counter stops counting. When the TAjout pin was outputting "H" level at that time, the output level becomes "L" and the timer Aj interrupt request bit is set to "1." When the TAjout pin was outputting "L" level, the output level does not change and a timer Aj interrupt request does not occur. - 2. When the timer's operating mode is set by one of the following procedures, the timer Aj interrupt request bit is set to "1." - •When the PWM mode is selected after reset - ●When the operating mode is switched from the timer mode to the PWM mode - •When the operating mode is switched from the event counter mode to the PWM mode Accordingly, when using the timer Aj interrupt (interrupt request bit), be sure to clear the timer Aj interrupt request bit to "0" after the above setting. # TIMER A 8.6 Pulse width modulation (PWM) mode **MEMORANDUM** # CHAPTER 9 # TIMER B - 9.1 Overview - 9.2 Block description - 9.3 Timer mode [Precautions for timer mode] 9.4 Event counter mode [Precautions for event counter mode] 9.5 Pulse period/Pulse width measurement mode [Precautions for pulse period/pulse width measurement (PWM) mode] # 9.1 Overview 9.2 Block description ### 9.1 Overview Timer B consists of three counters, Timers B0 to B2, each equipped with a 16-bit reload function. Timers B0 to B2 operate independently of one another. Timer B has three operating modes listed below. Timers B0 and B1 have selective three operating modes listed below. Timer B2 operates only in the timer mode. ### (1) Timer mode (Timers B0 to B2) The timer counts an internally generated count source. ### (2) Event counter mode (Timers B0 and B1) The timer counts an external signal. ### (3) Pulse period/Pulse width measurement mode (Timers B0 and B1) The timer measures an external signal's pulse period or pulse width. In this chapter, Timer Bi (i = 0 to 2) indicates Timers B0 to B2. Timer Bj (j = 0, 1) indicates Timers B0 and B1; this is used when the timer B's input/output pins are used etc. (Hereafter, input/output pins are called I/O pins.) # 9.2 Block description Figure 9.2.1 shows the block diagram of Timer B. Explanation of registers relevant to Timer B is described below. Fig. 9.2.1 Block diagram of Timer B ### 9.2.1 Counter and reload register (timer Bi register) Each of timer Bi counter and reload register consists of 16 bits and has the following functions. #### (1) Functions in timer mode and event counter mode Countdown in the counter is performed each time the count source is input. The reload register is used to store the initial value of the counter. When a counter underflow occurs, the reload register's contents are reloaded into the counter. A value is set to the counter and reload register by writing the value to the timer Bi register. Table 9.2.1 lists the memory assignment of the timer Bi register. The value written into the timer Bi register when the counting is not in progress is set to the counter and reload register. The value written into the timer Bi register when the counting is in progress is set only to the reload register. In this case, the reload register's updated contents are transferred to the counter when the next underflow occurs. The counter value is read out by reading out the timer Bi register. Note: When reading from or writing to the timer Bi register, perform it in a unit of 16 bits. For more information about the value obtained by reading the timer Bi register, refer to "[Precautions for timer mode]" and "[Precautions for event counter mode]." ### (2) Functions in pulse period/pulse width measurement mode Countup in the counter is performed each time the count source is input. The reload register is used to retain the pulse period or pulse width measurement result. When a valid edge is input to the TBj<sub>IN</sub> pin, the counter value is transferred to the reload register. In this mode, the value obtained by reading the timer Bj register is the reload register's contents, so that the measurement result is obtained. Note: When reading from the timer Bj register, perform it in a unit of 16 bits. Table 9.2.1 Memory assignment of timer Bi registers | Timer Bi register | High-order byte | Low-order byte | | |-------------------|--------------------------|--------------------------|--| | Timer B0 register | Address 51 <sub>16</sub> | Address 50 <sub>16</sub> | | | Timer B1 register | Address 53 <sub>16</sub> | Address 52 <sub>16</sub> | | | Timer B2 register | Address 55 <sub>16</sub> | Address 54 <sub>16</sub> | | **Note**: At reset, the contents of the timer Bi register are undefined. # TIMER B # 9.2 Block description ### 9.2.2 Count start register This register is used to start and stop counting. Each bit of this register corresponds to each timer. Figure 9.2.2 shows the structure of the count start register. Fig. 9.2.2 Structure of count start register ### 9.2.3 Timer Bi mode register Figure 9.2.3 shows the structure of the timer Bi mode register. The operating mode select bits are used to select the operating mode of Timer Bi. Bits 2, 3, and bits 5 to 7 have different functions according to the operating mode. These bits are described in the paragraph of each operating mode. Fig. 9.2.3 Structure of timer Bi mode register # TIMER B # 9.2 Block description ### 9.2.4 Timer Bi interrupt control register Figure 9.2.4 shows the structure of the timer Bi interrupt control register. For details about interrupts, refer to "CHAPTER 7. INTERRUPTS." Fig. 9.2.4 Structure of timer Bi interrupt control register ### (1) Interrupt priority level select bits (bits 2 to 0) These bits select a timer Bi interrupt's priority level. When using timer Bi interrupts, select one of the priority levels (1 to 7). When a timer Bi interrupt request occurs, its priority level is compared with the processor interrupt priority level (IPL). The requested interrupt is enabled only when its priority level is higher than the IPL. (However, this applies when the interrupt disable bit (I) = "0.") To disable timer Bi interrupts, set these bits to "0002" (level 0). ### (2) Interrupt request bit (bit 3) This bit is set to "1" when a timer Bi interrupt request occurs. This bit is automatically cleared to "0" when the timer Bi interrupt request is accepted. This bit can be set to "1" or cleared to "0" by software. ### 9.2.5 Port P5 direction register Input pins of Timer Bj are multiplexed with port P5. When using these pins as Timer Bj's input pins, set the corresponding bits of the port P5 direction register to "0" to set these port pins for the input mode. Figure 9.2.5 shows the relationship between port P5 direction register and the Timer Bj's input pins. Fig. 9.2.5 Relationship between port P5 direction register and Timer Bj's input pins # TIMER B # 9.3 Timer mode # 9.3 Timer mode In this mode, the timer counts an internally generated count source. (Refer to "**Table 9.3.1**.") Figure 9.3.1 shows the structures of the timer Bi mode register and timer Bi register in the timer mode. Table 9.3.1 Specifications of timer mode | Item | Specifications | | | | |-------------------------------------|----------------------------------------------------------------------------|--|--|--| | Count source | f <sub>2</sub> , f <sub>16</sub> , f <sub>64</sub> , or f <sub>512</sub> | | | | | Count operation | •Countdown | | | | | | •When a counter underflow occurs, reload register's contents are reloaded, | | | | | | and counting continues. | | | | | Division ratio | $\frac{1}{(n+1)}$ n: Timer Bi register's set value | | | | | Count start condition | When the count start bit is set to "1." | | | | | Count stop condition | When the count start bit is cleared to "0." | | | | | Interrupt request occurrence timing | When a counter underflow occurs. | | | | | TBj <sub>IN</sub> pin's function | Programmable I/O port | | | | | Read from timer Bi register | Counter value can be read out. | | | | | Write to timer Bi register | While counting is stopped | | | | | | When a value is written to the timer Bi register, it is written to both | | | | | | of the reload register and counter. | | | | | | While counting is in progress | | | | | | When a value is written to the timer Bi register, it is written only to | | | | | | the reload register. (Transferred to the counter at the next reload | | | | | | time.) | | | | Fig. 9.3.1 Structures of timer Bi mode register and timer Bi register in timer mode # TIMER B ## 9.3 Timer mode ### 9.3.1 Setting for timer mode Figure 9.3.2 shows an initial setting example for registers relevant to the timer mode. Note that when using interrupts, set up to enable the interrupts. For details, refer to "CHAPTER 7. INTERRUPTS." Fig. 9.3.2 Initial setting example for registers relevant to timer mode ### 9.3.2 Count source In the timer mode, the count source select bits (bits 6 and 7 at addresses 5B16 to 5D16) select the count source. Table 9.3.2 lists the count source frequency. **Table 9.3.2 Count source frequency** | | source<br>et bits | Count<br>source | Count source frequency | | | |----|-------------------|-------------------------|------------------------|------------------------------|------------------------------| | b7 | b6 | | $f(X_{IN}) = 8 MHz$ | f(X <sub>IN</sub> ) = 16 MHz | f(X <sub>IN</sub> ) = 25 MHz | | 0 | 0 | f <sub>2</sub> | 4 MHz | 8 MHz | 12.5 MHz | | 0 | 1 | <b>f</b> <sub>16</sub> | 500 kHz | 1 MHz | 1.5625 MHz | | 1 | 0 | <b>f</b> 64 | 125 kHz | 250 kHz | 390.625 kHz | | 1 | 1 | <b>f</b> <sub>512</sub> | 15625 Hz | 31250 Hz | 48.8281 kHz | # TIMER B ### 9.3 Timer mode ### 9.3.3 Operation in timer mode - ① When the count start bit is set to "1," the counter starts counting of the count source. - 2 When a counter underflow occurs, the reload register's contents are reloaded, and counting continues. - ③ The timer Bi interrupt request bit is set to "1" at the underflow in ②. The interrupt request bit remains set to "1" until the interrupt request is accepted or the interrupt request bit is cleared to "0" by software. Figure 9.3.3 shows an example of operation in the timer mode. Fig. 9.3.3 Example of operation in timer mode ## [Precautions for timer mode] While counting is in progress, by reading the timer Bi register, the counter value can be read out at any timing. However, if the timer Bi register is read at the reload timing shown in Figure 9.3.4, the value "FFFF16" is read out. If reading is performed in the period from when a value is set into the timer Bi register with the counter stopped until the counter starts counting, the set value is correctly read out. Fig. 9.3.4 Reading timer Bi register # TIMER B ## 9.4 Event counter mode # 9.4 Event counter mode In this mode, the timer counts an external signal. (Refer to "**Table 9.4.1.**") Figure 9.4.1 shows the structures of the timer Bj mode register and the timer Bj register in the event counter mode. Table 9.4.1 Specifications of event counter mode | Item | Specifications | | | |-------------------------------------|----------------------------------------------------------------------------|--|--| | Count source | •External signal input to the TBj⋈ pin | | | | | •The count source's valid edge can be selected from the falling edge, | | | | | the rising edge, and both of the falling and rising edges by software. | | | | Count operation | •Countdown | | | | | •When a counter underflow occurs, reload register's contents are reloaded, | | | | | and counting continues. | | | | Division ratio | $\frac{1}{(n+1)}$ n: Timer Bj register's set value | | | | Count start condition | When the count start bit is set to "1." | | | | Count stop condition | When the count start bit is cleared to "0." | | | | Interrupt request occurrence timing | When a counter underflow occurs. | | | | TBjin pin's function | Count source input | | | | Read from timer Bj register | Counter value can be read out. | | | | Write to timer Bj register | While counting is stopped | | | | | When a value is written to the timer Bj register, it is written to both | | | | | of the reload register and counter. | | | | | While counting is in progress | | | | | When a value is written to the timer Bj register, it is written only to | | | | | the reload register. (Transferred to the counter at the next reload | | | | | time.) | | | Fig. 9.4.1 Structures of timer Bj mode register and timer Bj register in event counter mode # TIMER B #### 9.4 Event counter mode #### 9.4.1 Setting for event counter mode Figure 9.4.2 shows an initial setting example for registers relevant to the event counter mode. Note that when using interrupts, set up to enable the interrupts. For details, refer to "CHAPTER 7. INTERRUPTS." Fig. 9.4.2 Initial setting example for registers relevant to event counter mode #### 9.4.2 Operation in event counter mode - ① When the count start bit is set to "1," the counter starts counting of the count source's valid edges. - 2 When a counter underflow occurs, the reload register's contents are reloaded, and counting continues. - ③ The timer Bj interrupt request bit is set to "1" at the underflow in ②. The interrupt request bit remains set to "1" until the interrupt request is accepted or the interrupt request bit is cleared to "0" by software. Figure 9.4.3 shows an example of operation in the event counter mode. Fig. 9.4.3 Example of operation in event counter mode # TIMER B ## 9.4 Event counter mode ## [Precautions for event counter mode] While counting is in progress, by reading the timer Bj register, the counter value can be read out at any timing. However, if the timer Bj register is read at the reload timing shown in Figure 9.4.4, the value "FFFF16" is read out. If reading is performed in the period from when a value is set into the timer Bj register with the counter stopped until the counter starts counting, the set value is correctly read out. Fig. 9.4.4 Reading timer Bj register # 9.5 Pulse period/Pulse width measurement mode In this mode, the timer measures an external signal's pulse period or pulse width. (Refer to "**Table 9.5.1.**") Timers B0 and B1 can be used in this mode. Figure 9.5.1 shows the structures of the timer Bj mode register and timer Bj register in the pulse period/pulse width measurement mode. #### Pulse period measurement The timer measures the pulse period of the external signal that is input to the TBjin pin. #### • Pulse width measurement The timer measures the pulse width ("L" level and "H" level widths) of the external signal that is input to the TBj<sub>IN</sub> pin. Table 9.5.1 Specifications of pulse period/pulse width measurement mode | Item | Specifications | | |-------------------------------------|------------------------------------------------------------------------------------------|--| | Count source | f2, f16, f64, or f512 | | | Count operation | ● Countup | | | | <ul> <li>Counter value is transferred to the reload register at valid edge of</li> </ul> | | | | measurement pulse, and counting continues after clearing the counter | | | | value to "000016." | | | Count start condition | When the count start bit is set to "1." | | | Count stop condition | When the count start bit is cleared to "0." | | | Interrupt request occurrence timing | ■ When valid edge of measurement pulse is input (Note 1). | | | | ● When a counter overflow occurs (Timer Bj overflow flag* is set to | | | | "1" simultaneously.) | | | TBjin pin's function | Measurement pulse input | | | Read from timer Bj register | The value obtained by reading timer Bj register is the reload register's | | | | contents (Measurement result) (Note 2). | | | Write to timer Bj register | Invalid | | Timer Bj overflow flag\*: The bit used to identify the source of an interrupt request occurrence. - Notes 1: No interrupt request occurs when the first valid edge is input after the counter starts counting. - 2: The value read out from the timer Bj register is undefined after the counter starts counting until the second valid edge is input. # 9.5 Pulse period/Pulse width measurement mode Fig. 9.5.1 Structures of timer Bj mode register and timer Bj register in pulse period/pulse width measurement mode #### 9.5.1 Setting for pulse period/pulse width measurement mode Figure 9.5.2 shows an initial setting example for registers relevant to the pulse period/pulse width measurement mode. Note that when using interrupts, set up to enable the interrupts. For details, refer to "CHAPTER 7. INTERRUPTS." Fig. 9.5.2 Initial setting example for registers relevant to pulse period/pulse width measurement mode # TIMER B # 9.5 Pulse period/Pulse width measurement mode #### 9.5.2 Count source In the pulse period/pulse width measurement mode, the count source select bits (bits 6 and 7 at addresses $5B_{16}$ and $5C_{16}$ ) select the count source. Table 9.5.2 lists the count source frequency. Table 9.5.2 Count source frequency | Count source select bits | | Count<br>source | Count source frequency | | | |--------------------------|----|------------------------|------------------------|------------------------------|------------------------------| | b7 | b6 | | $f(X_{IN}) = 8 MHz$ | f(X <sub>IN</sub> ) = 16 MHz | f(X <sub>IN</sub> ) = 25 MHz | | 0 | 0 | f <sub>2</sub> | 4 MHz | 8 MHz | 12.5 MHz | | 0 | 1 | <b>f</b> <sub>16</sub> | 500 kHz | 1 MHz | 1.5625 MHz | | 1 | 0 | <b>f</b> 64 | 125 kHz | 250 kHz | 390.625 kHz | | 1 | 1 | <b>f</b> 512 | 15625 Hz | 31250 Hz | 48.8281 kHz | #### 9.5.3 Operation in pulse period/pulse width measurement mode - ① When the count start bit is set to "1," the counter starts counting of the count source. - ② The counter value is transferred to the reload register when an valid edge of the measurement pulse is detected. (Refer to section "(1) Pulse period/Pulse width measurement.") - 3 The counter value is cleared to "000016" after the transfer in 2, and the counter continues counting. - ④ The timer Bj interrupt request bit is set to "1" when the counter value is cleared to "0000₁₆" in ③ (Note). The interrupt request bit remains set to "1" until the interrupt request is accepted or the interrupt request bit is cleared to "0" by software. - ⑤ The timer repeats operations ② to ④ above. Note: No timer Bj interrupt request occurs when the first valid edge is input after the counter starts counting. #### (1) Pulse period/Pulse width measurement The measurement mode select bits (bits 2 and 3 at addresses 5B<sub>16</sub> and 5C<sub>16</sub>) specify whether the pulse period of an external signal is measured or its pulse width is done. Table 9.5.3 lists the relationship between the measurement mode select bits and the pulse period/pulse width measurements. Make sure that the measurement pulse interval from the falling edge to the rising edge, and vice versa are two cycles of the count source or more. Additionally, use software to identify whether the measurement result indicates the "H" level or the "L" level width. Table 9.5.3 Relationship between measurement mode select bits and pulse period/pulse width measurements | b3 | b2 | Pulse period/Pulse width measurement | Measurement interval (Valid edges) | |----|----|--------------------------------------|---------------------------------------------------| | 0 | 0 | Pulse period measurement | From falling edge to falling edge (Falling edges) | | 0 | 1 | | From rising edge to rising edge (Rising edges) | | 1 | 0 | Pulse width measurement | From falling edge to rising edge, and vice versa | | | | | (Falling and rising edges) | #### (2) Timer Bj overflow flag A timer Bj interrupt request occurs when a measurement pulse's valid edge is input or a counter overflow occurs. The timer Bj overflow flag is used to identify the cause of the interrupt request, that is, whether it is an overflow occurrence or a valid edge input. The timer Bj overflow flag is set to "1" by an overflow. Accordingly, the cause of the interrupt request occurrence is identified by checking the timer Bj overflow flag in the interrupt routine. When a value is written to the timer Bj mode register with the count start bit = "1," the timer Bj overflow flag is cleared to "0" at the next count timing of the count source The timer Bj overflow flag is a read-only bit. Use the timer Bi interrupt request bit to detect the overflow timing. Do not use the timer Bi overflow flag for this detection. Figure 9.5.3 shows the operation during pulse period measurement. Figure 9.5.4 shows the operation during pulse width measurement. # TIMER B # 9.5 Pulse period/Pulse width measurement mode Fig. 9.5.3 Operation during pulse period measurement Fig. 9.5.4 Operation during pulse width measurement # [Precautions for pulse period/pulse width measurement mode] - 1. A timer Bj interrupt request is generated by the following sources: - Input of measured pulse's valid edge - Counter overflow When the overflow generates the interrupt request, the timer Bj overflow flag is set to "1." - 2. After reset, the timer Bj overflow flag is undefined. When a value is written to the timer Bj mode register with the count start bit = "1," this flag is cleared to "0" at the next count timing of the count source. - 3. An undefined value is transferred to the reload register when the first valid edge is input after the counter starts counting. In this case, no timer Bj interrupt request occurs. - 4. The counter value at start of counting is undefined. Accordingly, a timer Bj interrupt request may be generated by an overflow immediately after the counter starts counting. - 5. If the contents of the measurement mode select bits are changed after the counter starts counting, the timer Bj interrupt request bit is set to "1." When the same value which has been set in these bits are written again, the timer Bj interrupt request bit is not changed, that is, the bit retains the state. - 6. If the input signal to the TBjiN pin is affected by noise, etc., the counter may not perform the exact measurement. We recommend to verify, by software, that the measurement values are within a constant range. # TIMER B 9.5 Pulse period/Pulse width measurement mode **MEMORANDUM** - 10.1 Overview - 10.2 Block description - 10.3 Setting of real-time output - 10.4 Real-time output operation # 10.1 Overview #### 10.1 Overview The real-time output has the function of changing the output level of several pins simultaneously at every period of the timer. Figure 10.1.1 shows the block diagram of real-time output per bit. Real-time output has two operating modes described below. #### (1) Pulse mode 0 The 8-bit pulse output pins serve for two independent 4-bit outputs. Figure 10.1.2 shows the configuration of real-time output in the pulse mode 0. #### (2) Pulse mode 1 The 8-bit pulse output pins serve for a 2-bit and a 6-bit outputs. Figure 10.1.3 shows the configuration of real-time output in the pulse mode 1. Fig. 10.1.1 Block diagram of real-time output per bit Fig. 10.1.2 Configuration of real-time output in pulse mode 0 Fig. 10.1.3 Configuration of real-time output in pulse mode 1 # 10.2 Block description # 10.2 Block description Relevant registers to real-time output are described below. #### 10.2.1 Real-time output control register Figure 10.2.1 shows the structure of the real-time output control register. **Note:** When using the P60–P67 pins as the pulse output pins for real-time output, set the corresponding bits of the port P6 direction register (address 10<sub>16</sub>) to "1." | b1 b0 | 00 | 01 | 10 | 11 | |-------------------------------|----------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------| | When pulse mode 0 is selected | <ul> <li>─○ P67/RTP13</li> <li>─○ P66/RTP12</li> <li>─○ P65/RTP11</li> <li>─○ P64/RTP10</li> </ul> | - P67/RTP13<br>- P66/RTP12<br>- P65/RTP11<br>- P64/RTP10 | P67/RTP13 P66/RTP12 P65/RTP11 P64/RTP10 | <ul> <li>─○ P67/RTP13</li> <li>─○ P66/RTP12</li> <li>─○ P65/RTP11</li> <li>─○ P64/RTP10</li> </ul> | | | - P63/RTP03<br>- P62/RTP02<br>- P61/RTP01<br>- P60/RTP00 | P6 <sub>3</sub> /RTP0 <sub>3</sub><br>P6 <sub>2</sub> /RTP0 <sub>2</sub><br>P6 <sub>1</sub> /RTP0 <sub>1</sub><br>P6 <sub>0</sub> /RTP0 <sub>0</sub> | P6 <sub>3</sub> /RTP0 <sub>3</sub><br>P6 <sub>2</sub> /RTP0 <sub>2</sub><br>P6 <sub>1</sub> /RTP0 <sub>1</sub><br>P6 <sub>0</sub> /RTP0 <sub>0</sub> | | | When pulse mode 1 is selected | | | - P67/RTP13<br>- P66/RTP12<br>- P66/RTP11<br>- P64/RTP10<br>- P63/RTP03<br>- P62/RTP02 | - P67/RTP13<br>- P66/RTP12<br>- P65/RTP11<br>- P64/RTP10<br>- P63/RTP03<br>- P62/RTP02 | | | | | | -O P61/RTP01<br>-O P60/RTP00 RTP | Port : This functions as a programmable I/O port. RTP: This functions as a pulse output pin. Fig. 10.2.1 Structure of real-time output control register #### 10.2 Block description #### 10.2.2 Pulse output data registers 0 and 1 Figure 10.2.2 shows the structure of the pulse output data registers 0 and 1. The bit position of the RTP0<sub>2</sub> and RTP0<sub>3</sub> pulse output data bits differs according to the pulse mode. Before setting the pulse output data registers 0 and 1, set of the pulse output mode select bit (bit 2 at address 62<sub>16</sub>). The data written into the pulse output data registers 0 and 1 is output from the corresponding pulse output pins every underflow of Timers A0 and A1. Fig. 10.2.2 Structure of pulse output data registers 0 and 1 # 10.2 Block description #### 10.2.3 Port P6 direction register The pulse output pins are shared with port P6. When using these pins as pulse output pins of real-time output, set the corresponding bits of the port P6 direction register to "1" to set these ports for the output mode. Figure 10.2.3 shows the relationship between the port P6 direction register and the pulse output pins. Fig. 10.2.3 Relationship between port P6 direction register and pulse output pins After reset, the state of the port P6 pins are floated since these pins are in the input mode. The output levels of the pulse output pins are undefined until Timer A0 or A1 underflows first after the data for the timer is written. Because the pulse output data registers 0 and 1 are undefined after reset. When these conditions should be avoided, follow the procedure "Processing of avoiding undefined output before starting pulse output" in Figures 10.3.1 and 10.3.2. When reading the port P6 register (address E<sub>16</sub>), the output values of the real time output pins can be read out. #### 10.2.4 Timers A0 and A1 The data written into the pulse output registers 0 and 1 is output from the pulse output pins every underflow of Timer A0 or A1. Refer to section "8.3 Timer mode" for the setting of Timers A0 and A1. 10.3 Setting of real-time output # 10.3 Setting of real-time output Figures 10.3.1 to 10.3.3 show an initial setting example for registers relevant to the real-time output. Note that when using interrupts, set up to enable the interrupts. For details, refer to "CHAPTER 7. INTERRUPTS." Fig. 10.3.1 Initial setting example for registers relevant to real-time output (1) # 10.3 Setting of real-time output Fig. 10.3.2 Initial setting example for registers relevant to real-time output (2) # 10.3 Setting of real-time output Fig. 10.3.3 Initial setting example for registers relevant to real-time output (3) # 10.4 Real-time output operation # 10.4 Real-time output operation - ① When the timer Ai (i = 0, 1) count start bit is set to "1," the counter starts counting of the count source. - ② The contents of pulse output data register i are output from the pulse output pins at every underflow of Timer Ai. The timer is reloaded with the contents of the reload register and continues counting. - ③ The timer Ai interrupt request bit is set to "1" when the counter underflows in ②. The interrupt request bit retains "1" until the interrupt request is accepted or it is cleared by software. - Write the next output data into the pulse output data register i during the timer Ai interrupt routine or after the recognition of the timer Ai interrupt request occurrence. Figure 10.4.1 shows an example of real-time output operation. Fig. 10.4.1 Example of real-time output operation - 11.1 Overview - 11.2 Block description - 11.3 Clock synchronous serial I/O mode [Precautions for clock synchronous serial I/O mode] - 11.4 Clock asynchronous serial I/O (UART) mode #### 11.1 Overview #### 11.1 Overview Serial I/O consists of 2 channels: UART0 and UART1. They each have a transfer clock generating timer for the exclusive use of them and can operate independently. UART0 and UART1 have the same functions. UARTi (i = 0 and 1) has the following 2 operating modes: #### (1) Clock synchronous serial I/O mode Transmitter and receiver use the same clock as the transfer clock. Transfer data has a length of 8 bits. ## (2) Clock asynchronous serial I/O (UART) mode Transfer rate and transfer data format can arbitrarily be set. The user can select a transfer data length of 7 bits, 8 bits, or 9 bits. Figure 11.1.1 shows the transfer data formats in each operating mode. Fig. 11.1.1 Transfer data formats in each operating mode # 11.2 Block description Figure 11.2.1 shows the block diagram of Serial I/O. Registers relevant to Serial I/O are described below. Fig. 11.2.1 Block diagram of Serial I/O #### 11.2 Block description #### 11.2.1 UARTi transmit/receive mode register Figure 11.2.2 shows the structure of UARTi transmit/receive mode register. The serial I/O mode select bits are used to select a UARTi's operating mode. Bits 4 to 6 are described in section "11.4.2 Transfer data format," and bit 7 is done in section "11.4.8 Sleep mode." Fig. 11.2.2 Structure of UARTi transmit/receive mode register #### (1) Internal/External clock select bit (bit 3) #### ■ Clock synchronous serial I/O mode By clearing this bit to "0" in order to select an internal clock, the clock which is selected with the BRG count source select bits (bits 0 and 1 at addresses $34_{16}$ , $3C_{16}$ ) becomes the count source of the BRGi (described later). The BRGi's output divided by 2 becomes the transfer clock. Additionally, the transfer clock is output from the CLK<sub>i</sub> pin. By setting this bit to "1" in order to select an external clock, the clock input to the CLK<sub>i</sub> pin becomes the transfer clock. #### ■ UART mode By clearing this bit to "0" in order to select an internal clock, the clock which is selected with the BRG count source select bits (bits 0 and 1 at addresses $34_{16}$ , $3C_{16}$ ) becomes the count source of the BRGi (described later). Then, the CLKi pin functions as a programmable I/O port. By setting this bit to "1" in order to select an external clock, the clock input to the CLK<sub>i</sub> pin becomes the count source of BRGi. Always in the UART mode, the BRGi's output divided by 16 becomes the transfer clock. #### 11.2 Block description #### 11.2.2 UARTi transmit/receive control register 0 Figure 11.2.3 shows the structure of UARTi transmit/receive control register 0. For bits 0 and 1, refer to section "11.2.1 (1) Internal/External clock select bit (bit 3)." Fig. 11.2.3 Structure of UARTi transmit/receive control register 0 #### (1) CTS/RTS select bit (bit 2) By clearing this bit to "0" in order to select the CTS function, pins P8<sub>0</sub> and P8<sub>4</sub> function as CTS input pins, and the input signal of "L" level to these pins becomes one of the transmission conditions. By setting this bit to "1" in order to select the RTS function, pins P8<sub>0</sub> and P8<sub>4</sub> become RTS output pins. When the receive enable bit (bit 2 at addresses 35<sub>16</sub>, 3D<sub>16</sub>) is "0" (reception disabled), the RTS output pin outputs "H" level. In the clock synchronous serial I/O mode, the output level of the RTS pin becomes "L" when reception conditions are satisfied, and it becomes "H" when reception starts. Note that, when an internal clock is selected (bit 3 at addresses $30_{16}$ , $38_{16}$ = "0"), the RTS output is undefined. Accordingly, do not select the RTS function. In the clock asynchronous serial I/O mode, the output level of the RTS pin becomes "L" when the receive enable bit is set to "1." It becomes "H" when reception starts and it becomes "L" when reception is completed. #### (2) Transmit register empty flag (bit 3) This flag is cleared to "0" when the UARTi transmit buffer register's contents are transferred to the UARTi transmit register. When transmission is completed and the UARTi transmit register becomes empty, this flag is set to "1." #### 11.2.3 UARTi transmit/receive control register 1 Figure 11.2.4 shows the structure of UARTi transmit/receive control register 1. For bits 4 to 7, refer to section "11.3.6 Processing on detecting overrun error" and "11.4.7 Processing on detecting error." Fig. 11.2.4 Structure of UARTi transmit/receive control register 1 # 11.2 Block description #### (1) Transmit enable bit (bit 0) By setting this bit to "1," UARTi enters the transmission enable state. By clearing this bit to "0" during transmission, UARTi enters the transmission disable state after the transmission which is in progress at that time is completed. #### (2) Transmit buffer empty flag (bit 1) This flag is set to "1" when data set in the UARTi transmit buffer register is transferred from the UARTi transmit buffer register to the UARTi transmit register. This flag is cleared to "0" when data is set in the UARTi transmit buffer register. #### (3) Receive enable bit (bit 2) By setting this bit to "1," UARTi enters the reception enable state. By clearing this bit to "0" during reception, UARTi guits the reception immediately and enters the reception disable state. #### (4) Receive complete flag (bit 3) This flag is set to "1" when data is ready in the UARTi receive register and that is transferred to the UARTi receive buffer register (i.e., when reception is completed). This flag is cleared to "0" when one of the following is performed: - •Reading the low-order byte of the UARTi receive buffer register out - •Clearing the receive enable bit (bit 2) to "0" - •Clearing the serial I/O mode select bits (bits 2 to 0 at addresses 3016, 3816) to "0002." #### 11.2.4 UARTi transmit register and UARTi transmit buffer register Figure 11.2.5 shows the block diagram for the transmitter; Figure 11.2.6 shows the structure of UARTi transmit buffer register. Fig. 11.2.5 Block diagram for transmitter Fig. 11.2.6 Structure of UARTi transmit buffer register # 11.2 Block description Transmit data is set into the UARTi transmit buffer register. Set the transmit data into the low-order byte of this register when the microcomputer operates in the clock synchronous serial I/O mode or when a 7-bit or 8-bit length of transfer data is selected in the UART mode. When a 9-bit length of transfer data is selected in the UARTi transmit buffer register as follows: - •Bit 8 of the transmit data into bit 0 of high-order byte of this register. - •Bits 7 to 0 of the transmit data into the low-order byte of this register. The transmit data which is set in the UARTi transmit buffer register is transferred to the UARTi transmit register when the transmission conditions are satisfied, and then it is output from the TxDi pin synchronously with the transfer clock. The UARTi transmit buffer register becomes empty when the data which is set in the UARTi transmit buffer register is transferred to the UARTi transmit register. Accordingly, the user can set the next transmit data. When quitting the transmission which is in progress and setting the UARTi transmit buffer register again, follow the procedure described bellow: - ① Clear the serial I/O mode select bits (bits 2 to 0 at addresses 30<sub>16</sub>, 38<sub>16</sub>) to "000<sub>2</sub>" (Serial I/O disabled). - 2 Set the serial I/O mode select bits again. - 3 Set the transmit enable bit (bit 0 at addresses 35<sub>16</sub>, 3D<sub>16</sub>) to "1" (transmission enabled) and set transmit data in the UARTi transmit buffer register. #### 11.2.5 UARTi receive register and UARTi receive buffer register Figure 11.2.7 shows the block diagram for the receiver; Figure 11.2.8 shows the structure of UARTi receive buffer register. Fig. 11.2.7 Block diagram for receiver Fig. 11.2.8 Structure of UARTi receive buffer register # 11.2 Block description The UARTi receive register is used to convert serial data which is input to the RxD<sub>i</sub> pin into parallel data. This register takes in the signal input to the RxD<sub>i</sub> pin in a unit of 1 bit synchronously with the transfer clock. The UARTi receive buffer register is used to read out receive data. When reception is completed, the receive data which is taken in the UARTi receive register is automatically transferred to the UARTi receive buffer register. Note that the contents of the UARTi receive buffer register is updated when the next data is ready in the UARTi receive register before the data which has been transferred to the UARTi receive buffer register is read out. (i.e., an overrun error occurs.) The UARTi receive buffer register is initialized by setting the receive enable bit (bit 2 at addresses 35<sub>16</sub>, 3D<sub>16</sub>) to "1" after clearing it to "0." Figure 11.2.9 shows the contents of the UARTi receive buffer register when reception is completed. Fig. 11.2.9 Contents of UARTi receive buffer register when reception is completed #### 11.2.6 UARTi baud rate register (BRGi) The UARTi baud rate register (BRGi) is an 8-bit timer exclusively used for UARTi to generate a transfer clock. It has a reload register. Assuming that the value set in the BRGi is "n" ( $n = "00_{16}"$ to "FF<sub>16</sub>"), the BRGi divides the count source frequency by (n + 1). In the clock synchronous serial I/O mode, the BRGi is valid when an internal clock is selected, and the BRGi's output divided by 2 becomes the transfer clock. In the UART mode, the BRGi is always valid, and the BRGi's output divided by 16 becomes the transfer clock. The data which is written to the UARTi baud rate register (BRGi) is written to both the timer and the reload register whether transmission/reception is in progress or not. Accordingly, writing to these register must be performed while transmission/reception is stopped. Figure 11.2.10 shows the structure of the UARTi baud rate register (BRGi); Figure 11.2.11 shows the block diagram of transfer clock generating section. Fig. 11.2.10 Structure of UARTi baud rate register (BRGi) Fig. 11.2.11 Block diagram of transfer clock generating section ## 11.2 Block description #### 11.2.7 UARTi transmit interrupt control and UARTi receive interrupt control registers When using UARTi, 2 types of interrupts, which are UARTi transmit and UARTi receive interrupts, can be used. Each interrupt has its corresponding interrupt control register. Figure 11.2.12 shows the structure of UARTi transmit interrupt control and UARTi receive interrupt control registers. For details about interrupts, refer to "CHAPTER 7. INTERRUPTS." Fig. 11.2.12 Structure of UARTi transmit interrupt control and UARTi receive interrupt control registers #### (1) Interrupt priority level select bits (bits 0 to 2) These bits select a priority level of the UARTi transmit interrupt or UARTi receive interrupt. When using UARTi transmit/receive interrupts, select one of the priority levels (1 to 7). When a UARTi transmit/receive interrupt request occurs, its priority level is compared with the processor interrupt priority level (IPL). The requested interrupt is enabled only when its priority level is higher than the IPL. (However, this applies when the interrupt disable flag (I) = "0.") To disable UARTi transmit/receive interrupts, set these bits to " $000_2$ " (level 0). #### (2) Interrupt request bit (bit 3) The UARTi transmit interrupt request bit is set to "1" when data is transferred from the UARTi transmit buffer register to the UARTi transmit register. The UARTi receive interrupt request bit is set to "1" when data is transferred from the UARTi receive register to the UARTi receive buffer register. (However, when an overrun error occurs, it does not change.) Each interrupt request bit is automatically cleared to "0" when its corresponding interrupt request is accepted. This bit can be set to "1" or "0" by software. #### 11.2.8 Port P8 direction register I/O pins of UARTi are multiplexed with port P8. When using pins P82 and P86 as serial data input pins (RxDi), set the corresponding bits of the port P8 direction register to "0" to set these pins for the input mode. When using pins P80, P81, P83 to P85 and P87 as I/O pins ( $\overline{CTSi/RTSi}$ , CLKi, TxDi) of UARTi, these pins are forcibly set as I/O pins of UARTi regardless of the port P8 direction register's contents. Figure 11.2.13 shows the relationship between the port P8 direction register and UARTi's I/O pins. For details, refer to the description of each operating mode. Fig. 11.2.13 Relationship between port P8 direction register and UARTi's I/O pins ## 11.3 Clock synchronous serial I/O mode ## 11.3 Clock synchronous serial I/O mode Table 11.3.1 lists the performance overview in the clock synchronous serial I/O mode, and Table 11.3.2 lists the functions of I/O pins in this mode. Table 11.3.1 Performance overview in clock synchronous serial I/O mode | Item | | Functions | | |--------------------------|-------------------------------|-----------------------------------------------------------|--| | Transfer data format | | Transfer data has a length of 8 bits. | | | | | LSB first | | | Transfer rate | When selecting internal clock | BRGi's output divided by 2 | | | | When selecting external clock | Maximum 5 Mbps | | | Transmit/Receive control | | CTS function or RTS function can be selected by software. | | Table 11.3.2 Functions of I/O pins in clock synchronous serial I/O mode | Pin name | Functions | Method of selection | |-------------------------------------------------------|-----------------------|-----------------------------------------------------------------| | TxDi (P83, P87) | Serial data output | | | (Note) | | (Dummy data is output when performing only reception.) | | RxDi (P82, P86) | Serial data input | Port P8 direction register*1's corresponding bit = "0" | | | | (Can be used as an I/O port when performing only transmission.) | | CLK <sub>i</sub> (P8 <sub>1</sub> , P8 <sub>5</sub> ) | Transfer clock output | Internal/External clock select bit*2 = "0" | | | Transfer clock input | Internal/External clock select bit = "1" | | CTS <sub>i</sub> /RTS <sub>i</sub> | CTS input | CTS/RTS select bit*3 = "0" | | (P8 <sub>0</sub> , P8 <sub>4</sub> ) | RTS output | CTS/RTS select bit = "1" | Port P8 direction register\*1: address 14<sub>16</sub> Internal/External clock select bit\*2: bit 3 at addresses 3016, 3816 CTS/RTS select bit\*3: bit 2 at addresses 3416, 3C16 Note: The TxDi pin outputs "H" level until transmission starts after UARTi's operating mode is selected. #### 11.3.1 Transfer clock (Synchronizing clock) Data transfer is performed synchronously with the transfer clock. For the transfer clock, the user can select whether to generate the transfer clock internally or to input it from the external. The transfer clock is generated by operation of the transmit control circuit. Accordingly, <u>even when performing only reception</u>, set the transmit enable bit to "1," and set dummy data in the UARTi transmit buffer register in order to <u>make the transmit control circuit active</u>. #### (1) Internal generation of transfer clock The count source selected with the BRG count source select bits is divided by the BRGi, and the BRGi output is further divided by 2. This is the transfer clock. The transfer clock is output from the CLK<sub>i</sub> pin. #### [Setting for relevant registers] - •Select an internal clock (bit 3 at addresses 30<sub>16</sub>, 38<sub>16</sub> = "0"). - •Select the BRGi's count source (bits 0 and 1 at addresses 3416, 3C16) - •Set "division value 1" (= n; 0016 to FF16) to the BRGi (addresses 3116, 3916). Transfer clock's frequency = $$\frac{f_i}{2 (n+1)}$$ f<sub>i</sub>: Frequency of BRGi's count source (f<sub>2</sub>, f<sub>16</sub>, f<sub>64</sub>, f<sub>512</sub>) - •Enable transmission (bit 0 at addresses 35<sub>16</sub>, 3D<sub>16</sub> = "1"). - •Set data to the UARTi transmit buffer register (addresses 3216, 3A16) #### [Pin's state] - •A transfer clock is output from the CLK; pin. - •Serial data is output from the TxDi pin. (Dummy data is output when performing only reception.) #### (2) Input of transfer clock from the external A clock input from the CLK<sub>i</sub> pin is the transfer clock. #### [Setting for relevant registers] - •Select an external clock (bit 3 at addresses 30<sub>16</sub>, 38<sub>16</sub> = "1"). - •Enable transmission (bit 0 at addresses 35<sub>16</sub>, 3D<sub>16</sub> = "1"). - •Set data to the UARTi transmit buffer register (addresses 32<sub>16</sub>, 3A<sub>16</sub>). #### [Pin's state] - •A transfer clock is input from the CLK<sub>i</sub> pin. - •Serial data is output from the TxDi pin. (Dummy data is output when performing only reception.) ## 11.3 Clock synchronous serial I/O mode #### 11.3.2 Method of transmission Figure 11.3.1 shows an initial setting example for relevant registers when transmitting. Transmission is started when all of the following conditions (① to ③) are satisfied. When an external clock is selected, satisfy conditions ① to ③ with the following precondition satisfied. #### <Pre><Precondition> The CLK<sub>i</sub> pin's input is at "H" level Note: When an internal clock is selected, the above precondition is ignored. - ① Transmission is enabled (transmit enable bit = "1"). - 2 Transmit data is present in the UARTi transmit buffer register (transmit buffer empty flag = "0") - ③ The $\overline{CTS_i}$ pin's input is at "L" level (when the $\overline{CTS}$ function selected). Note: When the CTS function is not selected, condition 3 is ignored. By connecting the RTS<sub>i</sub> pin (receiver side) and CTS<sub>i</sub> pin (transmitter side), the timing of transmission and that of reception can be matched. For details, refer to section "11.3.5 Receive operation." When using interrupts, it is necessary to set the relevant registers to enable interrupts. For details, refer to "CHAPTER 7. INTERRUPTS." Figure 11.3.2 shows writing data after start of transmission, and Figure 11.3.3 shows detection of transmit completion. Fig. 11.3.1 Initial setting example for relevant registers when transmitting Fig. 11.3.2 Writing data after start of transmission Fig. 11.3.3 Detection of transmit completion #### 11.3.3 Transmit operation When the transmit conditions described in section "11.3.2 Method of transmission" are satisfied in the case of selecting an internal clock, a transfer clock is generated and the following operations are automatically performed after 1 cycle of the transfer clock has passed. When the transmit conditions are satisfied and the external clock is input to the CLKi pin in the case of selecting an external clock, the following operations are automatically performed. - •The UARTi transmit buffer register's contents are transferred to the UARTi transmit register. - •The transmit buffer empty flag is set to "1." - •The transmit register empty flag is cleared to "0." - •8 transfer clocks are generated (when an internal clock is selected). - •A UARTi transmit interrupt request occurs, and the interrupt request bit is set to "1." The transmit operations are described below: - ① Data in the UARTi transmit register is transmitted from the TxDi pin synchronously with the falling edge of the transfer clock. - This data is transmitted bit by bit sequentially beginning with the least significant bit. - 3 When 1-byte data has been transmitted, the transmit register empty flag is set to "1." This indicates the completion of transmission. #### Figure 11.3.4 shows the transmit operation. When an internal clock is selected, when the transmit conditions for the next data are satisfied at completion of the transmission, the transfer clock is generated continuously. Accordingly, when performing transmission continuously, set the next transmit data to the UARTi transmit buffer register during transmission (when the transmit register empty flag = "0"). When the transmit conditions for the next data are not satisfied, the transfer clock stops at "H" level. Figures 11.3.5 and 11.3.6 show examples of transmit timing. Fig. 11.3.4 Transmit operation Fig. 11.3.5 Example of transmit timing (when selecting internal clock, selecting CTS function) Fig. 11.3.6 Example of transmit timing (when selecting internal clock, not selecting CTS function) #### 11.3.4 Method of reception Figures 11.3.7 and 11.3.8 show initial setting examples for relevant registers when receiving. Reception is started when all of the following conditions (① to ③) are satisfied. When an external clock is selected, satisfy conditions ① to ③ with the following precondition satisfied. #### <Pre>condition> The CLKi pin's input is at "H" level. Note: When an internal clock is selected, the above precondition is ignored. - ① Reception is enabled (receive enable bit = "1"). - ② Transmission is enabled (transmit enable bit = "1"). - 3 Dummy data is present in the UARTi transmit buffer register (transmit buffer empty flag = "0") By connecting the RTS<sub>i</sub> pin (receiver side) and CTS<sub>i</sub> pin (transmitter side), the timing of transmission and that of reception can be matched. For details, refer to section "11.3.5 Receive operation." When using interrupts, it is necessary to set the relevant registers to enable interrupts. For details, refer to "CHAPTER 7. INTERRUPTS." Figure 11.3.9 shows processing after receive completion. Fig. 11.3.7 Initial setting example for relevant registers when receiving (1) Fig. 11.3.8 Initial setting example for relevant registers when receiving (2) Fig. 11.3.9 Processing after receive completion #### 11.3.5 Receive operation In the case of selecting an internal clock, when the receive conditions described in section "11.3.4 Method of reception" are satisfied, a transfer clock is generated and the reception is started after 1 cycle of the transfer clock has passed. In the case of selecting an external clock, when the receive conditions are satisfied, the UARTi enters the receive enable state and reception is started by input of an external clock to the CLKi pin. In the case of selecting an external clock and the RTS function, when the UARTi enters the receive enable state, the $\overline{RTS_i}$ pin's output level becomes "L" to inform the transmitter side that reception is enabled. When reception is started, the $\overline{RTS_i}$ pin's output level becomes "H." Accordingly, by connecting the $\overline{RTS_i}$ pin to the $\overline{CTS_i}$ pin of the transmitter side, the timing of transmission and that of reception can be matched. When an internal clock is selected, do not use the $\overline{RTS}$ function. It is because the $\overline{RTS}$ output becomes undefined. Figure 11.3.10 shows a connection example. The receive operations are described below: - ① The input signal of the RxDi pin is taken into the most significant bit of the UARTi receive register synchronously with the rising edge of the transfer clock. - 2 The contents of the UARTi receive register are shifted by 1 bit to the right. - 3 Steps 1 and 2 are repeated at each rising edge of the transfer clock. - When 1-byte data is prepared in the UARTi receive register, the contents of this register are transferred to the UARTi receive buffer register. - ⑤ Simultaneously with step ④, the receive complete flag is set to "1," and a UARTi receive interrupt request occurs and its interrupt request bit is set to "1." The receive complete flag is cleared to "0" when the low-order byte of the UARTi receive buffer register is read out. The RTS<sub>i</sub> pin outputs "H" level until the receive conditions are next satisfied (when selecting the RTS function). Figure 11.3.11 shows the receive operation, and Figure 11.3.12 shows an example of receive timing (when selecting an external clock). Fig. 11.3.10 Connection example ## 11.3 Clock synchronous serial I/O mode Fig. 11.3.11 Receive operation Fig. 11.3.12 Example of receive timing (when selecting external clock) #### 11.3.6 Processing on detecting overrun error In the clock synchronous serial I/O mode, an overrun error can be detected. An overrun error occurs when the next data is prepared in the UARTi receive register with the receive complete flag = "1" (data is present in the UARTi receive buffer register) and next data is transferred to the UARTi receive buffer register, in other words, when the next data is prepared before reading out the contents of the UARTi receive buffer register. When an overrun error occurs, the next receive data is written into the UARTi receive buffer register, and the UARTi receive interrupt request bit is not changed. An overrun error is detected when data is transferred from the UARTi receive register to the UARTi receive buffer register and the overrun error flag is set to "1." The overrun error flag is cleared to "0" by clearing the serial I/O mode select bits to "0002" or clearing the receive enable bit to "0." When an overrun error occurs during reception, initialize the overrun error flag and the UARTi receive buffer register before performing reception again. When it is necessary to perform retransmission owing to an overrun error which occurs in the receiver side, set the UARTi transmit buffer register again before starting transmission again. The method of initializing the UARTi receive buffer register and that of setting the UARTi transmit buffer register again are described below. #### (1) Method of initializing UARTi receive buffer register - ① Clear the receive enable bit to "0" (Reception disabled). - 2 Set the receive enable bit to "1" again (Reception enabled). #### (2) Method of setting UARTi transmit buffer register again - ① Clear the serial I/O mode select bits to "0002" (Serial I/O invalid). - ② Set the serial I/O mode select bits to "0012" again. - ③ Set the transmit enable bit to "1" (Transmission enabled), and set the transmit data to the UARTi transmit buffer register. ## 11.3 Clock synchronous serial I/O mode ## [Precautions for clock synchronous serial I/O mode] - 1. The transfer clock is generated by operation of the transmit control circuit. Accordingly, even when performing only reception, transmit operation (setting for transmission) must be performed. In this case, dummy data is output from the TxD<sub>i</sub> pin. - 2. When receiving, simultaneously set the receive enable bit and the transmit enable bit to "1." - 3. When receiving data, write dummy data to the low-order byte of the UARTi transmit buffer register for each reception of 1-byte data. - 4. When selecting an external clock, satisfy the following 3 conditions with the input to the CLK<sub>i</sub> pin = "H" level. #### <When transmitting> - ① Set the transmit enable bit to "1." - 2 Write transmit data to the UARTi transmit buffer register. #### <When receiving> - ① Set the receive enable bit to "1." - 2 Set the transmit enable bit to "1." - 3 Write dummy data to the UARTi transmit buffer register. Table 11.4.1 lists the performance overview in the UART mode, and Table 11.4.2 lists the functions of I/O pins in this mode. Table 11.4.1 Performance overview in UART mode | Item | | Functions | | |----------------------------------------------------------------------|-------------------------------|--------------------------------------------------------------------|--| | Transfer data | Start bit | 1 bit | | | format | Character bit (Transfer data) | 7 bits, 8 bits, or 9 bits | | | | Parity bit | 0 bit or 1 bit (Odd or even can be selected.) | | | | Stop bit | 1 bit or 2 bits | | | Transfer rate When selecting internal clock BRGi's output divided by | | BRGi's output divided by 16 | | | | When selecting external clock | Maximum 312.5 kbps | | | Error detection | | 4 types (Overrun, Framing, Parity, and Summing) | | | | | Presence of error can be detected only by checking error sum flag. | | Table 11.4.2 Functions of I/O pins in UART mode | Pin name | Functions | Method of selection | | |-------------------------------------------------------|---------------------------|---------------------------------------------------------|--| | TxDi (P83, P87) (Note 1) | Serial data output | | | | | | (Cannot be used as a programmable I/O port even when | | | | | performing only reception.) | | | RxDi (P82, P86) | Serial data input | Port P8 direction register*1's corresponding bit = "0" | | | | | (Can be used as a programmable I/O port when performing | | | | | only transmission.) | | | CLK <sub>i</sub> (P8 <sub>1</sub> , P8 <sub>5</sub> ) | Programmable I/O port | Internal/External clock select bit*2 = "0" | | | | BRGi's count source input | Internal/External clock select bit = "1" | | | CTSi/RTSi (P80, P84) | CTS input | CTS/RTS function select bit*3 = "0" | | | (Note 2) | RTS output | CTS/RTS function select bit = "1" | | Port P8 direction register\*1: address 14<sub>16</sub> Internal/External clock select bit\*2: bit 3 at addresses 30<sub>16</sub>, 38<sub>16</sub> CTS/RTS select bit\*3: bit 2 at addresses 34<sub>16</sub>, 3C<sub>16</sub> **Notes 1:** The TxD<sub>i</sub> pin outputs "H" level while transmission is not performed after selecting UARTi's operating mode. 2: The CTS<sub>i</sub>/RTS<sub>i</sub> pin can be used as an input port when performing only reception and not using the RTS function (when selecting CTS function). ## 11.4 Clock asynchronous serial I/O (UART) mode #### 11.4.1 Transfer rate (Frequency of transfer clock) The transfer rate is determined by the BRGi (addresses 31<sub>16</sub>, 39<sub>16</sub>). When setting "n" into BRGi, BRGi divides the count source frequency by (n + 1). The BRGi's output is further divided by 16, and the resultant clock becomes the transfer clock. Accordingly, "n" is expressed by the following formula. $$n = \frac{F}{16 \times B} - 1$$ n: Value set in BRGi (0016 to FF16) F: BRGi's count source frequency (Hz) B: Transfer rate (bps) An internal clock or an external clock can be selected as the BRGi's count source with the internal/external clock select bit (bit 3 at addresses 30<sub>16</sub>, 38<sub>16</sub>). When an internal clock is selected, the clock selected with the BRG count source select bits (bits 0 and 1 at addresses 34<sub>16</sub>, 3C<sub>16</sub>) becomes the BRGi's count source. When an external clock is selected, the clock input to the CLK<sub>i</sub> pin becomes the BRGi's count source. Set the same transfer rate for both transmitter and receiver sides. Tables 11.4.3 and 11.4.4 list the setting examples of transfer rate. Table 11.4.3 Setting examples of transfer rate (1) | Transfer | f(X <sub>IN</sub> ) = 24.576 MHz | | | $f(X_{IN}) = 25 \text{ MHz}$ | | | |------------|----------------------------------|-------------------------|-------------|------------------------------|-------------------------|-------------| | | BRGi's | BRGi's set | Actual time | BRGi's | BRGi's set | Actual time | | rate (bps) | count source | value : n | (bps) | count source | value : n | (bps) | | 300 | f <sub>64</sub> | 79 (4F <sub>16</sub> ) | 300.00 | <b>f</b> 64 | 80 (5016) | 301.41 | | 600 | <b>f</b> <sub>16</sub> | 159 (9F <sub>16</sub> ) | 600.00 | <b>f</b> <sub>16</sub> | 162 (A2 <sub>16</sub> ) | 599.12 | | 1200 | <b>f</b> 16 | 79 (4F <sub>16</sub> ) | 1200.00 | <b>f</b> <sub>16</sub> | 80 (5016) | 1205.63 | | 2400 | <b>f</b> 16 | 39 (27 <sub>16</sub> ) | 2400.00 | <b>f</b> <sub>16</sub> | 40 (2816) | 2381.86 | | 4800 | f <sub>2</sub> | 159 (9F <sub>16</sub> ) | 4800.00 | f <sub>2</sub> | 162 (A2 <sub>16</sub> ) | 4792.94 | | 9600 | f <sub>2</sub> | 79 (4F <sub>16</sub> ) | 9600.00 | f <sub>2</sub> | 80 (5016) | 9645.06 | | 14400 | f <sub>2</sub> | 52 (3416) | 14490.57 | f <sub>2</sub> | 53 (3516) | 14467.59 | | 19200 | f <sub>2</sub> | 39 (27 <sub>16</sub> ) | 19200.00 | f <sub>2</sub> | 40 (2816) | 19054.58 | | 31250 | | | | f <sub>2</sub> | 24 (1816) | 31250.00 | | 38400 | f <sub>2</sub> | 19 (1316) | 38400.00 | | | | Table 11.4.4 Setting examples of transfer rate (2) | Transfer | f(X <sub>IN</sub> ) = 22.1184 MHz | | | | |------------|-----------------------------------|-------------------------|-------------|--| | | BRGi's BRGi's set | | Actual time | | | rate (bps) | count source | value : n | (bps) | | | 300 | <b>f</b> <sub>64</sub> | 71 (47 <sub>16</sub> ) | 300.00 | | | 600 | <b>f</b> <sub>16</sub> | 143 (8F <sub>16</sub> ) | 600.00 | | | 1200 | <b>f</b> 16 | 71 (47 <sub>16</sub> ) | 1200.00 | | | 2400 | <b>f</b> 16 | 35 (2316) | 2400.00 | | | 4800 | f <sub>2</sub> | 143 (8F <sub>16</sub> ) | 4800.00 | | | 9600 | f <sub>2</sub> | 71 (47 <sub>16</sub> ) | 9600.00 | | | 14400 | f <sub>2</sub> | 47 (2F <sub>16</sub> ) | 14400.00 | | | 19200 | f <sub>2</sub> | 35 (2316) | 19200.00 | | | 28800 | f <sub>2</sub> | 23 (17 <sub>16</sub> ) | 28800.00 | | | 31250 | f <sub>2</sub> | 21 (1516) | 31418.18 | | | 38400 | f <sub>2</sub> | 17 (1116) | 38400.00 | | | 57600 | f <sub>2</sub> | 11 (0B <sub>16</sub> ) | 57600.00 | | | 115200 | f <sub>2</sub> | 5 (0516) | 115200.00 | | | 230400 | f <sub>2</sub> | 2 (0216) | 230400.00 | | #### 11.4.2 Transfer data format The transfer data format can be selected from formats shown in Figure 11.4.1. Bits 4 to 6 at addresses 30<sub>16</sub> and 38<sub>16</sub> select the transfer data format. (Refer to "Figure 11.2.2.") Set the same transfer data format for both transmitter and receiver sides. Figure 11.4.2 shows an example of transfer data format. Table 11.4.5 lists each bit in transmit data. Fig. 11.4.1 Transfer data format Fig. 11.4.2 Example of transfer data format Table 11.4.5 Each bit in transmit data | Name | Functions | | | |---------------|-----------------------------------------------------------------------------------------|--|--| | ST | "L" signal equivalent to 1 character bit which is added immediately before the | | | | Start bit | character bits. It indicates start of data transmission. | | | | DATA | Transmit data which is set in the UARTi transmit buffer register. | | | | Character bit | | | | | PAR | A signal that is added immediately after the character bits in order to improve data | | | | Parity bit | reliability. The level of this signal changes according to selection of odd/even parity | | | | | in such a way that the sum of "1"s in this bit and character bits is always an odd | | | | | or even number. | | | | SP | "H" level signal equivalent to 1 or 2 character bits which is added immediately after | | | | Stop bit | the character bits (or parity bit when parity is enabled). It indicates finish of data | | | | | transmission. | | | ## 11.4 Clock asynchronous serial I/O (UART) mode #### 11.4.3 Method of transmission Figure 11.4.3 shows an initial setting example for relevant registers when transmitting. The difference due to selection of transfer data length (7 bits, 8 bits, or 9 bits) is only that data length. When selecting a 7- or 8-bit data length, set the transmit data into the low-order byte of the UARTi transmit buffer register. When selecting a 9-bit data length, set the transmit data into the low-order byte and bit 0 of the high-order byte. Transmission is started when all of the following conditions (1) to 3) are satisfied: - ① Transmit is enabled (transmit enable bit = "1"). - 2 Transmit data is present in the UARTi transmit buffer register (transmit buffer empty flag = "0"). - ③ The CTSi pin's input is at "L" level (when the CTS function selected). Note: When the CTS function is not selected, condition 3 is ignored. By connecting the RTS<sub>i</sub> pin (receiver side) and CTS<sub>i</sub> pin (transmitter side), the timing of transmission and that of reception can be matched. For details, refer to section "11.4.6 Receive operation." When using interrupts, it is necessary to set the relevant registers to enable interrupts. For details, refer to "CHAPTER 7. INTERRUPTS." Figure 11.4.4 shows writing data after start of transmission, and Figure 11.4.5 shows detection of transmit completion. Fig. 11.4.3 Initial setting example for relevant registers when transmitting Fig. 11.4.4 Writing data after start of transmission Fig. 11.4.5 Detection of transmit completion ## 11.4 Clock asynchronous serial I/O (UART) mode #### 11.4.4 Transmit operation When the receive conditions described in section "11.4.3 Method of transmission" are satisfied, a transfer clock is generated and the following operations are automatically performed after 1 cycle of the transfer clock has passed. - •The UARTi transmit buffer register's contents are transferred to the UARTi transmit register. - •The transmit buffer empty flag is set to "1." - •The transmit register empty flag is cleared to "0." - •A UARTi transmit interrupt request occurs and the interrupt request bit is set to "1." The transmit operations are described below: - ① Data in the UARTi transmit register is transmitted from the TxDi pin. - ② This data is transmitted bit by bit sequentially in order of ST $\rightarrow$ DATA (LSB) $\rightarrow$ ••• $\rightarrow$ DATA (MSB) $\rightarrow$ PAR $\rightarrow$ SP according to the transfer data format. - ③ The transmit register empty flag is set to "1" at the center of the stop bit (or the second stop bit when selecting 2-stop bits), indicating completion of transmission. Additionally, whether the transmit conditions for the next data are satisfied or not is examined. When the transmit conditions for the next data are satisfied in step ③, the start bit is generated following the stop bit, and the next data is transmitted. When performing transmission continuously, set the next transmit data in the UARTi transmit buffer register during transmission (when the transmit register empty flag = "0"). When the transmit conditions for the next data are not satisfied, the $TxD_i$ pin outputs "H" level and the transfer clock stops. Figures 11.4.6 and 11.4.7 show examples of transmit timing when the transfer data length = 8 bits, and Figure 11.4.8 shows an example of transmit timing when the transfer data length = 9 bits. Fig. 11.4.6 Example of transmit timing when transfer data length = 8 bits (when parity enabled, selecting 1 stop bit, not selecting CTS function) Fig. 11.4.7 Example of transmit timing when transfer data length = 8 bits (when parity enabled, selecting 1 stop bit, selecting CTS function) Fig. 11.4.8 Example of transmit timing when transfer data length = 9 bits (when parity disabled, selecting 2 stop bits, not selecting CTS function) #### 11.4.5 Method of reception Figure 11.4.9 shows an initial setting example for relevant registers when receiving. Reception is started when all of the following conditions (① and ②) are satisfied: - ① Reception is enabled (receive enable bit = "1"). - 2 The start bit is detected. By connecting the RTS<sub>i</sub> pin (receiver side) and CTS<sub>i</sub> pin (transmitter side), the timing of transmission and that of reception can be matched. For details, refer to section "11.4.6 Receive operation." When using interrupts, it is necessary to set the relevant registers to enable interrupts. For details, refer to "CHAPTER 7. INTERRUPTS." Figure 11.4.10 shows processing after receive completion. Fig. 11.4.9 Initial setting example for relevant registers when receiving Fig. 11.4.10 Processing after receive completion ## 11.4 Clock asynchronous serial I/O (UART) mode #### 11.4.6 Receive operation When the receive enable bit is set to "1," the UARTi enters the receive enable state. After this, reception starts when ST is detected and a transfer clock is generated. In the case of selecting the $\overline{RTS}$ function, when the reception is enabled, the $\overline{RTS_i}$ pin's output level becomes "L" to inform the transmitter side that reception is enabled. When reception is started, the $\overline{RTS_i}$ pin's output level becomes "H." Accordingly, by connecting the $\overline{RTS_i}$ pin to the $\overline{CTS_i}$ pin of the transmitter side, the timing of transmission and that of reception can be matched. Figure 11.4.11 shows an connection example. The receive operation is described below. - ① The input signal of the RxD<sub>i</sub> pin is taken into the most significant bit of the UARTi receive register synchronously with the transfer clock's rising edge. - 2 The contents of the UARTi receive register are shifted by 1 bit to the right. - ③ Steps ① and ② are repeated at each rising edge of the transfer clock. - When one set of data has been prepared, in other words, when the shift has been performed several times according to the selected data format, the UARTi receive register's contents are transferred to the UARTi receive buffer register. - ⑤ Simultaneously with step ④, the receive complete flag is set to "1." Additionally, a UARTi receive interrupt request occurs and its interrupt request bit is set to "1." The receive complete flag is cleared to "0" when the low-order byte of the UARTi receive buffer register is read out. The RTS<sub>i</sub> pin's output level becomes "L" simultaneously with step (when selecting the RTS function). Figure 11.4.12 shows an example of receive timing when the transfer data length = 8 bits. Fig. 11.4.11 Connection example Fig. 11.4.12 Example of receive timing when transfer data length = 8 bits (when parity disabled, selecting 1 stop bit, selecting RTS function) ## 11.4 Clock asynchronous serial I/O (UART) mode #### 11.4.7 Processing on detecting error In the UART mode, 3 types of errors can be detected. Each error can be detected when the data in the UARTi receive register is transferred to the UARTi receive buffer register, and the corresponding error flag is set to "1." When any error occurs, the error sum flag is set to "1." Accordingly, presence of errors can be judged by using the error sum flag. Table 11.4.6 lists conditions for setting each error flag to "1" and method for clearing it to "0." Table 11.4.6 Conditions set to "1" and method cleared to "0" for each error flag | Table 11.4.6 Conditions set to "1" and method cleared to "0" for each error flag | | | | | |----------------------------------------------------------------------------------|----------------------------------------------|------------------------------------------------|--|--| | Error flag | Conditions for being set to "1" | Method for being cleared to "0" | | | | Overrun error flag | When the next data is prepared in the | •Clear the serial I/O mode select bits to | | | | | UARTi receive register with the receive | "0002." | | | | | complete flag = "1" (i.e., data is present | •Clear the receive enable bit to "0." | | | | | in the UARTi receive buffer register). In | | | | | | other words, when the next data is | | | | | | prepared before the contents of the UARTi | | | | | | receive buffer register are read out. (Note) | | | | | | [UARTi receive interrupt request bit is not | | | | | | changed.] | | | | | Framing error flag | When the number of detected stop bits | •Clear the serial I/O mode select bits to | | | | | does not match the set number of stop | "0002." | | | | | bits. | •Clear the receive enable bit to "0." | | | | | [UARTi receive interrupt request bit is set | •Read out the low-order byte of the UARTi | | | | | to "1."] | receive buffer register. | | | | Parity error flag | When the sum of "1"s in the parity bit | •Clear the serial I/O mode select bits to | | | | | and character bits does not match the | "0002." | | | | | set number of "1"s. | •Clear the receive enable bit to "0." | | | | | [UARTi receive interrupt request bit is set | •Read out the low-order byte of the UARTi | | | | | to "1."] | receive buffer register. | | | | Error sum flag | When 1 or more errors listed above occur. | •Clear the all error flags, which are overrun, | | | | | | framing and parity error flags. | | | Note: The next data is written into the UARTi receive buffer register. When an error occurs during reception, initialize the error flag and the UARTi receive buffer register, and then perform reception again. When it is necessary to perform retransmission owing to an error which occurs in the receiver side during transmission, set the UARTi transmit buffer register again, and then restarts transmission. The method of initializing the UARTi receive buffer register and that of setting the UARTi transmit buffer register again are described below. #### (1) Method of initializing UARTi receive buffer register - ① Clear the receive enable bit to "0" (reception disabled). - ② Set the receive enable bit to "1" again (reception enabled). #### (2) Method of setting UARTi transmit buffer register again - ① Clear the serial I/O mode select bits to "0002" (serial I/O invalid). - ② Set the serial I/O mode select bits again. - ③ Set the transmit enable bit to "1" (transmission enabled), and set the transmit data to the UARTi transmit buffer register. #### 11.4.8 Sleep mode This mode is used to transfer data between the specified microcomputers, which are connected by using UARTi. The sleep mode is selected by setting the sleep select bit (bit 7 at addresses 30<sub>16</sub>, 38<sub>16</sub>) to "1" when receiving. In the sleep mode, receive operation is performed when the MSB ( $D_8$ when the transfer data is 9 bits length, $D_7$ when it is 8 bits length, $D_6$ when it is 7 bits length) of the receive data is "1." Receive operation is not performed when the MSB is "0." (The UARTi receive register's contents are not transferred to the UARTi receive buffer register. Additionally, the receive complete flag and error flags do not change and a UARTi receive interrupt request does not occur.) The following shows an usage example of the sleep mode when the transfer data is 8 bits length. - ① Set the same transfer data format for the master and slave microcomputers. Select the sleep mode for the slave microcomputers. - ② Transmit data, which has "1" in bit 7 and the address of the slave microcomputer to be communicated in bits 0 to 6, from the master microcomputer to all slave microcomputers. - ③ All slave microcomputers receive data of step ②. (At this time, a UARTi receive interrupt request occurs.) - For all slave microcomputers, check in the interrupt routine whether bits 0 to 6 in the receive data match their own addresses. - ⑤ For the slave microcomputer of which address matches bits 0 to 6 in the receive data, terminate the sleep mode. (Do not terminate the sleep mode for the other slave microcomputers.) By performing steps ② to ⑤, "the microcomputer which performs transfer" is specified. - © Transmit data, which has "0" in bit 7, from the master microcomputer. (Only the microcomputer specified in steps ② to ⑤ can receive this data. The other microcomputers do not receive this data.) - ② By repeating step ⑥, transfer can be performed between two specific microcomputers continuously. When communicating with another microcomputer, perform steps ② to ⑤ in order to specify the new slave microcomputer. Fig. 11.4.13 Sleep mode 11.4 Clock asynchronous serial I/O (UART) mode **MEMORANDUM** # CHAPTER 12 A-D CONVERTER - 12.1 Overview - 12.2 Block description - 12.3 A-D conversion method - 12.4 Absolute accuracy and differential non-linearity error - 12.5 One-shot mode - 12.6 Repeat mode - 12.7 Single sweep mode - 12.8 Repeat sweep mode - 12.9 Precautions for A-D converter ## 12.1 Overview ## 12.1 Overview Table 12.1.1 lists the performance specifications of the A-D converter. Table 12.1.1 Performance specifications of A-D converter | Item | Performance specifications | |--------------------------------------|--------------------------------------------------------------| | A-D conversion method | Successive approximation conversion method | | Resolution | 8 bits | | Absolute accuracy | ±3 LSB | | Analog input pin | 8 pins (AN <sub>0</sub> to AN <sub>7</sub> ) ( <b>Note</b> ) | | Conversion rate per analog input pin | 57 φ <sub>AD</sub> * cycles | $\phi_{AD}^*$ : A-D converter's operation clock The A-D converter has the 4 operation modes listed below. #### One-shot mode This mode is used to perform the operation once for a voltage input from one selected analog input pin. ## •Repeat mode This mode is used to perform the operation repeatedly for a voltage input from one selected analog input pin. #### •Single sweep mode This mode is used to perform the operation for voltages input from multiple selected analog input pins, one at a time. #### •Repeat sweep mode This mode is used to perform the operation repeatedly for voltages input from multiple selected analog input pins. # 12.2 Block description Figure 12.2.1 shows the block diagram of the A-D converter. Registers relevant to the A-D converter are described below. Fig. 12.2.1 Block diagram of A-D converter ## 12.2 Block description #### 12.2.1 A-D control register Figure 12.2.2 shows the structure of the A-D control register. The A-D operation mode select bit selects the operation mode of the A-D converter. The other bits are described below. Fig. 12.2.2 Structure of A-D control register #### (1) Analog input select bits (bits 2 to 0) These bits are used to select an analog input pin in the one-shot mode and repeat mode. Pins which are not selected as analog input pins function as programmable I/O ports. These bits must be set again when the user switches the A-D operation mode to the one-shot mode or repeat mode after A-D conversion is performed in the single sweep mode or repeat sweep mode. ## 12.2 Block description #### (2) Trigger select bit (bit 5) This bit is used to select the source of trigger occurrence. (Refer to section "(3) A-D conversion start bit.") #### (3) A-D conversion start bit (bit 6) #### • When internal trigger is selected Setting this bit to "1" generates a trigger, causing the A-D converter to start operating. Clearing this bit to "0" causes the A-D converter to stop operating. In the one-shot mode or single sweep mode, this bit is cleared to "0" after the operation is completed. In the repeat mode or repeat sweep mode, the A-D converter continues operating until this bit is cleared to "0" by software. #### • When external trigger is selected When the $\overline{ADTRG}$ pin level goes from "H" to "L" with this bit = "1," a trigger occurs, causing the A-D converter to start operating. The A-D converter stops when this bit is cleared to "0." In the one-shot mode or single sweep mode, this bit remains set to "1" even after the operation is completed. In the repeat mode or repeat sweep mode, the A-D converter continues operating until this bit is cleared to "0" by software. #### (4) A-D conversion frequency ( $\phi_{AD}$ ) select bit (bit 7) As listed in Table 12.2.1, the conversion time of the A-D converter varies depending on the operating clock ( $\phi_{AD}$ ) selected by this bit. Since the A-D converter's comparator consists of capacity coupling amplifiers, keep that $\phi_{AD} \ge 250$ kHz during A-D conversion. Table 12.2.1 Conversion time per one analog input pin (unit: $\mu$ s) | A-D conversion frequency $(\phi_{AD})$ select bit | | 0 | 1 | |---------------------------------------------------|------------------------------|-------------------|-------------------| | $\phi$ ad | | f <sub>2</sub> /4 | f <sub>2</sub> /2 | | Conversion time | $f(X_{IN}) = 8 \text{ MHz}$ | 57.0 | 28.5 | | | $f(X_{IN}) = 16 \text{ MHz}$ | 28.5 | 14.25 | | | f(X <sub>IN</sub> ) = 25 MHz | 18.24 | 9.12 | ## 12.2 Block description #### 12.2.2 A-D sweep pin select register Figure 12.2.3 shows the structure of the A-D sweep pin select register. Fig. 12.2.3 Structure of A-D control register 1 #### (1) A-D sweep pin select bits (bits 1 and 0) These bits are used to select analog input pins in the single sweep mode or repeat sweep mode. In the single sweep mode and repeat sweep mode, pins which are not selected as analog input pins function as programmable I/O ports. ## 12.2 Block description #### 12.2.3 A-D register i (i = 0 to 7) Figure 12.2.4 shows the structure of the A-D register i. When the A-D conversion is completed, the conversion result (contents of the successive approximation register) is stored into this register. Each A-D register i corresponds to an analog input pin (AN<sub>i</sub>). Fig. 12.2.4 Structure of A-D register i ## 12.2 Block description ## 12.2.4 A-D conversion interrupt control register Figure 12.2.5 shows the structure of the A-D conversion interrupt control register. For details about interrupts, refer to "CHAPTER 7. INTERRUPTS." Fig. 12.2.5 Structure of A-D conversion interrupt control register #### (1) Interrupt priority level select bits (bits 2 to 0) These bits select an A-D conversion interrupt's priority level. When using A-D conversion interrupts, select one of the priority levels (1 to 7). When an A-D conversion interrupt request occurs, its priority level is compared with the processor interrupt priority level (IPL). The requested interrupt is enabled only when its priority level is higher than the IPL. (However, this applies when the interrupt disable flag (I) = "0.") To disable A-D conversion interrupts, set these bits to "0002" (level 0). #### (2) Interrupt request bit (bit 3) This bit is set to "1" when an A-D conversion interrupt request occurs. This bit is automatically cleared to "0" when the A-D conversion interrupt request is accepted. This bit can be set to "1" or cleared to "0" by software. ## 12.2 Block description #### 12.2.5 Port P7 direction register Input pins of the A-D converter are multiplexed with port P7. When using these pins as A-D converter's input pins, set the corresponding bits of the port P7 direction register to "0" to set these port pins for the input mode. Figure 12.2.6 shows the relationship between the port P7 direction register and A-D converter's input pins. Fig. 12.2.6 Relationship between port P7 direction register and A-D converter's input pins #### 12.3 A-D conversion method #### 12.3 A-D conversion method The A-D converter compares the comparison voltage ( $V_{ref}$ ), which is internally generated according to the contents of the successive approximation register, with the analog input voltage ( $V_{IN}$ ), which is input from the analog input pin (AN<sub>i</sub>). By reflecting the comparison result on the successive approximation register, $V_{IN}$ is converted into a digital value. When a trigger is generated, the A-D converter performs the following processing: #### ① Determining bit 7 of the successive approximation register The A-D converter compares $V_{ref}$ with $V_{IN}$ . At this time, the contents of the successive approximation register is "100000002" (initial value). Bit 7 of the successive approximation register changes according to the comparison result as follows: When $V_{ref} < V_{IN}$ , bit 7 = "1" When $V_{ref} > V_{IN}$ , bit 7 = "0" ## ② Determining bit 6 of the successive approximation register After setting bit 6 of the successive approximation register to "1," the A-D converter compares $V_{ref}$ with $V_{IN}$ . Bit 6 changes according to the comparison result as follows: When $V_{ref} < V_{IN}$ , bit 6 = "1" When $V_{ref} > V_{IN}$ , bit 6 = "0" ## 3 Determining bits 5 to 0 of the successive approximation register Operations in 2 are performed for bits 5 to 0. When bit 0 is determined, the contents (conversion result) of the successive approximation register is transferred to the A-D register i. The comparison voltage ( $V_{ref}$ ) is generated according to the latest contents of the successive approximation register. Table 12.3.1 lists the relationship between the successive approximation register's contents and $V_{ref}$ . Table 12.3.2 lists changes of the successive approximation register and $V_{ref}$ during the A-D conversion. Figure 12.3.1 shows the ideal A-D conversion characteristics. Table 12.3.1 Relationship between successive approximation register's contents and V<sub>ref</sub> | Successive approximation register's contents: n | V <sub>ref</sub> (V) | |-------------------------------------------------|-------------------------------------| | 0 | 0 | | 1 to 255 | $\frac{V_{REF}^*}{256}$ X (n - 0.5) | VREF\*: Reference voltage Table 12.3.2 Change in successive approximation register and V<sub>ref</sub> during A-D conversion Fig. 12.3.1 Ideal A-D conversion characteristics ## 12.4 Absolute accuracy and differential non-linearity error # 12.4 Absolute accuracy and differential non-linearity error The A-D converter's accuracy is described below. Refer to section "Appendix 12.3 A-D converter standard characteristics." also. #### 12.4.1 Absolute accuracy The absolute accuracy is the difference expressed in the LSB between the actual A-D conversion result and the output code of an A-D converter with ideal characteristics. The analog input voltage when measuring the accuracy is assumed to be the mid point of the input voltage width that outputs the same output code from an A-D converter with ideal characteristics. For example, when $V_{REF} = 5.12 \text{ V}$ , 1 LSB width is 20 mV, and 0 mV, 20 mV, 40 mV, 60 mV, 80 mV, ... are selected as the analog input voltages. The absolute accuracy = $\pm 3$ LSB indicates that when the analog input voltage is 100 mV, the output code expected from an ideal A-D conversion characteristics is "005<sub>16</sub>," however the actual A-D conversion result is between "002<sub>16</sub>" to "008<sub>16</sub>." The absolute accuracy includes the zero error and the full-scale error. The absolute accuracy is degraded when V<sub>REF</sub> is lowered. Any of the output codes for analog input voltages from V<sub>REF</sub> to AVcc is "FF<sub>16</sub>." Fig. 12.4.1 Absolute accuracy of A-D converter ## 12.4.2 Differential non-linearity error The differential non-linearity error indicates the difference between the 1 LSB step width (the ideal analog input voltage width while the same output code is expected to output) of an A-D converter with ideal characteristics and the actual measured step width (the actual analog input voltage width while the same output code is output). For example, when $V_{REF} = 5.12 \text{ V}$ , the 1 LSB width of an A-D converter with ideal characteristics is 20 mV, however when the differential non-linearity error is $\pm 1$ LSB, the actual measured 1 LSB width is 0 to 40 mV. Fig. 12.4.2 Differential non-linearity error ## 12.5 One-shot mode ## 12.5 One-shot mode In the one-shot mode, the operation for the input voltage from the one selected analog input pin is performed once, and the A-D conversion interrupt request occurs when the operation is completed. #### 12.5.1 Settings for one-shot mode Figure 12.5.1 shows an initial setting example for registers relevant to the one-shot mode. When using an interrupt, it is necessary to set the relevant registers to enable the interrupt. Refer to "CHAPTER 7. INTERRUPTS" for more descriptions. 12.5 One-shot mode Fig. 12.5.1 Initial setting example for registers relevant to one-shot mode #### 12.5 One-shot mode #### 12.5.2 One-shot mode operation description #### (1) When an internal trigger is selected - ① The A-D converter starts operation when the A-D conversion start bit is set to "1." - ② The A-D conversion is completed after 57 cycles of $\phi_{AD}$ . Then, the contents of the successive approximation register (conversion result) are transferred to the A-D register i. - 3 At the same time as step 2, the A-D conversion interrupt request bit is set to "1." - The A-D conversion start bit is cleared to "0" and the A-D converter stops operation. #### (2) When an external trigger is selected - ① The A-D converter starts operation when the input level to the AD™g pin changes from "H" to "L" while the A-D conversion start bit is "1." - ② The A-D conversion is completed after 57 cycles of $\phi_{AD}$ . Then, the contents of the successive approximation register (conversion result) are transferred to the A-D register i. - 3 At the same time as step 2, the A-D conversion interrupt request bit is set to "1." - The A-D conversion stops. The A-D conversion start bit remains set to "1" after the operation is completed. Accordingly, the operation of the A-D converter can be performed again from step 1 when the level of the $\overrightarrow{AD}_{TRG}$ pin changes from "H" to "L." When the level of the $AD_{TRG}$ pin changes from "H" to "L" during operation, the operation at that point is cancelled and is restarted from step $\oplus$ . Figure 12.5.2 shows the conversion operation in the one-shot mode. Fig. 12.5.2 Conversion operation in one-shot mode 12.6 Repeat mode # 12.6 Repeat mode In the repeat mode, the operation for the input voltage from the one selected analog input pin is performed repeatedly. In this mode, no A-D conversion interrupt request occurs. Additionally, the A-D conversion start bit (bit 6 at address $1E_{16}$ ) remains set to "1" until it is cleared to "0" by software, and the operation is performed repeatedly while the A-D conversion start bit is "1." ## 12.6.1 Settings for repeat mode Figure 12.6.1 shows an initial setting example for registers relevant to the repeat mode. ## 12.6 Repeat mode Fig. 12.6.1 Initial setting example for registers relevant to repeat mode #### 12.6.2 Repeat mode operation description #### (1) When an internal trigger is selected - ① The A-D converter starts operation when the A-D conversion start bit is set to "1." - ② The first A-D conversion is completed after 57 cycles of $\phi_{AD}$ . Then, the contents of the successive approximation register (conversion result) are transferred to the A-D register i. - ③ The A-D converter repeats operation until the A-D conversion start bit is cleared to "0" by software. The conversion result is transferred to the A-D register i each time the conversion is completed. #### (2) When an external trigger is selected - ① The A-D converter starts operation when the input level to the AD™ pin changes from "H" to "L" while the A-D conversion start bit is "1." - ② The first A-D conversion is completed after 57 cycles of $\phi_{AD}$ . Then, the contents of the successive approximation register (conversion result) are transferred to the A-D register i. - ③ The A-D converter repeats operation until the A-D conversion start bit is cleared to "0" by software. The conversion result is transferred to the A-D register i each time the conversion is completed. When the level of the $AD_{TRG}$ pin changes from "H" to "L" during operation, the operation at that point is cancelled and is restarted from step $\oplus$ . Figure 12.6.2 shows the conversion operation in the repeat mode. Fig. 12.6.2 Conversion operation in repeat mode # 12.7 Single sweep mode # 12.7 Single sweep mode In the single sweep mode, the operation for the input voltage from multiple selected analog input pins is performed, one at a time. The A-D converter is operated in ascending sequence from the $AN_0$ pin. The A-D conversion interrupt request occurs when the operation for all selected input pins are completed. #### 12.7.1 Settings for single sweep mode Figure 12.7.1 shows an initial setting example for registers relevant to the single sweep mode. When using an interrupt, it is necessary to set the relevant registers to enable the interrupt. Refer to "CHAPTER 7. INTERRUPTS" for more information. ## 12.7 Single sweep mode Fig. 12.7.1 Initial setting example for registers relevant to single sweep mode ## 12.7 Single sweep mode #### 12.7.2 Single sweep mode operation description #### (1) When an internal trigger is selected - ① The operation for the input voltage from the AN₀ pin starts when the A-D conversion start bit is set to "1." - ② The A-D conversion of the input voltage from the ANo pin is completed after 57 cycles of $\phi_{AD}$ . Then, the contents of the successive approximation register (conversion result) are transferred to the A-D register 0. - ③ For all of the selected analog input pins, the A-D conversion is performed. The conversion result is transferred to the A-D register i each time each pin is converted. - 4 When step 3 is completed, the A-D conversion interrupt request bit is set to "1." - ⑤ The A-D conversion start bit is cleared to "0" and the A-D converter stops operation. #### (2) When an external trigger is selected - ① The A-D converter starts operation for the input voltage from the AN₀ pin when the input level to the AD<sub>TRG</sub> pin changes from "H" to "L" while the A-D conversion start bit is "1." - ② The A-D conversion of the input voltage from the ANo pin is completed after 57 cycles of $\phi_{AD}$ . Then, the contents of the successive approximation register (conversion result) are transferred to the A-D register 0. - ③ For all of the selected analog input pins, the A-D conversion is performed. The conversion result is transferred to the A-D register i each time each pin is converted. - 4 When step 3 is completed, the A-D conversion interrupt request bit is set to "1." - ⑤ The A-D conversion stops. The A-D conversion start bit remains set to "1" after the operation is completed. Accordingly, the operation of the A-D converter can be performed again from step 1 when the level of the $\overrightarrow{AD}_{TRG}$ pin changes from "H" to "L." When the level of the AD<sub>TRG</sub> pin changes from "H" to "L" during operation, the operation at that point is cancelled and is restarted from step ①. Figure 12.7.2 shows the conversion operation in the single sweep mode. # 12.7 Single sweep mode Fig. 12.7.2 Conversion operation in single sweep mode ## 12.8 Repeat sweep mode ## 12.8 Repeat sweep mode In the repeat sweep mode, the operation for the input voltages from the multiple selected analog input pins is performed repeatedly. The A-D converter is operated in ascending sequence from the $AN_0$ pin. In this mode, no A-D conversion interrupt request occurs. Additionally, the A-D conversion start bit (bit 6 at address $1E_{16}$ ) remains set to "1" until it is cleared to "0" by software, and the operation is performed repeatedly while the A-D conversion start bit is "1." ## 12.8.1 Settings for repeat sweep mode Figure 12.8.1 shows an initial setting example for registers relevant to the repeat sweep mode. ## 12.8 Repeat sweep mode Fig. 12.8.1 Initial setting example for registers relevant to repeat sweep mode ## 12.8 Repeat sweep mode #### 12.8.2 Repeat sweep mode operation description ## (1) When an internal trigger is selected - ① The operation for the input voltage from the ANo pin starts when the A-D conversion start bit is set to "1." - ② The A-D conversion of the input voltage from the AN<sub>0</sub> pin is completed after 57 cycles of $\phi_{AD}$ . Then, the contents of the successive approximation register (conversion result) are transferred to the A-D register 0. - ③ For all of the selected analog input pins, the A-D conversion is performed. The conversion result is transferred to the A-D register i each time each pin is converted. - 4 For all of the selected analog input pins, the A-D conversion is performed again. - ⑤ The operation is performed repeatedly until the A-D conversion start bit is cleared to "0" by software. #### (2) When an external trigger is selected - ① The A-D converter starts operation for the input voltage from the AN₀ pin when the input level to the AD™RG pin changes from "H" to "L" while the A-D conversion start bit is "1." - ② The A-D conversion of the input voltage from the ANo pin is completed after 57 cycles of $\phi_{AD}$ . Then, the contents of the successive approximation register (conversion result) are transferred to the A-D register 0. - ③ For all of the selected analog input pins, the A-D conversion is performed. The conversion result is transferred to the A-D register i each time each pin is converted. - To all of the selected analog input pins, the A-D conversion is performed again. - ⑤ The operation is performed repeatedly until the A-D conversion start bit is cleared to "0" by software. When the level of the $\overline{AD_{TRG}}$ pin changes from "H" to "L" during operation, the operation at that point is cancelled and is restarted from step ①. Figure 12.8.2 shows the conversion operation in the repeat sweep mode. ## 12.8 Repeat sweep mode Fig. 12.8.2 Conversion operation in repeat sweep mode #### 12.9 Precautions for A-D converter #### 12.9 Precautions for A-D converter - 1. Writing to the following must be performed before a trigger occurs (while the A-D converter halts). - •Each bit (except bit 6) of the A-D control register - •Each bit of the A-D sweep pin select register - 2. When an external trigger is selected, the $AN_7/\overline{AD_{TRG}}$ pin is disconnected from the comparator. Therefore, this pin cannot be used as an analog input pin. - When the $AN_7$ pin is selected as an analog input pin while an external trigger is selected, the A-D converter operates, however, an undefined value is stored into the A-D register 7. - 3. Refer to "Appendix. 8 Countermeasure against noise" when using the A-D converter. # CHAPTER 13 # DMA CONTROLLER 13.1 Overview 13.2 Block description [Precautions for DMAC] 13.3 Control 13.4 Operation [Precautions for 2-bus cycle transfer] [Precautions for 1-bus cycle transfer] [Precautions for burst transfer mode] [Precautions for cycle-steal transfer mode] 13.5 Single transfer mode 13.6 Repeat transfer mode 13.7 Array chain transfer mode [Precautions for array chain transfer mode] 13.8 Link array chain transfer mode [Precautions for link array chain transfer mode] 13.9 DMA transfer time ## 13.1 Overview ## 13.1 Overview The DMA controller (hereafter called DMAC) transfers data using the bus and bypassing the CPU. DMAC of the M37721 provides four independent channels of DMA0–DMA3, which have the same function each. In this chapter, the source and destination of each DMA transfer are represented as follows. Memory A device which needs its own address to be specified Examples: Internal RAM and SFRs, external memory, and memory-mapped I/Os I/O A device which does not need its own address to be specified Example: External I/O devices #### 13.1.1 Performance overview Table 13.1.1 lists the performance overview. Table 13.1.1 DMAC performance overview | Tubic Tollil BillAo | performance overview | | |----------------------|--------------------------------------------------------------------------------------|--| | Item | Performance specifications | | | Number of channels | 4 channels | | | Transfer space | 16 Mbytes (between arbitrary spaces) | | | Number of transfer | Maximum of 16 Mbytes | | | bytes | | | | DMA request source | Internal 14 sources and External 1 source | | | Channel priority | Fixed or Rotating | | | Transfer rate | Maximum of 12.5 Mbytes/sec (at f(X <sub>IN</sub> ) = 25 MHz, 1-bus cycle transfer) | | | | Maximum of 6.25 Mbytes/sec (at f(X <sub>IN</sub> ) = 25 MHz, 2-bus cycle transfer) | | | Data transfer | 1-bus cycle or 2-bus cycle transfer | | | method | | | | Transfer unit | 8 or 16 bits | | | Address direction of | Fixed, Forward, or Backward | | | transfer | (Directions of source and destination are independently selectable.) | | | Transfer mode | Burst transfer or Cycle-steal transfer mode | | | Continuous transfer | Single transfer, Repeat transfer, Array chain transfer, or Link array chain transfer | | | mode | mode | | #### 13.1.2 Bus use priority levels The bus use priority levels are fixed by hardware as follows: DRAMC > Hold function > DMAC > CPU (DRAM refresh) Because DMAC has the third priority, it actually operates as follows: #### • When DRAM refresh request or Hold request is generated during DMA transfer After the transfer of one transfer unit (8-bit or 16-bit data), which is being performed at that time, is complete, DMAC relinquishes the bus to a DRAM refresh or a Hold function. When DMAC regains the right to use bus after the DRAM refresh ends or the Hold state is removed, DMA transfer is restarted at the following address. #### • When DMA request is generated during DRAM refresh or in Hold state DMAC gains the right to use bus after the DRAM refresh ends or the Hold state is removed. #### • When DMA request is generated while CPU uses bus Upon end of the bus cycle, DMAC gains the right to use bus if any DRAM refresh request or Hold request is not generated at that time. If a DRAM refresh request or a Hold request is generated when the bus cycle ends, DMAC gains the right to use bus after the DRAM refresh ends or the Hold state is removed. For details, refer to section "13.2.1 Bus access control circuit" and bus request sampling signals in timing diagrams. #### 13.1.3 Modes DMAC has the following transfer methods and modes. Because these methods and modes are independent each other, any combination between them is selectable. #### (1) Data transfer method #### ■ 2-bus cycle transfer This is a method used to transfer data between memories. A DMA transfer consumes 2 cycles: a read and a write cycle of data. For details, refer to section "13.4.1 2-bus cycle transfer." ## ■ 1-bus cycle transfer This is a method used to transfer data between a memory and an I/O. A read and write of data is carried out at the same time (in 1-bus cycle), so that high-speed transfer can be accomplished. For details, refer to section "13.4.2 1-bus cycle transfer." #### (2) Transfer unit #### ■ 8-bit transfer A minimum unit of DMA transfer is 8 bits; that is, an 8-bit data is transferred for one DMA request in the cycle-steal transfer mode. In the burst transfer mode, if a DRAM refresh request or a Hold request is generated during DMA transfer, or if $\overline{TC}$ input is driven from "H" to "L" to force DMA transfer into termination, DMAC relinquishes the bus after completion of 8-bit data transfer which is being performed at that time. #### ■ 16-bit transfer A minimum unit of DMA transfer is 16 bits; that is, a 16-bit data is transferred for one DMA request in the cycle-steal transfer mode. In the burst transfer mode, if a DRAM refresh request or a Hold request is generated during DMA transfer, or if $\overline{\text{TC}}$ input is driven from "H" to "L" to force DMA transfer into termination, DMAC relinquishes the bus after completion of 16-bit data transfer which is being performed at that time. #### 13.1 Overview #### (3) Transfer modes #### **■** Burst transfer mode When once a DMA request is accepted in this mode, an entire batch of data is transferred. Neither is the right to use bus returned to the CPU, nor the DMA request of the channel with the higher priority is accepted until the transfer is complete. However, if an external source (DMAREQi) is selected as a DMA request source with the level sense selected, DMA transfer is performed when the DMAREQi pin's input level is "L," and the right to use bus is returned to the CPU when the DMAREQi pin's input level is "H." Even in this case, any DMA request of the other channels is not accepted until the entire batch of data has been transferred. For details, refer to section "13.4.3 Burst transfer mode." #### **■** Cycle-steal transfer mode For each DMA request, 1 transfer unit of data is transferred. (Hereafter, transferring 1-transfer-unit data, which is 8-bit or 16-bit data in the M37721, is called "1-unit transfer.") When 1-unit transfer is complete and another DMA request (including that of other channels) is not generated, the DMAC relinquishes the right to use bus to the CPU. In the cycle-steal transfer mode, all of the DMA request sources are available. For details, refer to section "13.4.4 Cycle-steal transfer mode." Figure 13.1.1 shows the outline of the DMA transfer modes. Fig. 13.1.1 Outline of DMA transfer modes 13.1 Overview #### (4) Continuous transfer mode #### ■ Single transfer mode 1 block of data is transferred once. For details, refer to section "13.5 Single transfer mode." #### ■ Repeat transfer mode 1 block of data is transferred repeatedly. For details, refer to section "13.6 Repeat transfer mode." #### ■ Array chain transfer mode Several blocks of data are transferred. The transfer parameters (transfer source and destination addresses, the number of transfer bytes) of each block must be located on the memory in series. For details, refer to section "13.7 Array chain transfer mode." #### ■ Link array chain transfer mode Several blocks of data are transferred. Transfer parameters for each block can be located on the memory <u>in separate</u>, <u>in a unit of 1-block's parameters</u>. For details, refer to section "13.8 Link array chain transfer mode." ## 13.2 Block description ## 13.2 Block description Figures 13.2.1 and 13.2.2 show the DMAC block diagrams, and relevant registers are described below. Fig. 13.2.1 DMAC block diagram (1) Fig. 13.2.2 DMAC block diagram (2) ## 13.2 Block description #### 13.2.1 Bus access control circuit In the M37721, the bus is used by DRAMC, Hold function, DMAC, and CPU. When each request of DRAM refresh, Hold, and DMA is generated, each of DRAMC, Hold function, and DMAC issues its bus request to the bus access control circuit in DMAC. (Refer to "Figure 13.2.2.") Table 13.2.1 lists the bus request generating sources. Table 13.2.1 Bus request generating sources | Bus request | Bus request generating source | | |-------------|---------------------------------------------------|--| | BUS REQUEST | DRAM refresh request | | | (DRAMC) | (Generated by an underflow of the refresh timer.) | | | BUS REQUEST | Hold request | | | (Hold) | (Generated by "L"-level input to the HOLD pin.) | | | BUS REQUEST | DMA request | | | (DMAC) | (Generated by a DMA request source.) | | The bus access control circuit relinquishes the right to use bus to the function with the highest priority among functions, which issue bus requests when the BUS REQUEST signal is sampled. This is the bus request acceptance. If any bus request is not generated at bus request sampling, the CPU gains the right to use bus. The bus use priority levels are fixed by hardware, and the bus status is reported by status signal outputs ST0 and ST1. Table 13.2.2 lists the relationship between the bus use priority level, bus status, and status signals. Table 13.2.2 Relationship between bus use priority level, bus status, and status signals | Bus use | Bus status | | Status signals | | |----------------------------------------------------------------------------------------------------------------------------------------------------|--------------|-----|----------------|--| | priority level | | ST1 | ST0 | | | 1 (Highest) | DRAM refresh | 0 | 0 | | | 2 | Hold | 0 | 1 | | | 3 | DMAC | 1 | 0 | | | 4 (Lowest) CPU (Including the term while the CPU does not use the bus; for example, the term when the CPU is calculating and does not use the bus) | | | 1 | | ## 13.2 Block description The BUS REQUEST signal is sampled at a break in bus use. Table 13.2.3 and Figure 13.2.3 shows the timings of bus request sampling. Also, bus request sampling signals are shown in them. Table 13.2.3 Bus request sampling timing | Bus user | | Bus request sampling timing | | |------------------------------|----------|------------------------------------------|-------------------------------------------------------------| | DRAM re | efresh | After completion of a DRAM refresh cycle | | | Hold Every 1 cycle of $\phi$ | | Every 1 cycle of $\phi$ | | | DMAC | S/R | All except the following | After completion of 1-unit transfer | | | (Note 1) | At the end of each block | After 1-unit transfer and terminate-processing (3 cycles | | | | | of $\phi$ ) etc. are performed sequentially | | | Array/ | All except the following | After completion of 1-unit transfer | | | Link | At the end of each block | ■ During transfer in burst transfer mode | | | (Note 1) | (except the last block) | After the last 1-unit transfer of 1 block, the subsequent | | | | | 3 cycles of $\phi$ , and a read of the first 2 bytes in the | | | | | array state of the next block are performed sequentially | | | | | ■ During transfer in cycle-steal transfer mode | | | | | After the last 1-unit transfer of 1 block and the | | | | | subsequent 3 cycles of $\phi$ are performed sequentially | | | | At the end of the last block | After 1-unit transfer and terminate-processing (3 cycles | | | | | of $\phi$ ) are performed sequentially | | | | At an array state | After a read of 2 bytes of a transfer parameter | | CPU | | When an instruction is | After completion of 1 bus cycle | | | | fetched into queue buffer | | | | | At a read from or a write into | After completion of 1 bus cycle, or after completion of | | | | memory | the second bus cycle if a 16-bit data is accessed in a | | | | | unit of 8 bits (Note 2). | | | | While CPU does not use bus | Every 1 cycle of $\phi$ | **Notes 1**: S = Single transfer mode, R = Repeat transfer mode, Array = Array chain transfer mode, Link = Link array chain transfer mode 2: This applies when the data bus width is 8 bits or when memory is accessed starting at an odd address. If a DRAM refresh request or a Hold request is generated during a data transfer in the burst transfer mode, the request is accepted at the above-mentioned bus request sampling. Another DMA request (including that of other channels) cannot be accepted until the DMA transfer which is in progress normally terminates or is forced into termination. If a DRAM refresh request, a Hold request or another DMA request (including that of other channels) is generated during a data transfer in the cycle-steal transfer mode, the bus request with the highest priority is accepted at the above-mentioned bus request sampling. (If only several DMA requests are generated, the request of the channel whose priority is highest is accepted.) If any bus request is not generated at the above-mentioned bus sampling, the right to use bus is relinquished to the CPU. Note that no DMA request is accepted in array states. ## 13.2 Block description Fig. 13.2.3 Timing of bus request sampling #### 13.2 Block description #### 13.2.2 DMAC control register L Figure 13.2.4 shows the structure of DMAC control register L. Bit 0 is described in section "13.3.3 Channel priority levels," and bits 4–7 are also in section "13.3.2 DMA requests." #### (1) TC pin validity bit (Bit 1) When this bit is set to "1," port P10<sub>3</sub> functions as the $\overline{TC}$ pin. The $\overline{TC}$ pin is of an N-channel opendrain type and provides the following functions: #### Terminal count signal output When the transfer of an entire batch of data is normally terminated, the pin outputs "L" for 1 cycle of $\phi$ . (Refer to section "13.3.5 (1) Normal termination.") #### • Forced termination signal input When the $\overline{TC}$ pin's input level goes from "H" to "L" during DMA transfer, this DMA transfer is forced into termination. (Refer to section "13.3.5 (2) Forced termination.") Fig. 13.2.4 Structure of DMAC control register L 13.2 Block description #### 13.2.3 DMAC control register H Figure 13.2.5 shows the structure of DMAC control register H. Each of bits 0–3 is a software DMAi (i = 0 to 3) request bit, which corresponds to each channel. When a software DMA source is selected as a DMA request source, each of these bits is valid. (Refer to "13.3.2 DMA requests.") Bits 4–7 are described in section "13.3.1 DMA enabling." Fig. 13.2.5 Structure of DMAC control register H #### 13.2 Block description #### 13.2.4 Source address register i (SARi) Source address register i (hereafter called SARi) is a 24-bit register with a latch. SARi indicates the transfer source address of the data to be transferred next. The SARi latch has the following functions: - Maintains the value written to the address of SARi (in the single transfer and repeat transfer modes). - Indicates the start address of the transfer parameter memory of the next block (in the array chain transfer and link array chain transfer modes). When a value is written into the address of SARi, the same value is written into SARi and the SARi latch. When writing a value to the address of SARi, all 24 bits must be written. The contents of SARi can be read by reading the address of SARi; however, the value of the SARi latch cannot be read. (Refer to "Tables 13.2.4 and 13.2.5.") #### 13.2.5 Destination address register i (DARi) Destination address register i (hereafter called DARi) is a 24-bit register with a latch. DARi indicates the transfer destination address of the data to be transferred next. The DARi latch maintains the value written to the address of DARi. When a value is written into the address of DARi, the same value is written into DARi and the DARi latch. When writing a value to the address of DARi, all 24 bits must be written. The contents of DARi can be read by reading the address of DARi; however, the value of the DARi latch cannot be read. (Refer to "Tables 13.2.4 and 13.2.5.") #### 13.2.6 Transfer counter register i (TCRi) Transfer counter register i (hereafter called TCRi) is a 24-bit register with a latch. TCRi indicates the number of remaining bytes of the block under transfer. The TCRi latch has the following functions: - Maintains the value written to the address of TCRi (in the single transfer and repeat transfer modes). - Indicates the number of remaining blocks (in the array chain transfer mode). When a value is written into the address of TCRi, the same value is written into TCRi and the TCRi latch. When writing a value to the address of TCRi, all 24 bits must be written. The contents of TCRi can be read by reading the address of TCRi; however, the value of the TCRi latch cannot be read. (Refer to "Tables 13.2.4 and 13.2.5.") Table 13.2.4 Addresses of SARi, DARi, and TCRi | Channel | Source address register i | Destination address | Transfer counter register i | |---------|----------------------------------------|----------------------------------------|----------------------------------------| | Chamer | (SARi) | register i (DARi) | (TCRi) | | 0 | 1FC2 <sub>16</sub> —1FC0 <sub>16</sub> | 1FC6 <sub>16</sub> —1FC4 <sub>16</sub> | 1FCA <sub>16</sub> –1FC8 <sub>16</sub> | | 1 | 1FD2 <sub>16</sub> —1FD0 <sub>16</sub> | 1FD6 <sub>16</sub> —1FD4 <sub>16</sub> | 1FDA <sub>16</sub> —1FD8 <sub>16</sub> | | 2 | 1FE2 <sub>16</sub> —1FE0 <sub>16</sub> | 1FE6 <sub>16</sub> —1FE4 <sub>16</sub> | 1FEA <sub>16</sub> —1FE8 <sub>16</sub> | | 3 | 1FF2 <sub>16</sub> —1FF0 <sub>16</sub> | 1FF6 <sub>16</sub> —1FF4 <sub>16</sub> | 1FFA <sub>16</sub> —1FF8 <sub>16</sub> | 13.2 Block description Table 13.2.5 Functions of SARi, DARi, and TCRi | Register | Mode | Single transfer mode | Repeat transfer mode | Array chain transfer mode | Link array chain<br>transfer mode | | | | | |----------|------------|------------------------------------|-------------------------------------------------------------------------|-------------------------------------------|-----------------------------------|--|--|--|--| | SARi | SARi | Indicates the transfe | dicates the transfer source address of the data to be transferred next. | | | | | | | | | SARi latch | Maintains the transfe source. | r start address of the | Indicates the start add | | | | | | | DARi | DARi | Indicates the transfe | r destination address | of the data next to be | e transferred | | | | | | | DARi latch | Maintains the transfe destination. | r start address of the | (Not used) | (Not used) | | | | | | TCRi | TCRi | Indicates the number | r of remaining bytes o | of the block under tran | nsfer. | | | | | | | TCRi latch | Maintains the byte n data. | umber of the transfer | Indicates the number of remaining blocks. | (Not used) (Note) | | | | | Note: Any value other than 0 (000001<sub>16</sub>-FFFFFF<sub>16</sub>) must be written before DAM transfer. #### 13.2.7 Incrementer/Decrementer The incrementer/decrementer is a 24-bit register. After every 1-unit transfer, that increments (adds) or decrements (subtract) the contents of SARi and DARi. Table 13.2.6 lists the increment/decrement values. Table 13.2.6 Increment/Decrement values | Transfer unit | Address directions | | | | | |---------------|--------------------|----------|--|--|--| | | Forward | Backward | | | | | 8 bits | + 1 | - 1 | | | | | 16 bits | 16 bits + 2 | | | | | #### 13.2.8 Decrementer The decrementer is a 24-bit register. After every 1-unit transfer, that decrements the contents of TCRi by 1 when the transfer unit is 8 bits, and by 2 when 16 bits. In the array chain transfer mode, every time a transfer parameter is read, the contents of the TCRi latch are also decremented by 1. #### 13.2.9 DMA latch The DMA latch is a 16-bit latch. In 2-bus cycle transfer mode, the DMA latch maintains the value read from the transfer source memory with a read cycle until this value is written into the transfer destination memory. In 1-bus cycle transfer mode, the DMA latch is used to copy data. For copy, refer to section "13.4.2 1-bus cycle transfer." #### 13.2 Block description #### 13.2.10 DMAi mode register L Figure 13.2.6 shows the structure of DMAi mode register L. For bit 0, refer to section "13.1.3 (2) Transfer unit." For bit 1, refer to section "13.4.1 2-bus cycle transfer" and section "13.4.2 1-bus cycle transfer"; for bit 2, refer to section "13.4.3 Burst transfer mode" and section "13.4.4 Cycle-steal transfer mode." # (1) Transfer source address direction select bits (bits 4 and 5) and Transfer destination address direction select bits (bits 6 and 7) Address direction means an order of accessing memory in DMA transfer and is defined as follows: - Fixed direction: an address does not move. - Forward direction: an address moves upward from the specified start address. - Backward direction: an address moves downward from the specified start address. For details, refer to section "13.4.1 (3) Address directions in 2-bus cycle transfer" and section "13.4.2 (3) Address directions in 1-bus cycle transfer." Fig. 13.2.6 Structure of DMAi mode register L #### 13.2.11 DMAi mode register H Figure 13.2.7 shows the structure of DMAi mode register H. Bits 0 and 1 are used in 1-bus cycle transfer. For details, refer to section "13.4.2 1-bus cycle transfer." Bits 6 and 7 are the bits for selecting the continuous transfer mode. For details, refer to section "13.5 Single transfer mode" through section "13.8 Link array chain transfer mode." #### (1) Transfer source wait bit and Transfer destination wait bit (bits 4 and 5) When each of these bits is set to "1," 1-bus cycle in a DMA transfer consumes 3 cycles of $\phi$ , and when cleared to "0," 2 cycles of $\phi$ . These bits are valid for the internal and external areas. In the DRAM area, however, 1-bus cycle consumes 3 cycles of $\phi$ regardless of the states of these bits. (Refer to "CHAPTER 14. DRAM CONTROLLER.") The wait bit (bit 2 at address 5E<sub>16</sub>) is invalid in DMA transfer. However, Ready function is still valid in DMA transfer. Notes 1: Set bit 0 to "0" in 2-bus cycle transfer. #### Setting for I/O connection select bit | Transfer method | External data bus width | I/O connection | Setting for I/O connection select bit | |----------------------|-------------------------|----------------------------------------------------------------------|---------------------------------------| | 2-bus cycle transfer | | | It may be either "0" or "1." | | 1-bus cycle transfer | 8 bits | D <sub>0</sub> –D <sub>7</sub> | 0 | | | 16 bits | D <sub>0</sub> –D <sub>15</sub><br>(16-bit I/O × 1 or 8-bit I/O × 2) | 0 | | | | D <sub>0</sub> –D <sub>7</sub><br>(8-bit I/O) | 0 | | | | D <sub>8</sub> -D <sub>15</sub><br>(8-bit I/O) | 1 | Fig. 13.2.7 Structure of DMAi mode register H <sup>2:</sup> Bits 4 and 5 are valid to the external and internal areas. However, DRAM area is always handled with "Wait" regardless of the contents of these bits. The wait bit (bit 2 at address 5E<sub>16</sub>) is invalid in DMA transfer. #### 13.2 Block description #### 13.2.12 DMAi control register Figure 13.2.8 shows the structure of the DMAi control register. For bits 0–4, refer to section "13.3.2 (1) DMA request sources." #### (1) DMAACKi validity bit (bit 5) When this bit is set to "1," the corresponding pin of port P9 serves as the DMAACKI pin and outputs "L" during a DMA transfer. For details, refer to each timing diagram of section "13.5 Single transfer mode" through section "13.8 Link array chain transfer mode." Fig. 13.2.8 Structure of DMAi control register 13.2 Block description #### 13.2.13 DMAi interrupt control register Figure 13.2.9 shows the structure of the DMAi interrupt control register. For details about interrupts, refer to "CHAPTER 7. INTERRUPTS." Fig. 13.2.9 Structure of DMAi interrupt control register #### (1) Interrupt priority level select bits (bits 2 to 0) These bits select a DMAi interrupt's priority level. When using DMAi interrupts, select one of the priority levels (1 to 7). When a DMAi interrupt request occurs, its priority level is compared with the processor interrupt priority level (IPL). The requested interrupt is enabled only when its priority level is higher than the IPL. (However, this applies when the interrupt disable flag (I) = "0.") To disable DMAi interrupts, set these bits to " $000_2$ " (level 0). #### (2) Interrupt request bit (bit 3) This bit is set to "1" when a DMAi interrupt request occurs after the DMA transfer is complete. This bit is automatically cleared to "0" when the DMAi interrupt request is accepted. This bit can be set to "1" or cleared to "0" by software. #### 13.2 Block description #### 13.2.14 Port P9 direction register I/O pins of DMAi are multiplexed with port P9. When using these pins as the DMAREQi input pins, set the corresponding bits of the port P9 direction register to "0" to set these port pins for the input mode. When using these pins as the DMAACKi output pins, these pins are forcibly set to the DMAACKi output pins regardless of the direction register's contents. Figure 13.2.10 shows the relationship between the port P9 direction register and DMAi's I/O pins. Fig. 13.2.10 Relationship between port P9 direction register and DMAi's I/O pins #### [Precautions for DMAC] Do not access the registers relevant to DMAC by using DMA transfers; the address of the accessing register collides with that of the accessed one on the DMAC internal bus. 13.3 Control #### 13.3 Control The conditions for performing DMA transfer of DMAi (i = 0-3) are as follows: - Neither a DRAM refresh request nor a Hold request is generated. - A request of the channel with a higher priority than that of DMAi is not generated; or the request is disabled though it has been generated. - DMAi is enabled (DMAi enable bit = "1"). - A DMAi request is generated (DMAi request bit = "1"). The control method for each channel is described below. #### 13.3.1 DMA enabling Each of DMA channels 0–3 has a DMAi enable bit (bits 4–7 at address 69<sub>16</sub>). Table 13.3.1 lists the conditions for changing each DMAi enable bit. Table 13.3.1 Conditions for changing DMAi enable bit | DMAi enable bit | Conditions for bit change | | | | | | |---------------------------------------------|-----------------------------------------------------------------------------------|--|--|--|--|--| | Is set to "1." | A write of "1" to the DMAi enable bit | | | | | | | Is cleared to "0." | A write of "0" to the DMAi enable bit | | | | | | | | Transfer of an entire batch of data is complete (normal termination). | | | | | | | | • A change of TC input level from "H" to "L" during a DMA transfer of DMAi (Note) | | | | | | | (Forced termination, when TC pin is valid.) | | | | | | | **Note:** In the burst transfer mode (level sense), however, the term from the DMA transfer start until the transfer completion of an entire batch of data is applied. (It is also valid while the CPU has the right to use bus.) #### 13.3 Control #### 13.3.2 DMA requests #### (1) DMA request sources DMA request sources are specified by the DMA request source select bits and the edge sense/level sense select bit. (Refer to "Figure 13.2.8.") Table 13.3.2 lists the conditions for generating a DMA request. Table 13.3.2 Conditions for generating DMA request | DMA request sources | | Condition for generating DMA request | | | | | |--------------------------------------------------------------------|-------------|-------------------------------------------------------------------------------------------------|--|--|--|--| | External source | Level sense | "L"-level input to the DMAREQi pin (only in the burst transfer mode) | | | | | | Edge sense Change of the DMAREQi input pin's level from "H" to "L" | | | | | | | | Software DMAi request | | A write of "1" to the software DMAi request bit (each of bits 0-3 at address 69 <sub>16</sub> ; | | | | | | | | refer to "Figure 13.2.5.") | | | | | | Timers A0-A | 4, | When the interrupt request bit of each peripheral is set to "1" by the activity of | | | | | | Timers B0-B | 2, | peripherals (If "1" is written to any of these interrupt request bits by software, | | | | | | UARTO, UART1, | | the DMAi request bit does not change. Also, whatever value within 0-7 an | | | | | | A-D converte | r | interrupt priority level takes, this does not affect DMA requests.) | | | | | #### (2) Change of DMAi request bit A read of the DMAi request bits (each of bits 4–7 at address $68_{16}$ ) indicates whether the corresponding channel (0–3) is generating its DMA request or not. The DMAi request bit changes synchronized with the falling edge of $\phi_1$ . Table 13.3.3 lists the conditions for changing the DMAi request bit. For the timing of changing the DMAi request bit, refer to "**Figures 13.3.2 and 13.3.3**." Table 13.3.3 Conditions for changing DMAi request bit | DMAi Mode request bit | Burst tran<br>Edge sense | sfer mode<br>Level sense | Cycle-steal transfer mode | |-----------------------|--------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------| | Is set to "1." (Note) | Generation of DMAi request (Refer to "Table 13.3.2.") | Generation of DMAi request ("L"-level input to the DMAREQi pin) | Generation of DMAi request (Refer to "Table 13.3.2.") | | Is cleared to "0." | Normal termination Change of the TC pin's input level from "H "to "L" during DMA transfer (when the TC pin is valid) | <ul> <li>"H"-level input to the DMAREQi pin</li> <li>Change of the TC pin's input level from "H" to "L" (when the TC pin is valid)</li> <li>A write of "0" to the DMAi request bit</li> </ul> | Change of the TC pin's input level from "H" to "L" during | **Note:** While the DMAi enable bit is "0," the DMAi request bit is not set to "1" even if a DMA request is generated. When the DMAi enable bit is cleared to "0," also the DMAi request bit is cleared to "0." However, the DMA request generated while the DMAi enable bit = "0" is maintained; and when the DMAi enable bit is set to "1," the DMAi request bit is also set to "1," except for the burst transfer mode (level sense). 13.3 Control #### 13.3.3 Channel priority levels When the DMA enable bits of several channels are "1" and their DMA request bits are set to "1," the request of the channel with the highest priority is accepted first. The fixed or rotating channel priority can be selected by the priority select bit (bit 0 at address 68<sub>16</sub>). The priority levels themselves cannot be specified arbitrary. The channel priority levels are determined after the DMA requests are determined. #### (1) Fixed priority The fixed priority is selected when the priority select bit (bit 0 at address $68_{16}$ ) = "0." In the fixed priority, the channel priority levels are as follows: channel 0 > channel 1 > channel 2 > channel 3. #### (2) Rotating priority The rotating priority is selected when the priority select bit = "1." After reset, the priority levels are the same descending order as in the fixed priority: channel 0 > channel 1 > channel 2 > channel 3. Then, after every normal termination of a DMA transfer, the priority levels rotate in such a way that the lowest priority is given to the channel having been performed. When DMA transfer is forced into termination, the channel priority levels does not rotate. Figure 13.3.1 shows an example of determining the channel priority levels. #### 13.3 Control Fig. 13.3.1 Example of determining channel priority levels 13.3 Control #### 13.3.4 Processing from DMA request until DMA transfer execution DMA requests are sampled at every falling edge of $\phi_1$ ; when requested, the DMAi request bit is set to "1." Then, the channel priority levels and bus use priority levels are determined, and BUS REQUEST (DMAC) goes "1" if any DRAM refresh request or Hold request is not generated **(Note).** BUS REQUEST (DMAC) signal is sampled while the bus request sampling signal is "1" and is accepted (DMA request acceptance). Figure 13.3.2 shows an example of timing from the determination of a DMA request until the DMA transfer execution. Refer to section "13.9 DMA transfer time" for the time from DMA request generation until the CPU's regaining the right to use bus via DMA transfer. **Note:** In the following cases, BUS REQUEST (DMAC) does not go "1." However, the DMAi request bit remains set to "1." Accordingly, after completion of each state, the channel priority levels and bus use priority levels are determined, and BUS REQUEST (DMAC) goes "1" if any DRAM refresh request or Hold request is not generated. - When a DMA request is generated during a burst transfer or in an array state (However, if a DRAM refresh request or Hold request is generated during this term, its BUS REQUEST goes "1.") - When a DMA request is not accepted with a DRAM refresh request or Hold request generated #### 13.3 Control Fig. 13.3.2 Example of timing from determination of DMA request until DMA transfer execution 13.3 Control #### 13.3.5 Termination of DMA transfer As the methods of terminating DMA transfer, normal and forced termination are used. #### (1) Normal termination All of the DMAi transfers terminate and DMAC stops. This method is used in the single transfer, array chain transfer, and link array chain transfer modes. In the repeat transfer mode, however, normal termination cannot be applied to terminating transfer; then, forced termination must be used. (Refer to "(2) Forced termination" of this section.) Table 13.3.4 lists the states of DMAC at normal termination. Table 13.3.4 States of DMAC at normal termination | Item | State | | | | |----------------------------|-------------------------------------------------------|--|--|--| | DMAi interrupt request bit | 1 | | | | | DMAi request bit | In the burst transfer mode (edge sense): 0 | | | | | | In the burst transfer mode (level sense): not changed | | | | | | In the cycle-steal transfer mode: not changed (Note) | | | | | DMAi enable bit | 0 | | | | | TC output | Outputs "L" (when the TC pin is valid) | | | | | Channel priority levels | Rotating (when the rotating priority is selected) | | | | **Note:** In the cycle-steal transfer mode, the DMAi request bit is cleared to "0" when a DMA request is accepted. This bit is does not change at normal termination. At normal termination, the CPU regains the right to use bus after the terminate processing (3 cycles of $\phi$ ) via the transition of the right to use bus (1 cycle of $\phi$ ). Figure 13.3.3 shows a timing example at normal termination. #### 13.3 Control Fig. 13.3.3 Timing example at normal termination 13.3 Control #### (2) Forced termination The methods of terminating DMAC other than normal termination are as follows: - Drives the TC pin's input level from "H" to "L" during a DMA transfer (when the TC pin is valid). - Writes "0" to the DMAi enable bit. Table 13.3.5 lists the states of DMAC at forced termination. Table 13.3.5 States of DMAC at forced termination | Item | State | |----------------------------|--------------| | DMAi interrupt request bit | Not changed. | | DMAi request bit | 0 | | DMAi enable bit | 0 | | TC output | Not changed. | | Channel priority levels | Not changed. | When the $\overline{TC}$ pin is used for forced termination, select " $\overline{TC}$ pin valid" (bit 1 at address $68_{16}$ = "1"). Forced termination by the $\overline{TC}$ input is valid in the following cases: - During a DMA transfer in the burst transfer mode (edge sense) - During the term from the DMA transfer start until the transfer completion of an entire batch of data in the burst transfer mode with the level sense selected. (It is also valid while the CPU has the right to use bus). - During a DMA transfer in the cycle-steal transfer mode (Forced termination by the TC input is invalid while the CPU has the right to use bus.) The $\overline{TC}$ pin's input is determined at the falling edge of $\phi_1$ , and DMAC will relinquish the right to use bus to the CPU upon completion of the 1-unit transfer under execution at that time. At the forced termination by the DMAi enable bit, "0" is written to this bit at the rising edge of $\bar{E}$ of a write cycle to the DMAi enable bit. Accordingly, DMAi is disabled after this write. #### 13.3 Control #### 13.3.6 DMA transfer restart after termination #### (1) Restarting the same DMA transfer as the previous one from the beginning At normal and forced termination, the latches of SARi, DARi, and TCRi maintain their values written before the transfer start. (Refer to "Figure 13.3.4-a.") Therefore, DMA transfer must be restarted according to the following procedures: #### • In single or repeat transfer mode Set the DMAi enable bit to "1." It is not necessary to re-set the values of SARi, DARi, and TCRi by software. (Refer to "Figure 13.3.4-b.") #### In array chain or link array chain transfer mode - ① Re-set the values of SARi and TCRi. - 2 Set the DMAi enable bit to "1." # (2) Restarting transfer of data subsequent to one which has been transferred just before forced termination When reading values at the addresses of SARi, DARi, and TCRi after forced termination, the values of these registers (counters) can be read. These read values are the transfer source address, the transfer destination address which were to be transferred subsequently, and the number of remaining bytes. When writing these read values to the addresses of SARi, DARi, and TCRi respectively, the same values are also written to their latches. When setting the DMAi enable bit to "1" under this condition, transfer of data subsequent to one which has been transferred just before forced termination is restarted. (Refer to "Figure 13.3.4-c.") #### • In single transfer mode The remaining data can be transferred by the following procedure: - ① Read the values at addresses of SARi, DARi and TCRi. Then, rewrite these values into these addresses. - 2 Set the DMAi enable bit to "1." #### • In repeat transfer, array chain transfer, and link array chain transfer modes The remaining data of the block that was interrupted by forced termination can be transferred by the following procedure: - ① Switch over the current mode to the single transfer mode. - ② Read the values at addresses of SARi, DARi and TCRi. Then, rewrite these values into these addresses. - 3 Set the DMAi enable bit to "1." (Refer to "Figure 13.3.4-c.") - In order to transfer the next block, switch over the current mode to the previous mode after the above-mentioned transfer is normally terminated. Then, re-set the values of SARi, DARi, and TCRi. In the array chain or the link array chain transfer mode, information such as the next transfer parameters etc. cannot be read from each latch. Fig.13.3.4 States of SARi, DARi, TCRi after forced termination #### 13.4 Operation ### 13.4 Operation Operation of 1-unit transfer varies according to the data transfer method (2-bus cycle or 1-bus cycle transfer). In addition, how many units of transfer data are transferred for a DMA request varies according to the transfer mode (burst transfer or cycle-steal transfer mode). These data transfer methods and modes are described below. #### 13.4.1 2-bus cycle transfer When the transfer method select bit (Refer to "Figure 13.2.6.") = "0," 2-bus cycle transfer is selected. 2-bus cycle transfer is the method used to transfer data between memories. Since this method has a read and a write cycle, it consumes a minimum of 2 bus cycles for 1-unit transfer. Figure 13.4.1 shows an example of connecting external memories in 2-bus cycle transfer. Fig. 13.4.1 Example of connecting external memories in 2-bus cycle transfer #### (1) Register operation in 2-bus cycle transfer Figure 13.4.2 shows a basic operation of registers for 1-unit transfer in 2-bus cycle transfer. For register values to be specified, refer to section "13.5 Single transfer mode" through section "13.8 Link array chain transfer mode." It is because that these values vary according to continuous transfer modes. In 2-bus cycle transfer, the data read at a read cycle is maintained temporarily in the DMA latch, and the contents of this latch are written to a memory at a write cycle. Fig. 13.4.2 Basic operation of registers for 1-unit transfer in 2-bus cycle transfer and TCRi are used.) ### 13.4 Operation #### (2) Bus operation in 2-bus cycle transfer The time required for 1-unit transfer in 2-bus cycle transfer is given by the following formula: Transfer time per 1-unit transfer = (Read cycle) + (Write cycle) Since any area can be specified as a transfer source or a transfer destination, a read cycle varies with the conditions of a transfer source, and a write cycle with that of a transfer destination. Table 13.4.1 lists the time required for a read or write cycle per 1-unit transfer in 2-bus cycle transfer, and Figure 13.4.3 shows the bus-cycle operation waveforms in 2-bus cycle transfer. Table 13.4.1 Time required for a read or write cycle per 1-unit transfer in 2-bus cycle transfer | External | Transfer | Address directions | Data's start | Rea | d/Write cycl | e (Unit: φ cy | /cle) | |------------|----------|--------------------|--------------|---------|--------------|---------------|--------------| | bus width | unit | | address | Formula | No Wait | With Wait | DRAM area | | 16 bits | 16 bits | Fixed/Forward | Even | 1 + i | 2 (a) | 3 ( | (d) | | (including | | | Odd | 2 + 2i | 4 (c) | 6 | (f) | | internal | | Backward | Even | 2 + 2i | 4 (c) | 6 | (f) | | bus) | | | Odd | 2 + i | 3 (b) | 4 (e) | 4 (e) (Note) | | | 8 bits | Fixed/Forward/ | Even/Odd | 1 + i | 2 (a) | 3 ( | (d) | | | | Backward | | | | | | | 8 bits | 16 bits | Fixed/Forward/ | Even/Odd | 2 + 2i | 4 (c) | 6 | (f) | | | | Backward | | | | | | | | 8 bits | Fixed/Forward/ | Even/Odd | 1 + i | 2 (a) | 3 ( | (d) | | | | Backward | | | | | | Address directions: Refer to section "13.4.1 (3) Address directions in 2-bus cycle transfer." **Note:** When a transfer destination applies to this condition, 2-bus cycle transfer cannot be performed. When a transfer source applies to this condition and a transfer destination is in the DRAM area, 2-bus cycle transfer cannot also be performed. i: A term of $\bar{E}$ = "L" in 1-bus cycle; i = 1 at "No Wait", and i = 2 at "With Wait" or "DRAM area". When Ready function is used (Refer to section "3.3 Ready function."), the number of cycles extended by Ready must be added. <sup>():</sup> Indicates the corresponding waveform in Figure 13.4.3. Fig. 13.4.3 Bus-cycle operation waveforms in 2-bus cycle transfer #### 13.4 Operation #### (3) Address directions in 2-bus cycle transfer In 2-bus cycle transfer, the address direction of a transfer source and that of a transfer destination each can be selected independently. (Refer to "Figure 13.2.6.") Addresses move in the specified direction by the transfer unit. Tables 13.4.2 through 13.4.4 list address directions in 2-bus cycle transfer and examples of transfer result. Tables 13.4.2 Address directions in 2-bus cycle transfer and examples of transfer result (1) | i abies i | 3.4.2 Auu | ress directions | in Z-bus | | | | | | rer result | t (1) | |--------------------|----------------------|--------------------------------------------------|-------------------|---------------------------------------------------------------------------------------------------------|----------|----------|-------------------------------------|---------------|------------------------------------|-----------| | Address | direction | | | External data | a bus wi | atn : 16 | | | | | | | | Tran | sfer unit : 1 | 6 bits | | | Tran | sfer unit : 8 | bits | | | Transfer<br>source | Transfer destination | Data arrangement<br>on transfer source<br>memory | Transfer sequence | Data arrangel<br>transfer dest<br>memory (transf | ination | on tran | rrangement<br>esfer source<br>emory | | | stination | | Fixed | Fixed | * Low order Data High order | | Low order<br>Data High order | * | * | Data | <b>**</b> | Data | * | | Fixed | Forward | * Low order Data High order | | Low order Data High order Low order Data High order Low order Low order Data High order High order | | * | Data | | Data Data Data Data Data Data Data | * | | Fixed | Backward | * Low order Data High order | 3 2 | Low order Data High order Low order Data High order Low order Data High order Low order Data High order | * | * ] | Data | | Data Data Data Data Data Data Data | * | <sup>\* :</sup> Transfer start address 13.4 Operation Tables 13.4.3 Address directions in 2-bus cycle transfer and examples of transfer result (2) | | | | idth : 16 | dth : 16 bits or 8 bits | | | | | | | |-----------------|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|---------------------------------------------------------------------------------------|--------|------------------------|------------------------------------------------|----------------------------------------------|------------------------------------------------|-----------| | Address | direction | Transfer unit : 16 bits | | | | Transfer unit : 8 bits | | | | | | Transfer source | Transfer destination | Data arrangement<br>on transfer source<br>memory | Transfer sequence | Data arrangem<br>transfer destii<br>memory (transfe | nation | on trar | irrangement<br>nsfer source<br>nemory | Transfer sequence Data arrange transfer desi | | stination | | Forward | Fixed | Low order Data 1 — High order Data 2 — High order Low order Data 3 — High order Data 3 — High order | 3 | Low order<br>Data<br>1–3<br>High order | * | * | Data 1 Data 2 Data 3 Data 4 Data 5 Data 6 | | Data 1–6 | * | | Forward | Forward | Low order Data 1 — High order Data 2 — High order Low order Data 3 — High order Data 3 — High order | ① ① ② → ② ③ ③ | Low order Data 1 High order Low order Data 2 High order Low order Data 3 High order | * | * | Data 1 Data 2 Data 3 Data 4 Data 5 Data 6 | ① ② ③ ③ ④ ⑤ ⑥ | Data 1 Data 2 Data 3 Data 4 Data 5 Data 6 | * | | Forward | Backward | Low order Data 1 — High order Data 2 — High order Low order Data 3 — High | on relationsl | Tilgit order | | * | Data 1 Data 2 Data 3 Data 4 Data 5 Data 6 | | Data 6 Data 5 Data 4 Data 3 Data 2 Data 1 | * | \*: Transfer start address ### 13.4 Operation Tables 13.4.4 Address directions in 2-bus cycle transfer and examples of transfer result (3) | Address direction | | | | External data b | dth: 16 bits or 8 bits | | | | | | |-------------------|----------------------|---------------------------------------------------------------------------------------------------|-------------------|-------------------------------------------------------------------------------------------------------------|------------------------|--------------------------------------------------|-------------------------------------------|-----------------------|-------------------------------------------------------------------------|---| | | | Transfer unit : 16 bits | | | | | Transfer unit: 8 bits | | | | | Transfer source | Transfer destination | Data arrangement<br>on transfer source<br>memory | Transfer sequence | Data arrangement on transfer destination memory (transfer result) | | Data arrangement<br>on transfer source<br>memory | | Transfer<br>sequence | Data arrangement on<br>transfer destination<br>memory (transfer result) | | | Backward | Fixed | Low order Data 3 — High order Low order Data 2 — High order Low order Data 1 — High order | 3 | Low order Data 1–3 High order | k | * | Data 6 Data 5 Data 4 Data 3 Data 2 Data 1 | | Data 1–6 | * | | Backward | Forward | Low order Data 3 High order Low order Data 2 High order Low order Data 1 High order | | Low order Data 1 High order Low order Data 2 High order Low order Data 3 High order | ķ | * | Data 6 Data 5 Data 4 Data 3 Data 2 Data 1 | 66 6 3 2 1 | Data 1 Data 2 Data 3 Data 4 Data 5 Data 6 | * | | Backward | Backward | Low order Data 3 High order Low order Data 2 High order Low order Data 1 High order High order | 2 | Low order Data 3 — High order Low order Data 2 — High order Low order Data 1 — High order High order ** | | * | Data 6 Data 5 Data 4 Data 3 Data 2 Data 1 | 6<br>6<br>4<br>3<br>2 | Data 6 Data 5 Data 4 Data 3 Data 2 Data 1 | * | \*: Transfer start address 13.4 Operation #### [Precautions for 2-bus cycle transfer] When the 16-bit external data bus width = 16 bits and the transfer unit = 16 bits under the following conditions, 2-bus cycle transfer cannot be performed. (Refer to "Table 13.4.1.") #### • Conditions for transfer destination Transfer destination = DRAM area, Address direction = Backward, Data's start address = Odd address #### • Conditions for transfer source and destination Transfer source = DRAM area, Address direction = Backward, Data's start address = Odd address Transfer destination = DRAM area ### 13.4 Operation #### 13.4.2 1-bus cycle transfer When the transfer method select bit (Refer to "Figure 13.2.6.") = "1," 1-bus cycle transfer is selected. 1-bus cycle transfer is the method used to transfer data between a memory and an I/O. In this method, a read and write of 1-tansfer-unit data are simultaneously performed during 1-bus cycle. The address bus, $\overline{BHE}$ , $\overline{BLE}$ , and $R/\overline{W}$ indicate the states of memory. Figure 13.4.4 shows an example of connecting external memories and I/Os in 1-bus cycle transfer. Fig. 13.4.4 Example of connecting external memories and I/Os in 1-bus cycle transfer 13.4 Operation In 1-bus cycle transfer, the following considerations must be taken in designing the system: - Achieve the condition that 1-transfer-unit data can be accessed in 1-bus cycle. (Refer to "Table 13.4.5.") - Specify the transfer address direction and I/O connections. (Refer to "Figure 13.2.7.") - Compose the read and write signal generating circuit externally. (These signals are for I/Os.) The M37721 outputs signals to the memory. Accordingly, make sure to compose the circuit which generates write signals for I/Os when the M37721 outputs read signals; which generates read signals for I/Os when the M37721 outputs write signals. Figure 13.4.5 shows an example of the circuit generating a write signal and a read signal for I/Os. Fig. 13.4.5 Example of circuit generating write signal and read signal for I/Os #### 13.4 Operation #### (1) Register operation in 1-bus cycle transfer Figure 13.4.6 shows a basic operation of registers for 1-unit transfer in 1-bus cycle transfer. For register values to be specified, refer to section "13.5 Single transfer mode" through section "13.8 Link array chain transfer mode." It is because these values vary depending on each continuous transfer mode. In 1-bus cycle transfer, a read and write of 1-transfer-unit data are simultaneously performed during 1-bus cycle. Fig. 13.4.6 Basic operation of registers for 1-unit transfer in 1-bus cycle transfer 13.4 Operation #### (2) Bus operation in 1-bus cycle transfer The time required for 1-unit transfer in 1-bus cycle transfer is given by the following formulas: - Transfer from memory to I/O: Transfer time per 1-unit transfer = (Read cycle of memory) - Transfer from I/O to memory: Transfer time per 1-unit transfer = (Write cycle of memory) In 1-bus cycle transfer, 1-transfer-unit data is accessed in 1-bus cycle, so that limitations are imposed on the transfer conditions to be applied. Table 13.4.5 lists the conditions of 1-bus cycle transfer and the transfer time per 1-unit transfer, and Figure 13.4.7 shows the bus-cycle operation waveforms in 1-bus cycle transfer. Table 13.4.5 Conditions of 1-bus cycle transfer and Transfer time per 1-unit transfer | External | Transfer | Address directions Data's start Read/Write cycle (Unit: φ cycl | | | | | | |------------|----------|----------------------------------------------------------------|----------|---------|---------|-----------|-----------| | bus width | unit | | address | Formula | No Wait | With Wait | DRAM area | | 16 bits | 16 bits | Fixed/Forward | Even | 1 + i | 2 (a) | 3 (c) | | | (including | | | Odd | | | | | | internal | | Backward | Even | | | | | | bus) | | | Odd | 2 + i | 3 (b) | 4 (d) | | | | 8 bits | Fixed/Forward/ | Even/Odd | 1 + i | 2 (a) | 3 | (c) | | | | Backward | | | | | | | 8 bits | 16 bits | Fixed/Forward/ | Even/Odd | | | | | | | | Backward | | | | | | | | 8 bits | Fixed/Forward/ | Even/Odd | 1 + i | 2 (a) | 3 | (c) | | | | Backward | | | | | | Address directions: Refer to section "13.4.2 (3) Address directions in 1-bus cycle transfer." There is no address direction on the I/O side. - i: A term of $\overline{E}$ = 'L" in 1-bus cycle; i = 1 at "No Wait", and i = 2 at "With Wait" or "DRAM area". When Ready function is used (Refer to section "3.3 Ready function."), the number of cycles extended by Ready must be added. - (): Indicates the corresponding waveform in Figure 13.4.7. - /: 1-bus cycle transfer cannot be performed. When the external data bus width = 16 bits and the transfer unit = 8 bits are selected, the data bus which the memory uses and the data bus to which I/O is connected may be different. In such a case, data is copied from the data bus of a transfer source to that of a transfer destination by using the DMA latch. For the combination that data copy may occur, data copy delay time $t_{d(data)}$ must be taken into consideration. Table 13.4.6 lists the data flows on the data bus in 1-bus cycle transfer, and Table 13.4.7 lists the outputs of the address bus, the data bus, and the bus control signals in 1-bus cycle transfer. ### 13.4 Operation Fig. 13.4.7 Bus-cycle operation waveforms in 1-bus cycle transfer Table 13.4.6 Data flows on data bus in 1-bus cycle transfer | External data bus width | I/O<br>connection | Transfer<br>unit | Read/Write address<br>of memory | Data flow | |-------------------------|---------------------------|------------------|------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------| | 16 bits | Data bus D0-D7 and D8-D15 | 16 bits | Even address<br>and<br>Odd address | Data bus D <sub>8</sub> -D <sub>15</sub> Data bus D <sub>0</sub> -D <sub>7</sub> Memory I/O I/O | | 16 bits | Data bus<br>Do-D7 | 8 bits | Even address | M37721 — Data bus D8–D15 Data bus D0–D7 Memory Memory I/O | | | | | Odd address | Note: Data is copied from data bus Do-D7 to De-D15 or from data bus De-D15 to Do-D7 in the M37721's DMAC. Note the data copy delay time td(data). | | 16 bits | Data bus<br>D8-D15 | 8 bits | Even address | Note: Data is copied from data bus Do-D7 to De-D15 or from data bus De-D15 to Do-D7 in the M37721's DMAC. Note the data copy delay time td(data). | | | | | Odd address | M37721 Data bus D <sub>8</sub> -D <sub>15</sub> Data bus D <sub>0</sub> -D <sub>7</sub> | | 8 bits | Data bus<br>Do–D7 | 8 bits | Even address<br>and<br>Odd address | M37721 Data bus Do-D7 Memory I/O | **Note:** When the memory is the internal memory or SFR, the above case for external data bus width = 16 bits applies. ### 13.4 Operation Table 13.4.7 Outputs of address bus, data bus, and bus control signals in 1-bus cycle transfer | | | | | Output of address bus, data bus, and bus control signals | | | | | | |-------------------------------|--------------------------------------------------------------------------------------|------------------|---------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | External<br>data bus<br>width | I/O<br>connection | Transfer<br>unit | Read/Write<br>address of<br>memory | Transferred from memory to I/O E R/W | Transferred from I/O to memory | | | | | | 16 bits | Data bus<br>D <sub>0</sub> –D <sub>7</sub><br>and<br>D <sub>8</sub> –D <sub>15</sub> | 16 bits | Even<br>address<br>and<br>Odd address | A8/D8-A15/D15 Transfer source data data data data data data data dat | Transfer destination address Transfer destination address | | | | | | 16 bits | Data bus<br>D₀–D7 | 8 bits | Even<br>address<br>Odd<br>address | A8/D8-A15/D15 Transfer source address A16/D0-A23/D7 H BHE BLE L A8/D8-A15/D15 Transfer source address L A8/D8-A15/D15 Transfer source address Copy address A16/D0-A23/D7 Transfer source address Copy address A16/D0-A23/D7 Transfer source address A16/D0-A23/D7 Transfer source address A16/D0-A23/D7 Transfer source address A16/D0-A23/D7 | Transfer destination address Transfer destination address H Transfer destination address L Transfer destination address I/O data Transfer destination address Transfer destination address Transfer destination address | | | | | | 16 bits | Data bus | 8 bits | Even<br>address | A8/D8-A15/D15 Transfer source address data A16/D0-A23/D7 H BHE BLE L | Transfer destination address Copy Transfer destination I/O data H | | | | | | 10 5110 | D8-D15 | o she | Odd<br>address | A8/D8-A15/D15 Transfer source address \( \) Odd address data address \( \) A16/D0-A23/D7 Transfer source address \( \) Invalid data \( \) BHE H BLE | Transfer destination address Transfer destination Invalid data L | | | | | | 8 bits | Data bus<br>Do-D7 | 8 bits | Even<br>address<br>and<br>Odd address | A8-A15 Transfer source address A16/D0-A23/D7 Transfer source address Data Address | Transfer destination address Transfer destination address | | | | | <sup>:</sup> When the memory is the internal memory or SFR, data is output. When the memory is the external memory, it enters a floating state. 13.4 Operation #### (3) Address directions in 1-bus cycle transfer In 1-bus cycle transfer, the transfer source and destination address directions of memory are selectable. (Refer to "Figure 13.2.6.") Addresses move in the specified direction by the transfer unit. Tables 13.4.8 and 13.4.9 list address directions in 1-bus cycle transfer and examples of transfer results. Table 13.4.8 Address directions in 1-bus cycle transfer and examples of transfer results (1) | Address direction | | External da | ata bus wid | lth : 16 bits | External data bus width: 16 bits or 8 bits | | | | | |------------------------|--------------------------|---------------------------------------------------------------------------------------|-----------------------------------|-----------------------------------|--------------------------------------------|-------------------------------------------|-----------------------------------------|----------|--| | | | Tran | sfer unit : 1 | 16 bits | Transfer unit: 8 bits | | | | | | Transfer source memory | Transfer destination I/O | Data arrangement on transfer source memory | Transfer destination sequence I/O | | Data arrangement on transfer source memory | | Transfer<br>sequence | | | | Fixed | _ | * Low order<br>Data —<br>High order | | Low order<br>Data —<br>High order | * | Data | <b></b> | Data | | | Forward | _ | Low order Data 1 High order Low order Data 2 High order Low order Data 3 High order | 3 | Low order Data 1–3 High order | * | Data 1 Data 2 Data 3 Data 4 Data 5 Data 6 | ① ② ③ ④ ⑤ | Data 1–6 | | | Backward | _ | Low order Data 3 High order Low order Data 2 High order Low order Data 1 High order | | Low order Data 1–3 High order | * | Data 6 Data 5 Data 4 Data 3 Data 2 Data 1 | 6 6 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 | Data 1–6 | | <sup>\*:</sup> Transfer start ## 13.4 Operation Table 13.4.9 Address directions in 1-bus cycle transfer and examples of transfer results (2) | Address direction | | External data bus width : 16 bits | | | | External data bus width : 16 bits or 8 bits | | | | | |---------------------------|-----------------------------|-----------------------------------|-------------------|--------------------------------------------------------------------------------------------------------------|---------|---------------------------------------------|-------------------|-------------------|--------------------------------------------|------------| | | | Transfer unit : 16 bits | | | | Transfer unit: 8 bits | | | | | | Transfer<br>source<br>I/O | Transfer destination memory | Transfer source I/O | Transfer sequence | Data arranger<br>transfer dest<br>memory (transf | ination | Trans | fer source<br>I/O | Transfer sequence | Data arrang<br>transfer de<br>memory (tran | estination | | _ | Fixed | Low order<br>Data —<br>High order | | Low order<br>Data —<br>High order | 1 | *[ | Data | | Data | * | | _ | Forward | Low order<br>Data —<br>High order | | Low order Data — High order Low order Data — High order Low order Low order Data — High order High order | 1 | | Data | | Data Data Data Data Data Data Data | * | | _ | Backward | Low order<br>Data<br>High order | | Low order Data — High order Low order Data — High order Low order Low order Data — High order | | | Data | 6 4 3 2 0 | Data Data Data Data Data Data Data | * | \*: Transfer start 13.4 Operation ### [Precautions for 1-bus cycle transfer] - 1. The area that overlaps with internal RAM and SFRs must not be assigned to an external memory. When the contents in the overlapped area are read, the data of internal RAM or SFRs and that of external memory are simultaneously placed on the data bus; and they collide with each other. - 2. For the system that transfers data with 16-bit external data bus width from an external memory to an 8-bit I/O, the external memory must be composed to be read in a unit of 8 bits. If the external memory cannot be read in a unit of 8 bits, the data read from the external memory at data copy collides with the copied data on the data bus. - 3. Under the following conditions, 1-bus cycle transfer cannot be performed. (Refer to "Table 13.4.5."): - External data bus width = 16 bits, Transfer unit = 16 bits, Address direction of memory = Fixed or Forward, Data's start address of memory = Odd - External data bus width = 16 bits, Transfer unit = 16 bits, Address direction of memory = Backward, Data's start address of memory = Even - External data bus width = 16 bits, Transfer unit = 16 bits, Target memory of DMA transfer = DRAM area, Address direction of memory = Backward, Data's start address of memory = Odd - External data bus width = 8 bits, Transfer unit = 16 bits ### 13.4 Operation #### 13.4.3 Burst transfer mode The burst transfer mode can operate in either edge sense or level sense mode. #### (1) Burst transfer mode (edge sense) When the transfer mode select bit = "0" and the edge sense/level sense select bit = "0," this mode is selected. (Refer to "Figures 13.2.6 and 13.2.8.") In this mode, all of the DMA request sources are available. Figure 13.4.8 shows a transfer example in the burst transfer mode (edge sense). When once a DMA request is accepted in this mode, an entire batch of data is transferred: the right to use bus is not returned to the CPU until the transfer is complete. During a burst transfer, any DMA request (including that of other channels) cannot be accepted. However, the BUS REQUEST signal is sampled basically at every completion of 1-unit transfer. (Refer to "Table 13.2.3.") When a DRAM refresh request or Hold request is generated at this time, the right to use bus is not returned to the CPU, and the request is accepted. When the transfer of an entire batch of data is complete, the DMAC relinquishes the right to use bus to the CPU. When the next DMA request is generated, the right is once returned to the CPU to sample the DMA request. #### (2) Burst transfer mode (level sense) When the transfer mode select bit = "0" and the edge sense/level sense select bit = "1", this mode is selected. (Refer to "Figures 13.2.6 and 13.2.8.") In this mode, only the external source is used as a DMA request source. Set the DMA request source select bits to "00012." (Refer to "Figure 13.2.8.") Figure 13.4.9 shows a transfer example in the burst transfer mode (level sense). When the DMAREQI pin's input level = "L," the DMAi request bit is cleared to "0"; when this pin's input level = "L," the DMAi request bit is set to "1." Therefore, when the DMAREQi pin's input level is "L" with the DMAi enable bit = "1," a DMA transfer starts. When the DMAREQi pin's input level goes from "L" to "H," the right to use bus will be returned to the CPU at completion of 1-unit transfer under execution at that time. When the DMAREQi pin's input level goes "L" again, the DMA transfer restarts at the next address. Once a DMAi transfer starts, any DMA request (including that of other channels) cannot be accepted, even if the DMAREQI pin's input level is "H," until the transfer is terminated normally or forcibly. However, the BUS REQUEST signal is sampled basically at every completion of 1-unit transfer. (Refer to "Table 13.2.3.") When a DRAM refresh request or Hold request is generated at this time, the right to use bus is not returned to the CPU, and the request is accepted. When the transfer of an entire batch of data is complete, the DMAC relinquishes the right to the CPU. If the next DMA request is generated, the right is once returned to the CPU to sample the DMA request. Fig. 13.4.8 Transfer example in the burst transfer mode (edge sense) Fig. 13.4.9 Transfer example in the burst transfer mode (level sense) ### 13.4 Operation ### [Precautions for burst transfer mode] 1. In the burst transfer mode (edge sense), the DMAi request bit is cleared to "0" when the transfer of an entire batch of data is complete or the transfer is forced into termination. Therefore, another DMA request of the same channel i is invalid if generated during DMAi transfer. Fig. 13.4.10 Timing when clearing DMAi request bit to "0" in burst transfer mode 2. Because interrupt priority levels are determined while the CPU fetches an operation code, interrupt requests are not accepted during a DMA transfer. In the burst transfer mode (edge sense), therefore, interrupt requests cannot be accepted until the transfer of an entire batch of data is complete or the transfer is forced into termination. #### 13.4.4 Cycle-steal transfer mode When the transfer mode select bit = "1" and the edge sense/level sense select bit = "0," this mode is selected. (Refer to "Figures 13.2.6 and 13.2.8.") In this mode, all of the DMA request sources are available. Figure 13.4.11 shows a transfer example in the cycle-steal transfer mode 1-transfer-unit data is transferred for each DMA request. The BUS REQUEST signal is sampled basically at every completion of 1-unit transfer. (Refer to "**Table 13.2.3.**") When a DRAM refresh request or Hold request is generated at this time, the right to use bus is not returned to the CPU, and the request is accepted. When several DMA requests are generated, the request of the channel which has the highest priority among them is accepted, and DMA transfer is performed without returning the right to use bus to the CPU. When any request is not generated, the CPU gains the right. Fig. 13.4.11 Transfer example in cycle-steal transfer mode ### 13.4 Operation ### [Precautions for cycle-steal transfer mode] #### 1. When DMA transfers of the same channel are continuously performed In the cycle-steal transfer mode, the DMAi request bit is cleared to "0" in every 1-unit transfer. Also, it takes 1.5 cycles of $\phi$ from the generation of a DMA request until that of a BUS REQUEST (DMAC). Therefore, if another DMA request of the same channel i is generated during a DMAi transfer in the cyclesteal transfer mode, any one of the following three cases occurs depending on the timing of request generation: - The DMA request becomes invalid. - The DMA transfer continues without returning the right to use bus. - After returning the right to use bus to the CPU, the DMAC regains the right and restarts the DMA transfer. Fig. 13.4.12 Conditions for performing DMA transfers of the same channel continuously 13.4 Operation #### 2. When a DMA transfer of another channel is subsequently performed In the cycle-steal transfer mode, it takes 1.5 cycles of $\phi$ from the generation of a DMA request until that of a BUS REQUEST (DMAC). Therefore, if a DMA request of another channel is generated during a DMAi transfer in the cycle-steal mode, either one of the following two cases occurs depending on its timing of request generation: - The DMAC performs the DMA transfer subsequently without returning the right to use bus. - After returning the right to use bus to the CPU once, the DMAC regains the right and performs the DMA transfer. Fig. 13.4.13 Conditions for performing DMA transfers of another channel subsequently ### 13.5 Single transfer mode ## 13.5 Single transfer mode This mode is used to transfer a block of data once. Table 13.5.1 lists the specifications of the single transfer mode, and Figure 13.5.1 shows the register structures of SARi, DARi, and TCRi in this mode. Table 13.5.1 Specifications of single transfer mode | Item | Performance specifications | | | |-------------------------------------|-----------------------------------------------------------------------|--|--| | Transfer parameter memory | Not required. | | | | Condition of normal termination | TCRi = 0 | | | | Conditions of forced termination | ● Falling edge of the TC pin's input from "H" to "L" | | | | | (when the $\overline{TC}$ pin validity bit ="1") | | | | | ■ Write "0" to the DMAi enable bit | | | | Interrupt request generation timing | At normal termination | | | | Functions of registers | SARi latch: Indicates the transfer start address of data block at the | | | | | transfer source. | | | | | SARi: Indicates the address of the next transfer source. | | | | | DARi latch: Indicates the transfer start address of data block at the | | | | | transfer destination. | | | | | DARi: Indicates the address of the next transfer destination. | | | | | TCRi latch: Indicates the number of transfer bytes. | | | | | TCRi: Indicates the number of remaining transfer bytes. | | | TC pin validity bit: Bit 1 at address 6816 ### 13.5 Single transfer mode Fig. 13.5.1 Register structures of SARi, DARi, and TCRi in single transfer mode ### 13.5 Single transfer mode #### 13.5.1 Setting of single transfer mode Figures 13.5.2 through 13.5.4 show an initial setting example for registers relevant to the single transfer mode. In addition, when timer A, timer B, UART, or the A-D converter is selected as a DMA request source, the setting for the peripheral is required. For details of the setting, refer to the chapter of each peripheral function. When a DMAi interrupt is used, the setting for enabling the interrupt is also required. For details, refer to "CHAPTER 7. INTERRUPTS." Fig. 13.5.2 Initial setting example for registers relevant to single transfer mode (1) ### 13.5 Single transfer mode Fig. 13.5.3 Initial setting example for registers relevant to single transfer mode (2) ### 13.5 Single transfer mode Fig. 13.5.4 Initial setting example for registers relevant to single transfer mode (3) ### 13.5 Single transfer mode #### 13.5.2 Operation in single transfer mode Figure 13.5.5 shows the operation flowchart of the single transfer mode, and Figure 13.5.6 shows a timing diagram of the single transfer mode (burst transfer mode). For the cycle-steal transfer mode, refer to the following: - All transfers except for the last 1-unit transfer: Figure 13.8.12 - Last 1-unit transfer: Figure 13.8.14 Also, refer to section "13.2.1 Bus access control circuit" for the bus request sampling during transfer. Fig. 13.5.5 Operation flowchart of single transfer mode ## 13.5 Single transfer mode Fig. 13.5.6 Timing diagram of single transfer mode (burst transfer mode) 13.6 Repeat transfer mode ## 13.6 Repeat transfer mode This mode is used to transfer one block of data repeatedly. Table 13.6.1 lists the specifications of the repeat transfer mode, and Figure 13.6.1 shows the register structures of SARi, DARi, and TCRi in this mode. Table 13.6.1 Specifications of repeat transfer mode | Item | Performance specifications | | | | |-------------------------------------|-----------------------------------------------------------------------|--|--|--| | Transfer parameter memory | Not required | | | | | Condition of normal termination | — (No normal termination) | | | | | Conditions of forced termination | ■ Falling edge of the TC pin's input from "H" to "L" | | | | | | (when the $\overline{TC}$ pin validity bit = "1") | | | | | | ● Write "0" to the DMAi enable bit | | | | | Interrupt request generation timing | No request is generated. | | | | | Functions of registers | SARi latch: Indicates the transfer start address of data block at the | | | | | | transfer source. | | | | | | SARi: Indicates the address of the next transfer source. | | | | | | DARi latch: Indicates the transfer start address of data block at the | | | | | | transfer destination. | | | | | | DARi: Indicates the address of the next transfer destination. | | | | | | TCRi latch: Indicates the number of transfer bytes. | | | | | | TCRi: Indicates the number of remaining bytes being transferred. | | | | TC pin validity bit: Bit 1 at address 68<sub>16</sub> ### 13.6 Repeat transfer mode Fig. 13.6.1 Register structures of SARi, DARi, and TCRi in repeat transfer mode 13.6 Repeat transfer mode ### 13.6.1 Setting of repeat transfer mode Figures 13.6.2 through 13.6.4 show an initial setting example for registers relevant to the repeat transfer mode. In addition, when timer A, timer B, UART, or the A-D converter is selected as a DMA request source, the setting for the peripheral is required. For details of the setting, refer to the chapter of each peripheral function. In this mode, only the forced termination can terminate the DMA transfer. (Refer to section "13.3.5 (2) **Forced termination.**" Therefore, in the burst transfer mode (edge sense selected), be sure to validate the $\overline{TC}$ pin. Fig. 13.6.2 Initial setting example for registers relevant to repeat transfer mode (1) ### 13.6 Repeat transfer mode Fig. 13.6.3 Initial setting example for registers relevant to repeat transfer mode (2) 13.6 Repeat transfer mode Fig. 13.6.4 Initial setting example for registers relevant to repeat transfer mode (3) ### 13.6 Repeat transfer mode #### 13.6.2 Operation in repeat transfer mode Figure 13.6.5 shows the operation flowchart of the repeat transfer mode, and Figure 13.6.6 shows a timing diagram of the repeat transfer mode (burst transfer mode). For the cycle-steal transfer mode, refer to the following: - All transfers except for the last 1-unit transfer: Figure 13.8.12 - Last 1-unit transfer: Figure 13.8.13 Also, refer to section "13.2.1 Bus access control circuit" for the bus request sampling during transfer. Fig. 13.6.5 Operation flowchart of repeat transfer mode ### 13.6 Repeat transfer mode Fig. 13.6.6 Timing diagram of repeat transfer mode (burst transfer mode) ### 13.7 Array chain transfer mode ### 13.7 Array chain transfer mode This mode is used to transfer several blocks of data. According to the information of each block stored in memory area (Note), several blocks of data are transferred. All of the transfer parameters <u>must be located in series</u>. Table 13.7.1 lists the specifications of the array chain transfer mode, and Figure 13.7.1 shows the register structures of SARi, DARi, and TCRi in this mode. **Note:** Each of the following information is called "transfer parameter": transfer start addresses of transfer source and destination, and transfer data's byte number. Table 13.7.1 Specifications of array chain transfer mode | Item | Performance specifications | | | | |-------------------------------------|----------------------------------------------------------------------------|--|--|--| | Transfer parameter memory | Required. | | | | | | ● In 2-bus cycle transfer: 12 bytes per one block | | | | | | (transfer source's transfer start address, transfer destination's transfer | | | | | | start address, transfer data's byte number) | | | | | | ● In 1-bus cycle transfer: 8 bytes per one block | | | | | | (from memory to I/O: transfer source's transfer start address, transfer | | | | | | data's byte number) | | | | | | (from I/O to memory: transfer destination's transfer start address, | | | | | | transfer data's byte number) | | | | | Condition of normal termination | TCRi latch = 0 and TCRi = 0 | | | | | Conditions of forced termination | ● Falling edge of the TC pin's input from "H" to "L" | | | | | | (when the $\overline{TC}$ pin validity bit = "1") | | | | | | ● Write "0" to the DMAi enable bit | | | | | Interrupt request generation timing | At normal termination | | | | | Functions of registers | SARi latch: Indicates the transfer parameter memory's start address of | | | | | | the next block. | | | | | | SARi: Indicates the address of the next transfer source. | | | | | | DARi latch: Not used. | | | | | | DARi: Indicates the address of the next transfer destination. | | | | | | TCRi latch: Indicates the number of remaining transfer blocks. | | | | | | TCRi: Indicates the number of remaining transfer bytes. | | | | TC pin validity bit: Bit 1 at address 6816 Fig. 13.7.1 Register structures of SARi, DARi, and TCRi in array chain transfer mode ### 13.7 Array chain transfer mode #### 13.7.1 Transfer parameter memory in array chain transfer mode The transfer parameters required for each transfer method are described below. These parameters must be located in series <u>starting at an even addresses</u>. Figure 13.7.2 shows a transfer parameter memory map in the array chain transfer mode. #### (1) In 2-bus cycle transfer All of the following transfer parameters are required for each block of data; that is, a transfer parameter memory consumes 12 bytes for each block. - Transfer source's transfer start address (24 bits) + Dummy data (8 bits) - Transfer destination's transfer start address (24 bits) + Dummy data (8 bits) - Transfer data's byte number (24 bits) + Dummy data (8 bits) ### (2) In 1-bus cycle transfer from memory to I/O All of the following transfer parameters are required for each block of data; that is, a transfer parameter memory consumes 8 bytes for each block. - Transfer source's transfer start address (24 bits) + Dummy data (8 bits) - Transfer data's byte number (24 bits) + Dummy data (8 bits) #### (3) In 1-bus cycle transfer from I/O to memory All of the following transfer parameters are required for each block of data; that is, a transfer parameter memory consumes 8 bytes for each block. - Transfer destination's transfer start address (24 bits) + Dummy data (8 bits) - Transfer data's byte number (24 bits) + Dummy data (8 bits) Fig. 13.7.2 Transfer parameter memory map in array chain transfer mode ### 13.7 Array chain transfer mode #### 13.7.2 Setting of array chain transfer mode Figures 13.7.3 through 13.7.5 show an initial setting example for registers relevant to the array chain transfer mode. In addition, when timer A, timer B, UART, or the A-D converter is selected as a DMA request source, the setting for the peripheral is required. For details of the setting, refer to the chapter of each peripheral function. When a DMAi interrupt is used, the setting for enabling the interrupt is also required. For details, refer to "CHAPTER 7. INTERRUPTS." Fig. 13.7.3 Initial setting example for registers relevant to array chain transfer mode (1) Fig. 13.7.4 Initial setting example for registers relevant to array chain transfer mode (2) Fig. 13.7.5 Initial setting example for registers relevant to array chain transfer mode (3) ### 13.7 Array chain transfer mode #### 13.7.3 Operation in array chain transfer mode Figure 13.7.6 shows the operation flowchart of the array chain transfer mode, and Figures 13.7.7 and 13.7.8 show timing diagrams of the array chain transfer mode (burst transfer mode). For the cycle-steal transfer mode, refer to the following: - Transfer of transfer parameters in an array state: Figures 13.8.10 and 13.8.11 - All transfers except in an array state and except the last 1-unit transfer of each block: Figure 13.8.12 - Last 1-unit transfer of each block except the last block: Figure 13.8.13 - Last 1-unit transfer of the last block: Figure 13.8.14 The processing performed in the array chain transfer mode consists of an array state and a transfer state. #### (1) Array state In an array state, transfer parameters are read from the transfer parameter memory in a unit of 2 bytes and transferred to registers SARi, DARi, and TCRi and their latches. As shown in Figure 13.7.2, a transfer parameter consists of 4 bytes (24 bits of data + 8 bits of dummy data). One bus cycle always consumes 3 cycles of $\phi$ . During an array state, the DMAACKi pin outputs "H" level. For the bus request sampling in an array state, refer to section "13.2.1 Bus access control circuit." #### (2) Transfer state Data is transferred in a transfer state. For the bus request sampling in a transfer state, refer to section "13.2.1 Bus access control circuit." Fig. 13.7.6 Operation flowchart of array chain transfer mode Fig. 13.7.7 Timing diagram of array chain transfer mode (burst transfer mode) (1) Fig. 13.7.8 Timing diagram of array chain transfer mode (burst transfer mode) (2) 13.7 Array chain transfer mode ### [Precautions for array chain transfer mode] If the following two conditions are satisfied when the transfer unit is 16 bits and the address direction of transfer source or destination is fixed, the array chain transfer mode can be used: - The external data bus width = 16 bits or the internal memory is used. - The transfer start address on the address-direction-fixed side is an even address. ### 13.8 Link array chain transfer mode ### 13.8 Link array chain transfer mode This mode is used to transfer several blocks of data. According to the information of each block stored in memory area (Note), several blocks of data are transferred. Transfer parameters can be located in separate memory locations, in a unit of one block's parameters. Table 13.8.1 lists the specifications of the link array chain transfer mode, and Figure 13.8.1 shows the register structures of SARi, DARi, and TCRi in this mode. **Note:** Each of the following information is called "transfer parameter": transfer start addresses of transfer source and destination, and transfer data's byte number. Table 13.8.1 Specifications of link array chain transfer mode | Item | Performance specifications | |-------------------------------------|----------------------------------------------------------------------------| | Transfer parameter memory | Required. | | | ● In 2-bus cycle transfer: 16 bytes per one block | | | (transfer source's transfer start address, transfer destination's transfer | | | start address, transfer data's byte number, next transfer parameter | | | memory's start address) | | | ● In 1-bus cycle transfer: 12 bytes per one block | | | (from memory to I/O: transfer source's transfer start address, transfer | | | data's byte number, next transfer parameter memory's start address) | | | (from I/O to memory: transfer destination's transfer start address, | | | transfer data's byte number, next transfer parameter memory's start | | | address) | | Condition of normal termination | SARi latch = 0 and TCRi = 0 | | Conditions of forced termination | ●Falling edge of TC pin's input from "H" to "L" | | | (when the $\overline{TC}$ pin validity bit = "1") | | | ●Write "0" to the DMAi enable bit | | Interrupt request generation timing | At normal termination | | Functions of registers | SARi latch: Indicates the transfer parameter memory's start address of | | | the next block. | | | SARi: Indicates the address of the next transfer source. | | | DARi latch: Not used. | | | DARi: Indicates the address of the next transfer destination. | | | TCRi latch: Not used. | | | TCRi: Indicates the number of remaining bytes being transferred. | TC pin validity bit: Bit 1 at address 6816 ### 13.8 Link array chain transfer mode Fig. 13.8.1 Register structures of SARi, DARi, and TCRi in link array chain transfer mode ## 13.8 Link array chain transfer mode #### 13.8.1 Transfer parameter memory in link array chain transfer mode The transfer parameters required for each transfer method are described below. These parameters can be located in separate memory locations, in a unit of one block's parameters. However, these parameters must be located <u>starting at an even address</u>. Figure 13.8.2 shows a transfer parameter memory map in the link array chain transfer mode. #### (1) In 2-bus cycle transfer All of the following transfer parameters are required for each block of data; that is, a transfer parameter memory consumes 16 bytes for each block. - Transfer source's transfer start address (24 bits) + Dummy data (8 bits) - Transfer destination's transfer start address (24 bits) + Dummy data (8 bits) - Transfer data's byte number (24 bits) + Dummy data (8 bits) - Start address of next transfer parameter memory (24 bits) (Note) + Dummy data (8 bits) #### (2) In 1-bus cycle transfer from memory to I/O All of the following transfer parameters are required for each block of data; that is, a transfer parameter memory consumes 12 bytes for each block. - Transfer source's transfer start address (24 bits) + Dummy data (8 bits) - Transfer data's byte number (24 bits) + Dummy data (8 bits) - Start address of next transfer parameter memory (24 bits) (Note) + Dummy data (8 bits) #### (3) In 1-bus cycle transfer from I/O to memory All of the following transfer parameters are required for each block of data; that is, a transfer parameter memory consumes 12 bytes for each block. - Transfer destination's transfer start address (24 bits) + Dummy data (8 bits) - Transfer data's byte number (24 bits) + Dummy data (8 bits) - Start address of next transfer parameter memory (24 bits) (Note) + Dummy data (8 bits) **Note:** For the last block of data, write "00000016" as the start address of the next transfer parameter memory. Fig. 13.8.2 Transfer parameter memory map in link array chain transfer mode ## 13.8 Link array chain transfer mode #### 13.8.2 Setting of link array chain transfer mode Figures 13.8.3 through 13.8.5 show an initial setting example for registers relevant to the link array chain transfer mode. In addition, when timer A, timer B, UART, or the A-D converter is selected as a DMA request source, the setting for the peripheral is required. For details of the setting, refer to the chapter of each peripheral function. When a DMAi interrupt is used, the setting for enabling the interrupt is also required. For details, refer to "CHAPTER 7. INTERRUPTS." Fig. 13.8.3 Initial setting example for registers relevant to link array chain transfer mode (1) Fig. 13.8.4 Initial setting example for registers relevant to link array chain transfer mode (2) Fig. 13.8.5 Initial setting example for registers relevant to link array chain transfer mode (3) ## 13.8 Link array chain transfer mode #### 13.8.3 Operation in link array chain transfer mode Figure 13.8.6 shows the operation flowchart of the link array chain transfer mode, and Figures 13.8.7 and 13.8.8 show timing diagrams of the link array chain transfer mode (burst transfer mode). In addition, Figure 13.8.9 shows the conditions necessary for timings shown in Figures 13.8.7, 13.8.8, and 13.8.10 through 13.8.14. For the cycle-steal transfer mode, refer to the following: - Transfer of transfer parameters in an array state: Figures 13.8.10 and 13.8.11 - All transfers except for that in an array state and except for the last 1-unit transfer of each block: Figure 13.8.12 - Last 1-unit transfer of each block except for the last block: Figure 13.8.13 - Last 1-unit transfer of the last block: Figure 13.8.14 The processing performed in the link array chain transfer mode consists of an array state and a transfer state. #### (1) Array state In an array state, transfer parameters are read from the transfer parameter memory in a unit of 2 bytes and transferred to registers SARi, DARi, and TCRi and their latches. As shown in Figure 13.8.2, a transfer parameter consists of 4 bytes (24 bits of data + 8 bits of dummy data). One bus cycle always consumes 3 cycles of $\phi$ . During an array state, the DMAACKi pin outputs "H" level. For the bus request sampling in an array state, refer to section "13.2.1 Bus access control circuit." #### (2) Transfer state Data is transferred in a transfer state. For the bus request sampling in a transfer state, refer to section "13.2.1 Bus access control circuit." Fig. 13.8.6 Operation flowchart of link array chain transfer mode Fig. 13.8.7 Timing diagram of link array chain transfer mode (burst transfer mode) (1) Fig. 13.8.8 Timing diagram of link array chain transfer mode (burst transfer mode) (2) # 13.8 Link array chain transfer mode Figure 13.8.9 shows the conditions necessary for timings shown in Figures 13.8.7, 13.8.8, and 13.8.10 through 13.8.14. Fig. 13.8.9 Conditions necessary for timings shown in Figures 13.8.7, 13.8.8, and 13.8.10 through 13.8.14 Fig. 13.8.10 Timing diagram of cycle-steal transfer mode (1) Fig. 13.8.11 Timing diagram of cycle-steal transfer mode (2) ## 13.8 Link array chain transfer mode #### • 1-unit transfer - 1-unit transfer is performed with a DMAi request on the following conditions: - Single transfer mode (except for the last 1-unit transfer) - Repeat transfer mode (except for the last 1-unit transfer of block) - Array chain transfer mode (except for the first and last 1-unit transfers of each block) - Link array chain transfer mode (except for the first and last 1-unit transfers of each block) - The above figure is the example of the second 1-unit transfer for processing the first block in "Figure 13.8.9." - The Bus request caused by DRAM refresh, Hold, or DMA is sampled while the Bus request sampling signal is "H," and is accepted. Fig. 13.8.12 Timing diagram of cycle-steal transfer mode (3) ## 13.8 Link array chain transfer mode #### ● Last transfer of each block At the last term (except for the last block) for processing of each block in the repeat, array chain, and link array chain transfer modes, 1-unit transfer is performed with one DMAi request, and the right to use bus is relinquished after 3 cycles of $\phi$ . - The above figure is the example of the last term for processing the first block in "Figure 13.8.9." - The Bus request caused by DRAM refresh, Hold, or DMA is sampled while the bus request sampling signal is "H," and is accepted. Fig. 13.8.13 Timing diagram of cycle-steal transfer mode (4) Fig. 13.8.14 Timing diagram of cycle-steal transfer mode (5) 13.8 Link array chain transfer mode ## [Precautions for link array chain transfer mode] If the following two conditions are satisfied when the transfer unit is 16 bits and the address direction of transfer source or destination is fixed, the link array chain transfer mode can be used: - The external data bus width = 16 bits or the internal memory is used. - The transfer start address on the address-direction-fixed side is an even address. #### 13.9 DMA transfer time #### 13.9 DMA transfer time Calculation of time from the CPU's relinquishing the right to use bus until its regaining the right under the following conditions is described with reference to cycles of $\phi$ : - A DMAi request is generated while the CPU holds the right to use bus. - The above right is returned to the CPU after completion of DMA transfer for one DMA request. For the time per 1-unit transfer, refer to section "13.4.1 (2) Bus operation in 2-bus cycle transfer" and section "13.4.2 (2) Bus operation in 1-bus cycle transfer." Also, for the time from DMA request generation until the start of the DMA transfer, refer to section "13.3.4 Processing from DMA request until DMA transfer execution": and for that from issuing instructions for forced termination until returning the right to use bus to the CPU, refer to section "13.3.5 (2) Forced termination." #### 13.9.1 Cycle-steal transfer mode #### (1) 1-unit transfer In the following cases, 1-unit transfer is performed at one DMAi transfer. (Refer to "Figure 13.8.12.") - Single transfer mode: except for the last 1-unit transfer - Repeat transfer mode: except for the last 1-unit transfer of a block - Array chain transfer mode: except for the first and last 1-unit transfers of each block - Link array chain transfer mode: except for the first and last 1-unit transfers of each block Fig. 13.9.1 1-unit transfer - ① Transition of the right to use bus from CPU to DMAC: 1 cycle - ② DMA transfer per 1-transfer unit: - In 2-bus cycle transfer···Read cycle + Write cycle (Add a value which satisfies the read/write conditions. Refer to "Table 13.4.1.") - In 1-bus cycle transfer...Refer to "Table 13.4.5." - 3 Transition of the right to use bus from DMAC to CPU: 1 cycle ## [Example] 2-bus cycle transfer, transfer unit =16 bits, external data bus width = 16 bits, and under the following conditions: - Transfer source: address direction = forward, start address of data = even, with Wait - Transfer destination: address direction = backward, start address of data = even, without Wait $$\bigcirc$$ + $\bigcirc$ + $\bigcirc$ = 1 + $\bigcirc$ + 4) + 1 = 9 cycles 13.9 DMA transfer time #### (2) Last transfer of each block In the following cases, 1-unit transfer and the processing for 3 cycles are performed sequentially. (Refer to "Figures 13.8.13 and 13.8.14.") - Single transfer mode: the last 1-unit transfer - Repeat transfer mode: the last 1-unit transfer of a block - Array chain transfer mode: the last 1-unit transfer of each block (including the last block) - Link array chain transfer mode: the last 1-unit transfer of each block (including the last block) Fig. 13.9.2 Last transfer of each block - ① Transition of the right to use bus from CPU to DMAC: 1 cycle - 2 DMA transfer per 1-unit transfer: - In 2-bus cycle transfer---Read cycle + Write cycle (Add a value which satisfies the read/write conditions. Refer to "Table 13.4.1.") - In 1-bus cycle transfer...Refer to "Table 13.4.5." - 3 Terminate processing or the last processing of each block: 3 cycles - 4 Transition of the right to use bus from DMAC to CPU: 1 cycle #### [Example] 2-bus cycle transfer, transfer unit =16 bits, external data bus width = 16 bits, and under the following conditions: - Transfer source: address direction = forward, start address of data = even, with Wait - Transfer destination: address direction = backward, start address of data = even, without Wait ① + ② + ③ + ④ = 1 + (3 + 4) + 3 + 1 = 12 cycles ## 13.9 DMA transfer time #### (3) Transfer of array state In the following cases, the processing in an array state and the first 1-unit transfer are performed sequentially. (Refer to "Figures 13.8.10 and 13.8.11.") - Array chain transfer mode: the first transfer of each block - Link array chain transfer mode: the first transfer of each block Fig. 13.9.3 Transfer of array state - ① Transition of the right to use bus from CPU to DMAC: 1 cycle - ② Array state: The number of transfer parameters $\times$ the number of reads of a transfer parameter $\times$ the number of bus cycles for a read + 1 cycle (Refer to "Table 13.9.1.") - 3 DMA transfer per 1-unit transfer: - In 2-bus cycle transfer···Read cycle + Write cycle (Add a value which satisfies the read/write conditions. Refer to "Table 13.4.1.") - In 1-bus cycle transfer...Refer to "Table 13.4.5." - 4 Transition of the right to use bus from DMAC to CPU: 1 cycle #### [Example] Link array chain transfer mode, external data bus width = 16 bits, 2-bus cycle transfer, transfer unit =16 bits, and under the following conditions: - Transfer source: address direction = forward, start address of data = even, with Wait - Transfer destination: address direction = backward, start address of data =odd, with Wait ① + ② + ③ + ④ = 1 + 25 + (3 + 4) + 1 = 34 cycles Table 13.9.1 Time required for processing in array state | NA - I - | External data | T ( (l l | Number of transfer | Number of reads of | Time required for | | |------------------|--------------------------|----------------------|--------------------|----------------------|--------------------------------|--| | Mode | bus width | Transfer method | parameters | a transfer parameter | processing in array state | | | | Dus Width | | | | (Unit: φ cycle) | | | Array chain | 16 bits | 2-bus cycle transfer | 3 | 2 | $3 \times 2 \times 3 + 1 = 19$ | | | transfer mode | (Including internal bus) | 1-bus cycle transfer | 2 | 2 | $2 \times 2 \times 3 + 1 = 13$ | | | | 8 bits | 2-bus cycle transfer | 3 | 4 | $3 \times 4 \times 3 + 1 = 37$ | | | | | 1-bus cycle transfer | 2 | 4 | $2 \times 4 \times 3 + 1 = 25$ | | | Link array chain | 16 bits | 2-bus cycle transfer | 4 | 2 | $4 \times 2 \times 3 + 1 = 25$ | | | transfer mode | (Including internal bus) | 1-bus cycle transfer | 3 | 2 | $3 \times 2 \times 3 + 1 = 19$ | | | | 8 bits | 2-bus cycle transfer | 4 | 4 | $4 \times 4 \times 3 + 1 = 49$ | | | | C Sito | 1-bus cycle transfer | 3 | 4 | $3 \times 4 \times 3 + 1 = 37$ | | 13.9 DMA transfer time #### 13.9.2 Burst transfer mode #### (1) Single transfer mode Fig. 13.9.4 Single transfer mode (burst transfer mode selected) - ① Transition of the right to use bus from CPU to DMAC: 1 cycle - 2 DMA transfer per an entire batch of data: - In 2-bus cycle transfer...(Read cycle + Write cycle\*1) × the number of transfers\*2 - \*1: Add a value which satisfies the read/write conditions. Refer to "Table 13.4.1." - \*2: When the transfer unit is 16 bits, the number of transfers = the number of transfer bytes/2 When the transfer unit is 8 bits, the number of transfers = the number of transfer bytes - In 1-bus cycle transfer...Refer to "Table 13.4.5." - 3 Terminate processing: 3 cycles - 4 Transition of the right to use bus from DMAC to CPU: 1 cycle #### [Example] External data bus width = 16 bits, 2-bus cycle transfer, transfer unit =16 bits, the number of the transfer bytes = 10 bytes, and under the following conditions: - Transfer source: address direction = forward, start address of data = even, with Wait - Transfer destination: address direction = backward, start address of data = even, without Wait ① + ② + ③ + ④ = 1 + 5 (3 + 4) + (3 + 1) = 40 cycles #### 13.9 DMA transfer time #### (2) Repeat transfer mode In the repeat transfer mode of burst transfer (edge sense), the method of terminating DMA transfer is only the forced termination by the $\overline{TC}$ input. Therefore, the time from the CPU's relinquishing the right to use bus until regaining the right depends on the timing of the $\overline{TC}$ input. Fig. 13.9.5 Repeat transfer mode (burst transfer mode and edge sense selected) - ① Transition of the right to use bus from CPU to DMAC: 1 cycle - 2 DMA transfer per 1 block: - In 2-bus cycle transfer...(Read cycle + Write cycle\*1) × the number of transfers\*2 - \*1: Add a value which satisfies the read/write conditions. Refer to "Table 13.4.1." - \*2: When the transfer unit is 16 bits, the number of transfers = the number of transfer bytes/2 When the transfer unit is 8 bits, the number of transfers = the number of transfer bytes - In 1-bus cycle transfer···Refer to "Table 13.4.5." - 3 Terminate processing: 3 cycles - ④ DMA transfer of the block at the TC input: above ② The number of transfers is assumed to be up to the DMA transfer of 1-unit transfer which was in progress at the TC input. - ⑤ Transition of the right to use bus from DMAC to CPU: 1 cycle #### [Example] External data bus width = 16 bits, 2-bus cycle transfer, transfer unit =16 bits, the number of the transfer bytes = 10 bytes, and under the following conditions: - Transfer source: address direction = forward, start address of data = even, with Wait - Transfer destination: address direction = backward, start address of data = even, without Wait - $\overline{TC}$ is input when the "m"th byte (m = even) of the "n"th block is in transfer. ① + $$(n-1)(2+3)+4+5=1+(n-1){5(3+4)+3}+m/2+1=38n+m/2-36$$ cycles #### 13.9 DMA transfer time #### (3) Array chain transfer mode and Link array chain transfer mode Fig 13.9.6 Array chain transfer mode and Link array chain transfer mode - ① Transition of the right to use bus from CPU to DMAC: 1 cycle - ② Array state: The number of transfer parameters $\times$ the number of reads of a transfer parameter $\times$ the number of bus cycles for a read + 1 cycle (Refer to "Table 13.9.1.") - 3 DMA transfer per an entire batch of data: - In 2-bus cycle transfer...(Read cycle + Write cycle\*1) × the number of transfers\*2 - \*1: Add a value which satisfies the read/write conditions. Refer to "Table 13.4.1." - \*2: When the transfer unit is 16 bits, the number of transfers = the number of transfer bytes/2 When the transfer unit is 8 bits, the number of transfers = the number of transfer bytes - In 1-bus cycle transfer...Refer to "Table 13.4.5." - 4 Last processing of each block: 3 cycles - ⑤ Terminate processing: 3 cycles - ® Transition of the right to use bus from DMAC to CPU: 1 cycle #### [Example] Array chain transfer mode, external data bus width = 16 bits, 2-bus cycle transfer, transfer unit =16 bits, the number of transfer blocks = 3, and under the following conditions: - Transfer source: address direction = forward, without Wait - Transfer destination: address direction = backward, without Wait - First block: transfer source's data start address = even, transfer destination's data start address = even, the number of transfer bytes =10 bytes - Second block: transfer source's data start address = even, transfer destination's data start address = odd, the number of transfer bytes = 12 bytes - Third block: transfer source's data start address =odd, transfer destination's data start address =odd, the number of transfer bytes =14 bytes $$0 + 2 + 3 + 4 + 2 + 3 + 4 + 2 + 3 + 5 + 6$$ = 1 + 19 + 5(2 + 4) + 3 + 19 + 6(2 + 3) + 3 + 19 + 7(4 + 3) + 3 + 1 = 177 cycles 13.9 DMA transfer time **MEMORANDUM** - 14.1 Overview - 14.2 Block description - 14.3 Setting for DRAMC - 14.4 DRAMC operation - 14.5 Precautions for DRAMC ## 14.1 Overview, 14.2 Block description #### 14.1 Overview Table 14.1.1 lists the performance specifications of DRAM controller (hereafter called DRAMC). Table 14.1.1 Performance specifications of DRAMC | Item | Performance specifications | | | | |--------------------------|---------------------------------------------------|--|--|--| | DRAM area | 0 to 15 Mbytes; programmable in a unit of 1 Mbyte | | | | | Refreshing method | CAS before RAS; dispersive refreshing | | | | | Refresh timer | 8 bits | | | | | Multiplexed address pins | 10 | | | | # 14.2 Block description Figure 14.2.1 shows the block diagram of DRAMC. Registers relevant to DRAMC are described below. Fig. 14.2.1 Block diagram of DRAMC 14.2 Block description #### 14.2.1 DRAM control register Figure 14.2.2 shows the structure of the DRAM control register. Fig. 14.2.2 Structure of DRAM control register ## 14.2 Block description #### (1) DRAM area select bits (bits 0 to 3) These 4 bits specify a DRAM area of 15 Mbytes maximum in a unit of 1 Mbyte. Figure 14.2.3 shows setting examples of DRAM areas. Fig. 14.2.3 Setting examples of DRAM areas #### (2) DRAM validity bit (bit 7) When this bit is set to "1," pin functions for DRAM control become valid, and the refresh timer starts counting. Table 14.2.1 lists the pin functions for DRAM control. Table 14.2.1 Pin functions for DRAM control | | | Pins | | | | | | |--------------|--------------|----------------------------------|-------------------------------------|------------------------------------|-------------------------------------------------------------------------|-----------|--| | DRAM | Operation | A <sub>0</sub> /MA <sub>0</sub> | P106/MA8, | P104/CAS, | A <sub>16</sub> /D <sub>0</sub> -A <sub>23</sub> /D <sub>7</sub> , | ST0, ST1 | | | validity bit | | $-A_7/MA_7$ | P107/MA9 | P10₅/RAS | A8/D8-A15/D15, | | | | | | | | | R/W, Ē, BLE, BHE | | | | | Accessing | MA <sub>0</sub> –MA <sub>7</sub> | MA <sub>8</sub> , MA <sub>9</sub> | CAS, RAS | A <sub>16</sub> /D <sub>0</sub> -A <sub>23</sub> /D <sub>7</sub> , | ST0, ST1 | | | | DRAM area | | | | A8/D8-A15/D15, | | | | | | | | | R/W, E, BLE, BHE | | | | 1 | DRAM refresh | $A_0 - A_7$ | MA <sub>8</sub> , MA <sub>9</sub> | CAS, RAS | A <sub>16</sub> /D <sub>0</sub> -A <sub>23</sub> /D <sub>7</sub> , | ST0, ST1 | | | | | | | | A8/D8-A15/D15 | ([0,0] is | | | | | | | | R/W, E, BLE, BHE | output.) | | | | Other than | A <sub>0</sub> -A <sub>7</sub> | MA <sub>8</sub> , MA <sub>9</sub> | CAS, RAS | A <sub>16</sub> /D <sub>0</sub> -A <sub>23</sub> /D <sub>7</sub> , | ST0, ST1 | | | | the above | | | | A8/D8-A15/D15, | | | | | | | | | R/W, E, BLE, BHE | | | | | | A <sub>0</sub> -A <sub>7</sub> | P10 <sub>6</sub> , P10 <sub>7</sub> | P10 <sub>4</sub> ,P10 <sub>5</sub> | A <sub>16</sub> /D <sub>0</sub> -A <sub>23</sub> /D <sub>7</sub> , | ST0, ST1 | | | 0 | _ | | | | A8/D8-A15/D15 | | | | | | | | | $R/\overline{W}$ , $\overline{E}$ , $\overline{BLE}$ , $\overline{BHE}$ | | | 14.2 Block description #### 14.2.2 Refresh timer The refresh timer is an 8-bit timer with a reload register and is used to generate refresh requests for DRAM data. Assuming that the set value of the refresh timer = "n," the refresh timer counts $f_{16}$ (n + 1) times. Figure 14.2.4 shows the structure of the refresh timer, and the following formula gives the value to be written to the refresh timer. $$n = \{m \ [\mu s] \ X \ \frac{f(X_{IN})}{16}\} - 1$$ n: a set value of the refresh timer (n = $01_{16}$ -FF<sub>16</sub>) m:a refresh interval Examples of "m": an average of 15.625 $\mu$ s for 512 refresh cycles at 8-ms intervals an average of 125 $\mu$ s for 512 refresh cycles at 64-ms intervals Fig. 14.2.4 Structure of refresh timer ## 14.2 Block description #### 14.2.3 Address comparator The address comparator examines whether the address to be accessed is within the DRAM area. When this address is within DRAM area, control signals are sent to the $\overline{RAS}$ and $\overline{CAS}$ generating circuit and the address multiplexer. #### 14.2.4 RAS and CAS generating circuit The RAS signal (a timing signal to latch a row address) and the CAS signal (a timing signal to latch a column address) are generated by a control signal from the address comparator. #### 14.2.5 Address multiplexer Address data is time-shared by the control signal from the address comparator and is output to the MA $_{0}$ –MA $_{9}$ pins. The time-sharing method depends on the external bus width. Table 14.2.2 lists the time-sharing method for the address at DRAM access. When the 8-bit external bus width is selected, A $_{0}$ –A $_{19}$ are time-shared and are output; when the 16-bit external bus width is selected, A $_{1}$ –A $_{20}$ are time-shared and are output. Table 14.2.2 Time-sharing method for address at DRAM access | | Pin name | | Ao/MAo | A <sub>1</sub> /MA <sub>1</sub> | A <sub>2</sub> /MA <sub>2</sub> | A <sub>3</sub> /MA <sub>3</sub> | A <sub>4</sub> /MA <sub>4</sub> | A <sub>5</sub> /MA <sub>5</sub> | A <sub>6</sub> /MA <sub>6</sub> | A7/MA7 | P106/MA8 | P107/MA9 | |-----|----------------|----------------|-----------------|---------------------------------|---------------------------------|---------------------------------|---------------------------------|---------------------------------|---------------------------------|-----------------|-----------------|-----------------| | | 8-bit external | Row address | Ao | <b>A</b> 1 | $A_2$ | Аз | A <sub>4</sub> | <b>A</b> 5 | $A_6$ | <b>A</b> 7 | <b>A</b> 16 | <b>A</b> 18 | | sig | bus width | Column address | A8 | <b>A</b> 9 | <b>A</b> <sub>10</sub> | <b>A</b> <sub>11</sub> | A <sub>12</sub> | A <sub>13</sub> | <b>A</b> 14 | A <sub>15</sub> | A <sub>17</sub> | <b>A</b> 19 | | | | Row address | A <sub>16</sub> | <b>A</b> 1 | <b>A</b> <sub>2</sub> | Аз | A <sub>4</sub> | <b>A</b> 5 | A <sub>6</sub> | A <sub>7</sub> | A <sub>18</sub> | A <sub>20</sub> | | Out | bus width | Column address | A8 | <b>A</b> 9 | <b>A</b> <sub>10</sub> | <b>A</b> 11 | A <sub>12</sub> | <b>A</b> 13 | A <sub>14</sub> | A <sub>15</sub> | A <sub>17</sub> | <b>A</b> 19 | ## 14.3 Setting for DRAMC Figure 14.3.1 shows an initial setting example for registers relevant to DRAMC. Fig. 14.3.1 Initial setting example for registers relevant to DRAMC ## 14.4 DRAMC operation ## 14.4 DRAMC operation #### 14.4.1 Waveform example of DRAM control signals Figure 14.4.1 shows a waveform example of the DRAM control signals. When DRAM is accessed, the bus cycle is always with "wait" (the low-level width of $\overline{E}$ is equivalent to 2 cycles of $\phi$ ). It is not affected by the wait bit, the wait bit of the transfer source, and the wait bit of the transfer destination. #### (1) Read Cycle In the read cycle, the CAS signal falls with a delay of 0.5 cycle of $\phi$ after the RAS signal has changed from "H" to "L." The <u>address</u> bus signal <u>changes</u> from "row address" to "column address" within a period from a fall of RAS until a fall of <u>CAS</u>. Pins $A_{16}/D_0$ – $A_{23}/D_7$ and $A_8/D_8$ – $A_{15}/D_{15}$ output addresses and input data in the same way as in reading external devices other than DRAM. #### (2) Write Cycle In the write cycle, the CAS signal falls with a delay of 1 cycle of $\phi$ after the RAS signal has changed from "H" to "L." The address bus signal changes "row address" to "column address" within a period from a fall of $\overline{RAS}$ until a fall of $\overline{CAS}$ . Pins $A_{16}/D_0$ – $A_{23}/D_7$ and $A_8/D_8$ – $A_{15}/D_{15}$ output addresses and data in the same way as in writing external devices other than DRAM. ## (3) Refresh Cycle In the refresh cycle, the RAS signal falls with a delay of 0.5 cycle of $\phi$ after the CAS signal has changed from "H" to "L." R/W is undefined. One refresh request requires 5 cycle of $\phi$ , including the time for passing the right to use buses. 14.4 DRAMC operation Fig. 14.4.1 Waveform example of DRAM control signals ## 14.4 DRAMC operation #### 14.4.2 Refresh request - ① When the DRAM validity bit is set to "1," the refresh timer starts counting down. The count source is $f_{16}$ . - ② When the contents of the refresh timer reach "00<sub>16</sub>," a refresh request occurs. The refresh timer reloads the contents of address 66<sub>16</sub> and continues counting. - ③ Refresh requests are sampled as bus requests (DRAMC) by using the bus access controller. As soon as a refresh request is acknowledged by sampling, the following ⊕ is performed because DRAM refresh has the highest priority in using the bus. However, when the CPU or DMAC uses the bus, no bus request is sampled until the CPU or DMAC releases the bus. Therefore, in a period from when a refresh request occurs until DRAM refresh is performed, the delay listed in Table 14.4.1 occurs depending on the refresh request generating timing. Figures 14.4.2 and 14.4.3 show refresh delay time examples when CPU is operating and during DMA transfer. For a bus request, refer to "13.2.1 Bus access control circuit." - 4 When the refresh request is accepted, the right to use the bus is passed to DRAM refresh (1 cycle of $\phi$ ). Both of the output levels of ST1 and ST0 are "L." (The bus status is indicated as [0, 0].) - ⑤ The $\overline{RAS}$ and the $\overline{CAS}$ signals are output and the DRAM data is refreshed (refresh cycle: 3 cycles of $\phi$ ). - ® The right to use the bus is passed to the CPU, DRAM or Hold (1 cycle of $\phi$ ). The outputs of ST1 and ST0 change. Note: In Stop or Wait mode, DRAM refresh is not performed because no refresh request occurs. Table 14.4.1 Delay time from when refresh request occurs until DRAM refresh is performed | Source of using bus | | Delay time (unit: $\phi$ cycle) | | | | | |---------------------|--------------------------------------------------|---------------------------------|-------------------|---------------------|--|--| | | | Minimum | Maximum (no Wait) | Maximum (with Wait) | | | | | CPU | 1.5 | 4.5 | 6.5 | | | | | Transfer (a unit of 1 transfer) | 1.5 | 8.5 | 12.5 | | | | DMAC | Transfer (a unit of 1 transfer) + Complete cycle | | 11.5 | 15.5 | | | | | Array state | | 6.5 | 6.5 | | | | Hold | | 1.5 | 1.5 | 1.5 | | | **Note:** The above is applied when Ready is not used. The delay time includes the time for passing the right to use buses to DRAM refresh (1 cycle). Fig. 14.4.2 Refresh delay time example when CPU is operating Fig. 14.4.3 Refresh delay time example during DMA transfer ## 14.5 Precautions for DRAMC ## 14.5 Precautions for DRAMC - 1. Set the refresh timer (address 6616) to any of 0116-FF16. - 2. When a DRAM refresh request occurs during Hold state, a refresh cycle is activated regardless of the bus state. It is because a bus request is always sampled during Hold state. Therefore, in order to use the DRAMC together with the Hold function, an external circuit which is controlled depending on the states of ST0 and ST1 is required. - 3. DRAM refresh is not performed in Stop or Wait mode. - 15.1 Block description - 15.2 Operation description - 15.3 Precautions for Watchdog timer #### 15.1 Block description Watchdog functions as follows: - Detects a program runaway. - Measures a certain time from when oscillation starts owing to terminating Stop mode. (Refer to section "5.3 Stop mode.") # 15.1 Block description Figure 15.1.1 shows the block diagram of Watchdog timer. Fig. 15.1.1 Block diagram of Watchdog timer #### 15.1 Block description #### 15.1.1 Watchdog timer Watchdog timer is a 12-bit counter where the count source which is selected with the watchdog timer frequency select bit (bit 0 at address 61<sub>16</sub>) is counted down. A value "FFF<sub>16</sub>" is automatically set in Watchdog timer in the cases listed below. An arbitrary value cannot be set to Watchdog timer. - When dummy data is written to the watchdog timer register (Refer to "Figure 15.1.2.") - When the most significant bit of Watchdog timer becomes "0" - When the STP instruction is executed (Refer to section "5.3 Stop mode.") - At reset Fig. 15.1.2 Structure of watchdog timer register #### 15.1.2 Watchdog timer frequency select register This is used to select a Watchdog timer's count source. Figure 15.1.3 shows the structure of the watchdog timer frequency select register. Fig. 15.1.3 Structure of watchdog timer frequency select register #### 15.2 Operation description ### 15.2 Operation description #### 15.2.1 Basic operation - ① Watchdog timer starts counting down from "FFF16." - When the Watchdog timer's most significant bit becomes "0" (counted 2048 times), a watchdog timer interrupt request occurs. (Refer to "Table 15.2.1.") - ③ When the interrupt request occurs at above ②, a value "FFF16" is set to Watchdog timer. The watchdog timer interrupt is a non-maskable interrupt. When the watchdog timer interrupt request is accepted, the processor interrupt priority level (IPL) is set to "1112." Table 15.2.1 Occurrence interval of watchdog timer interrupt request | Watchdog timer | $f(X_{IN}) = 25 \text{ MHz}$ | | | |----------------------|------------------------------|---------------------|--| | frequency select bit | Count source | Occurrence interval | | | 0 | <b>f</b> <sub>512</sub> | 41.94 ms | | | 1 | <b>f</b> 32 | 2.62 ms | | #### 15.2 Operation description Write dummy data to the watchdog timer register (address 60<sub>16</sub>) before the most significant bit of Watchdog timer becomes "0." When Watchdog timer is used to detect a program runaway, a watchdog timer interrupt request occurs if writing to address 60<sub>16</sub> is not performed owing to a program runaway and the most significant bit of Watchdog timer becomes "0." This means that a program runaway has occurred. In order to reset the microcomputer when a program runaway is detected, write "1" to the software reset bit (bit 3 at address 5E<sub>16</sub>) in the watchdog timer interrupt routine. Fig. 15.2.1 Example of program runaway detection by Watchdog timer #### 15.2 Operation description #### 15.2.2 Stop period Watchdog timer stops operation in the following period: - ① Hold state (Refer to section "3.4 Hold function.") - ② During DMAC operation (Refer to "CHAPTER 13. DMA CONTROLLER.") - 3 During DRAM refresh (Refer to "CHAPTER 14. DRAM CONTROLLER.") - 4 Stop mode When states ① to ③ are terminated, Watchdog timer restarts counting from the state before it stops operation. For Watchdog timer's operation when state ④ is terminated, refer to section "15.2.3 Operation in Stop mode." #### 15.2.3 Operation in Stop mode In Stop mode, Watchdog timer stops operation. Immediately after Stop mode is terminated, Watchdog timer operates as follows. (Refer to section "5.3 Stop mode.") #### (1) When Stop mode is terminated by hardware reset Supply of $\phi$ and $\phi_{\text{CPU}}$ starts immediately after Stop mode is terminated, and the microcomputer performs "operation after reset." (Refer to "**CHAPTER 4. RESET.**") The watchdog timer frequency select bit becomes "0," and Watchdog timer starts counting of $f_{512}$ from "FFF<sub>16</sub>." #### (2) When Stop mode is terminated by interrupt request occurrence Immediately after Stop mode is terminated, Watchdog timer starts counting of $f_{32}$ from "FFF<sub>16</sub>" regardless of the contents of watchdog timer frequency select bit (bit 0 at address $61_{16}$ ). Supply of $\phi$ and $\phi_{CPU}$ starts when Watchdog timer's most significant bit becomes "0." (At this time, a watchdog timer interrupt request does not occur.) When supply of $\phi_{\text{CPU}}$ starts, the microcomputer executes the routine of the interrupt which is used to terminate Stop mode. Watchdog timer restarts counting of the count source (f<sub>32</sub> or f<sub>512</sub>), which was counted immediately before executing the **STP** instruction, from "FFF<sub>16</sub>." #### 15.3 Precautions for Watchdog timer ### 15.3 Precautions for Watchdog timer - 1. When dummy data is written to address 60<sub>16</sub> with the 16-bit data length, writing to address 61<sub>16</sub> is simultaneously performed. Accordingly, when the user does not want to change a value of the watchdog timer frequency select bit (bit 0 at address 61<sub>16</sub>), write the previous value to the bit simultaneously with writing to address 60<sub>16</sub>. - 2. When the STP instruction is executed, Watchdog timer stops. (Refer to section "5.3 Stop mode.") - 3. Watchdog timer stops during DRAM refresh, hold state, and DMAC operation. (For Watchdog timer's structure, refer to "Figure 15.1.1.") Accordingly, when a bus request is changed in the period which is shorter than 1 cycle of the count source (Note), Watchdog timer's count may gain. (Refer to "Figure 15.3.1.") Note: f<sub>32</sub> or f<sub>512</sub>, which is selected by the watchdog timer frequency select bit Fig. 15.3.1 Count source for Watchdog timer 15.3 Precautions for Watchdog timer **MEMORANDUM** # CHAPTER 16 # **APPLICATION** - 16.1 Memory connection - 16.2 Examples of using DMA controller - 16.3 Comparison of sample program execution rate #### 16.1 Memory connection This chapter describes application. Application shown here is just examples. The user shall modify them according to the actual application and test them. # 16.1 Memory connection This section shows examples for memory and I/O connection. Refer to "CHAPTER 3. CONNECTION WITH EXTERNAL DEVICES" for details about the functions and operations of used pins when connecting a memory or I/O. Refer to section "Appendix 11. Electrical characteristics" for timing requirements of the microcomputer. #### 16.1.1 Memory connection model For the M37721, the level of the external data bus width select signal makes it possible to select the memory connection model from the four models listed in Table 16.1.1. #### (1) Minimum model This is a connection model of which external data bus width is 8 bits and access space is expanded up to 64 Kbytes. It is unnecessary to connect the address latch externally, so this model gives priority to cost and is most suitable when connecting the memory of which data bus width is 8 bits. #### (2) Medium model A This is a connection model of which external data bus width is 8 bits and access space is expanded up to 16 Mbytes. In this model, the high-order 8 bits of the external address bus ( $A_{16}$ to $A_{23}$ ) are multiplexed with the external data bus. Therefore, an n-bit ( $n \le 8$ ) address latch is required for latching n bits of the address in $A_{16}$ to $A_{23}$ . #### (3) Medium model B This is a connection model of which external data bus width is 16 bits and access space is expanded up to 64 Kbytes. This model gives priority to rate performance. In this model, the middle-order 8 bits of the external address bus ( $A_8$ to $A_{15}$ ) are multiplexed with the external data bus. Therefore, an 8-bit address latch is required for latching $A_8$ to $A_{15}$ . #### (4) Maximum model This is a connection model of which external data bus width is 16 bits and access space is expanded up to 16 Mbytes. In this model, the high- and middle-order 16 bits of the external address bus ( $A_8$ to $A_{23}$ ) are multiplexed with the external data bus. Therefore, an 8-bit address latch for latching $A_8$ to $A_{15}$ and an n-bit ( $n \le 8$ ) address latch for latching n bits of $A_{16}$ to $A_{23}$ are required. Table 16.1.1 Memory connection model Notes 1: Refer to "CHAPTER 3. CONNECTION WITH EXTERNAL DEVICES" for details about the functions and operations of used pins when connecting a memory. Refer to section "Appendix 11. Electrical characteristics" for timing requirements. <sup>2:</sup> Because the address bus can be expanded up to 24 bits when connecting a memory, strengthen the M37721's Vss and Vcc lines on the system. (Refer to section "Appendix 8. Countermeasure against noise.") #### 16.1 Memory connection #### 16.1.2 How to calculate timing Timings at which data is read or written when connecting a memory and precautions when connecting a memory are described below. For timing requirements of the memory and detailed account except limits described below, also refer to the memory's Data book etc. When using bus buffers, various logical circuits, etc., be sure to consider the propagation delay time etc. #### (1) Timing for reading data When reading data, the external data bus is placed in a floating state, and data is read from the external memory. This floating state is maintained after the falling edge of the $\overline{E}$ signal until an interval of $t_{pzx(E-DLZ/DHZ)}$ has passed after the rising edge of the $\overline{E}$ signal. Satisfy $t_{su(DL/DH-E)}$ when inputting data read from the external memory. The following are described below: - •Timing for reading data from the flash memory, SRAM, and DRAM - •Calculation formulas for the external memory's access time, which are for $t_{su(DL/DH-E)}$ to be satisfied The memory output enable signal ( $\overline{OE}$ ) is assumed to be generated from the $\overline{E}$ signal. #### • Timing for reading data from flash memory and SRAM Fig. 16.1.1 Timing for reading data from flash memory and SRAM #### 16.1 Memory connection Address access time : $t_{a(AD)} \le t_{su(A-DL/DH)} - address$ latch delay time\*1 $\overline{\text{OE}}$ access time : $t_{\text{a(OE)}} \leq t_{\text{w(EL)}} - t_{\text{su(DL/DH-E)}}$ Chip select access time : $t_{a(S)} \le t_{su(A-DL/DH)} - (address decode time^{*2} + address latch delay time^{*1})$ Address latch delay time\*1: Delay time required when latching address (Unnecessary in minimum model) Address decode time\*2: Time required for validating chip select signal after decoding address Table 16.1.2 lists the calculation formulas and values for each parameter in Figure 16.1.1. Figure 16.1.2 shows the relationship between $t_{\text{Su}(A-DL/DH)}$ and $f(X_{\text{IN}})$ . Table 16.1.2 Calculation formulas and Values for each parameter in Figure 16.1.1 (unit : ns) | parameter in rigure 10:1:1 (unit : 113) | | | | | |-----------------------------------------|---------------------------------------|---------------------------------------|--|--| | | Calculation formulas and Values | | | | | | No Wait | Wait | | | | tw(EL) | $\frac{2 \times 10^9}{f(X_{IN})}$ -25 | $\frac{4 \times 10^9}{f(X_{IN})}$ -25 | | | | tsu(A-DL) | 3 X 10 <sup>9</sup> -70 | 5 X 10 <sup>9</sup> -70 | | | | $t_{su(A-DH)}$ | f(X <sub>IN</sub> ) | f(X <sub>IN</sub> ) | | | | tpzx(E-DLZ) | 1 X 10 <sup>9</sup> | | | | | tpzx(E-DHZ) | $\frac{1}{f(X_{IN})}$ -20 | | | | | tsu(DL-E) | 30 | | | | | tsu(DH-E) | 3 | | | | Fig. 16.1.2 Relationship between tsu(A-DL/DH) and f(XIN) #### 16.1 Memory connection #### • Timing for reading data from DRAM Fig. 16.1.3 Timing for reading data from DRAM ``` \begin{array}{l} \underline{CAS} \ \ access \ time \ : \ t_{CAC} \le t_{w(EL)} - t_{d(E\text{-}CASL)} - t_{su(DL/DH\text{-}E)} \\ \hline RAS \ \ access \ time \ : \ t_{RAC} \le t_{w(EL)} - t_{d(E\text{-}RASL)} - t_{su(DL/DH\text{-}E)} \\ \hline Column \ \ address \ \ access \ time \ : \ t_{AA} \le t_{w(EL)} - t_{d(E\text{-}CA)} - t_{su(DL/DH\text{-}E)} \\ \hline OE \ \ \ access \ \ time \ : \ t_{OEA} \le t_{w(EL)} - t_{su(DL/DH\text{-}E)} \\ \hline \end{array} ``` Table 16.1.3 lists the calculation formula and value for each parameter in Figure 16.1.3. Figure 16.1.4 shows the relationship between $t_{CAC}$ , $t_{RAC}$ , $t_{AA}$ and $f(X_{IN})$ . Table 16.1.3 Calculation formula and Value for each parameter in Figure 16.1.3 (unit : ns) | | parameter in Figure 101110 (anni 1 110) | |--------------------------------|-----------------------------------------| | | Calculation formula and Value | | tw(EL) | 4 X 10 <sup>9</sup> - 25 | | | f(X <sub>IN</sub> ) | | td(E-RASL) | 0.0 | | | 30 | | td(E-CASL) | $\frac{1 \times 10^9}{10} + 37.5$ | | | ${f(X_{IN})} + 37.5$ | | td(E-CA) | $\frac{1 \times 10^9}{100} + 25$ | | | f(X <sub>IN</sub> ) + 23 | | tpzx(E-DLZ) | 1 × 10 <sup>9</sup> – 20 | | $t_{\text{pzx}(\text{E-DHZ})}$ | f(X <sub>IN</sub> ) - 20 | | tsu(DL-E) | 30 | | tsu(DH-E) | 30 | **Note:** When accessing DRAM, Wait is always inserted regardless of the contents of the Wait bit, source's Wait bit, and destination's Wait bit. Fig. 16.1.4 Relationship between tcac, trac, taa and f(XIN) #### 16.1 Memory connection #### (2) Timing for writing data When writing data, the output data is stabilized when an interval of $t_{d(E-DLQ/DHQ)}$ has passed after the falling edge of the $\overline{E}$ signal. This data is continuously output until when an interval of $t_{h(E-DLQ/DHQ)}$ has passed after the rising edge of the $\overline{E}$ signal. Data to be written to an external memory must satisfy the data set up time $(t_{Su(D)})$ (for DRAM, the data hold time $(t_{DH})$ ) of the external memory. The following are described below: - •Timing for writing data to flash memory, SRAM, and DRAM - •Calculation formulas which are for t<sub>su(D)</sub> and t<sub>DH</sub> to be satisfied #### • Timing for writing data to flash memory and SRAM Fig. 16.1.5 Timing for writing data to flash memory and SRAM Data setup time : $t_{\text{su}(D)} \leq t_{\text{w}(\text{EL})} - t_{\text{d}(\text{E-DLQ/DHQ})}$ Table 16.1.4 lists the calculation formulas and values for each parameter in Figure 16.1.5, Figure 16.1.6 shows the relationship between $t_{\text{su}(D)}$ and $f(X_{\text{IN}})$ . Table 16.1.4 Calculation formulas and Values for each parameter in Figure 16.1.5 (unit: ns) | | Calculation formulas and Values | | | |-----------------------|----------------------------------|-------------------------|--| | | No Wait | Wait | | | tw(EL) | $\frac{2 \times 10^9}{2000}$ -25 | 4 X 10 <sup>9</sup> –25 | | | | ${f(X_{IN})}$ -25 | $f(X_{IN})$ -25 | | | td(E-DLQ) | 25 | | | | $t_{\text{d(E-DHQ)}}$ | 35 | | | | th(E-DLQ) | 1 X 10 <sup>9</sup> | | | | th(E-DHQ) | ${f(X_{IN})}$ -22 | | | Fig. 16.1.6 Relationship between t<sub>su(D)</sub> and f(X<sub>IN</sub>) #### 16.1 Memory connection #### • Timing for writing data to DRAM Fig. 16.1.7 Timing for writing data to DRAM Data hold time : $t_{DH} \le t_{w(EL)} - t_{d(E-CASL)} + t_{h(E-DLQ/DHQ)}$ Table 16.1.5 lists the calculation formula and value for each parameter in Figure 16.1.7. Figure 16.1.8 shows the relationship between $t_{DH}$ and $f(X_{IN})$ . Table 16.1.5 Calculation formula and value for each parameter in Figure 16.1.7 (unit: ns) | Calculation formula and Value | |-------------------------------------------| | $\frac{4 \times 10^9}{4 \times 10^9}$ -25 | | $\frac{1}{f(X_{IN})}$ | | 80 to 115 | | 35 | | 33 | | $\frac{1 \times 10^9}{f(X_{IN})}$ -22 | | $f(X_{IN})$ –22 | | | **Note:** When accessing DRAM, Wait is always inserted regardless of the contents of the Wait bit, source's Wait bit, and destination's Wait bit. Fig. 16.1.8 Relationship between toh and f(XIN) #### 16.1 Memory connection #### (3) Precautions on memory connection As described in ① to ③ below, if specifications of the external memory do not match those of the M37721, some considerations must be incorporated into circuit design: - ① When using an external memory that requires a long access time - 2 When data is output from an external memory before falling edge of the E signal - $\ \ \,$ When using an external memory that outputs data for more than $t_{pzx(E-DLZ/DHZ)}$ after rising edge of the $\ \ \,$ signal #### ① When using external memory that requires long access time If the M37721's $t_{su(DL/DH-E)}$ cannot be satisfied because the external memory requires a long access time, try to carry out the following: - Lower f(X<sub>IN</sub>). - Select "software Wait is inserted." (Refer to section "3.2 Software Wait.") - Use Ready function. (Refer to section "3.3 Ready function.") Figure 16.1.9 shows an example of using Ready function (no software Wait). Figure 16.1.10 shows an example of using Ready function (software Wait). Ready function is valid for the internal areas, so that the circuits in Figures 16.1.9 and 16.1.10 use the chip select signal ( $\overline{CS_2}$ ) to specify areas where Ready function is valid. In these cases, the $\overline{CS_2}$ signal is externally generated. Fig. 16.1.9 Example of using Ready function (no software Wait) # 16.1 Memory connection Fig. 16.1.10 Example of using Ready function (software Wait) #### 2 When data is output from external memory before falling edge of E signal Because the external memory outputs data before the falling edge of the E signal, there is a possibility that the tail of address collides with the head of data. In such a case, generate the external memory read signal $(\overline{OE})$ by using $\overline{E}$ . (Refer to "Figure 16.1.11.") Fig. 16.1.11 Example of making data output timing delayed # When using external memory that outputs data for more than t<sub>pzx(E-DLZ/DHZ)</sub> after rising edge of E signal Because the external memory outputs data for more than $t_{pzx(E-DLZ/DHZ)}$ after the rising edge of the $\bar{E}$ signal, there is a possibility that the tail of data collides with the head of address. In such a case, try to carry out the following: - Cut the tail of data output from the memory by using, for example, a bus buffer. - Use the Mitsubishi's memory chips that can be connected without a bus buffer. Figures 16.1.12 to 16.1.15 show examples of using bus buffers and the timing charts. Table 16.1.6 lists the Mitsubishi's memory chips that can be connected without a bus buffer. When using one of these memory chips, timing parameters $t_{DF}$ and $t_{dis(OE)}$ listed below are guaranteed. Accordingly, no bus buffer is necessary for the system where the external memory's read signal $(\overline{OE})$ goes high within $t_{pzx(E-DLZ/DHZ)}$ - $t_{DF}$ (or $t_{dis(OE)}$ ) [ns] after the rising edge of the $\overline{E}$ signal. Table 16.1.6 Mitsubishi's memory chips that can be connected without bus buffers | Memory | Туре | tdf/tdis(OE) (Maximum) | |--------------|------------------------------------------------------|------------------------| | Flash memory | M5M28F101AP, FP, J, VP, RV-85, -10 | 15 ns | | | M5M28F102AFP, J, VP-85, -10 | (Guaranteed as kit.) | | SRAM | M5M5256DP, FP, KP, VP, RV-45LL, -45XL, -55LL, -55XL, | (Note) | | | -70LL, -70XL | | | | M5M5278DP, J-12 | 6 ns | | | M5M5278DP, FP, J-15, -15L | 7 ns | | | M5M5278DP, FP, J-20, -20L | 8 ns | Note: $t_{DF}$ or $t_{dis(OE)}$ listed above is guaranteed when these memory chips are connected with the M37721. When the user wants specifications of these memory chips, add a comment " $t_{DF}/t_{dis(OE)} = 15$ ns, microcomputer and kit." # 16.1 Memory connection Fig. 16.1.12 Example of using bus buffers (1) Fig. 16.1.13 Timing chart for circuit example using bus buffers (1) # 16.1 Memory connection Fig. 16.1.14 Example for using bus buffers (2) (connecting with memory requiring long data hold time for writing) Fig. 16.1.15 Timing chart for circuit example using bus buffers (2) #### 16.1 Memory connection #### 16.1.3 Example of memory connection Examples of the flash memory, SRAM, and DRAM connection and the timing charts are described as follows. #### (1) Example of flash memory connection (minimum model) Fig. 16.1.16 Example of flash memory connection (minimum model) Fig. 16.1.17 Timing chart for flash memory connection example (minimum model) #### 16.1 Memory connection #### (2) Example of flash memory and SRAM connection (maximum model) Fig. 16.1.18 Example of flash memory and SRAM connection (maximum model) Fig. 16.1.19 Timing chart for example of flash memory and SRAM connection (maximum model) #### 16.1 Memory connection (3) Example of DRAM connection (external bus width = 8 bits) ① Fig. 16.1.20 Example of M5M44800CJ (512K $\times$ 8 bits) connection (external bus width = 8 bits) Fig. 16.1.21 Timing chart for example of M5M44800CJ (512K × 8 bits) connection (external bus width = 8 bits) #### 16.1 Memory connection (4) Example of DRAM connection (external bus width = 8 bits) 2 Fig. 16.1.22 Example of M5M417800CJ (2M $\times$ 8 bits) connection (external bus width = 8 bits) Fig. 16.1.23 Timing chart for example of M5M417800CJ (2M × 8 bits) connection (external bus width = 8 bits) # 16.1 Memory connection (5) Example of DRAM connection (external bus width = 8 bits) 3 Fig. 16.1.24 Example of M5M44400CJ (1M × 4 bits) connection (external bus width = 8 bits) Fig. 16.1.25 Timing chart for example of M5M44400CJ (1M $\times$ 4 bits) connection (external bus width = 8 bits) ## 16.1 Memory connection (6) Example of DRAM connection (external bus width = 16 bits) ① Fig. 16.1.26 Example of M5M418160CJ (1M $\times$ 16 bits) connection (external bus width = 16 bits) Fig. 16.1.27 Timing chart for example of M5M418160CJ (1M × 16 bits) connection (external bus width = 16 bits) ## 16.1 Memory connection (7) Example of DRAM connection (external bus width = 16 bits) 2 Fig. 16.1.28 Example of M5M44170CJ (256K $\times$ 16 bits) connection (external bus width = 16 bits) Fig. 16.1.29 Timing chart for example of M5M44170CJ (256K × 16 bits) connection (external bus width = 16 bits) ## 16.1 Memory connection (8) Example of DRAM connection (external bus width = 16 bits) 3 Fig. 16.1.30 Example of M5M417800CJ (2M $\times$ 8 bits) connection (external bus width = 16 bits) Fig. 16.1.31 Timing chart for example of M5M417800CJ (2M × 8 bits) connection (external bus width = 16 bits) # 16.1 Memory connection (9) Example of DRAM connection (external bus width = 16 bits) @ Fig. 16.1.32 Example of M5M44400CJ (1M $\times$ 4 bits) connection (external bus width = 16 bits) Fig. 16.1.33 Timing chart for example of M5M44400CJ (1M × 4 bits) connection (external bus width = 16 bits) #### 16.1 Memory connection (10) Example of DRAM connection (external bus width = 16 bits) (5) Fig. 16.1.34 Example of M5M44260CJ (256K × 16 bits) connection (external bus width = 16 bits) Fig. 16.1.35 Timing chart for example of M5M44260CJ (256K × 16 bits) connection (external bus width = 16 bits) #### 16.1 Memory connection #### 16.1.4 Example of I/O expansion #### (1) Example of port expansion circuit using M66010FP Figure 16.1.36 shows an example of a port expansion circuit using the M66010FP. Make sure that the frequency of Serial I/O transfer clock must be 1.923 MHz or less. About Serial I/O control in this expansion example is described below. In this example, 8-bit data transmission/reception is performed 3 times by using UART0, so that 24-bit port expansion is realized. Setting of UART0 is described below: - Clock synchronous serial I/O mode: Transmission/Reception enable state - Internal clock is selected. Transfer clock frequency is 1.66 MHz. - LSB first The control procedure is described below: - ① Output "L" level from port P45. (Expanded I/O ports of the M66010FP enter a floating state by this signal. ) - 2 Output "H" level from port P45. - 3 Output "L" level from port P44. - 4 Transmit/Receive 24-bit data by using UART0. - ⑤ Output "H" level from port P44. Figure 16.1.37 shows the serial transfer timing between the M37721 and the M66010FP. Fig. 16.1.36 Example of port expansion circuit using M66010FP ## 16.1 Memory connection Fig. 16.1.37 Serial transfer timing between M37721 and M66010FP ## 16.2 Examples of using DMA controller #### 16.2.1 Example of Centronics interface configuration The following is an example of Centronics interface configurated by using DMA0, Timers A2 and A3. #### (1) Specifications - •Octal latch's contents are transferred to the data buffer (RAM) by using DMA0. The trigger is the STB signal. (Refer to "Figure 16.2.1.") - •"L" level width of the $\overline{ACK}$ signal is generated by using Timer A2; one-shot pulse mode; the trigger is the rising edge of the $\overline{DMAACKO}$ signal. (Refer to "Figure 16.2.2.") - •Timer A3 generates the time from when the ACK <u>signal rises</u> until the BUSY signal falls; one-shot pulse mode; the trigger is the rising edge of the <u>DMAACKO</u> signal. (Refer to "**Figure 16.2.2.**") - •P4<sub>3</sub> is used for BUSY signal generation. When outputting "H" level, the next transfer can wait. In that case, the contents of the preceding transfer are hold in the octal latch. - •When the data buffer is filled (in other words, DMA transfer is completed), a DMA interrupt occurs. # 16.2 Examples of using DMA controller Fig. 16.2.1 Example of Centronics interface configuration Fig. 16.2.2 Relationship between ACK and BUSY #### (2) Initial setting example for relevant register Fig. 16.2.3 Initial setting example for relevant register (1) #### 16.2 Examples of using DMA controller Fig. 16.2.4 Initial setting example for relevant register (2) ## 16.2 Examples of using DMA controller Fig. 16.2.5 Initial setting example for relevant register (3) #### 16.2 Examples of using DMA controller #### 16.2.2 Example of stepping motor control The following is an example where the slow-up or slow-down control for the stepping motor is performed by using DMA1, DMA2, and RTP0. #### (1) Specifications - •DMA1 transfers the stepping motor's phase output data from the phase output data table to the RTP0 pulse output data register. (Refer to "Figure 16.2.6" and "Table 16.2.1.") - •DMA2 transfers the step time for slow up or slow down from the timer A0 set value data table to the timer A0 register. (Refer to "Figure 16.2.6.") - After slow up or slow down is completed, a DMA2 interrupt occurs. - •Phase output is performed by RTP0; pulse output mode 0 (Refer to "Figures 16.2.6 and 16.2.7.") - •After slow up or slow down is completed, the motor operates with the definite rate. Fig. 16.2.6 Example of stepping motor control Table 16.2.1 Example of phase output data table | | 2-2 phase | 1-2 phase | |---|-----------|-----------| | 0 | 0011 | 0011 | | 1 | 1001 | 0001 | | 2 | 1100 | 1001 | | 3 | 0110 | 1000 | | 4 | 0011 | 1100 | | 5 | 1001 | 0100 | | 6 | 1100 | 0110 | | 7 | 0110 | 0010 | Fig. 16.2.7 Example of phase output ## 16.2 Examples of using DMA controller (2) Initial setting example for relevant register Fig. 16.2.8 Initial setting example for relevant register (1) Fig. 16.2.9 Initial setting example for relevant register (2) #### 16.2 Examples of using DMA controller Fig. 16.2.10 Initial setting example for relevant register (3) #### 16.2.3 Example of dynamic lighting for LED The following is an example of dynamic lighting for LED by using DMA3 and Timer B0. #### (1) Specifications - •The eight 7-segment LEDs are lighted up; port P6 outputs the segment data; port P7 outputs the digit data. (Refer to "Figure 16.2.11.") - •The display data and the segment data are transferred from the data buffer to the port P6 and P7 registers by DMA3. - •Digit switch interval is generated by Timer B0. - •16 bytes of RAM are used as the data buffer. 1-digit display data consists of 2 bytes; the digit data is placed in the high-order byte; the segment data is placed in the low-order byte. (Refer to "Table 16.2.2.") When the digit data and segment data are "0," the LED is lighted up (ON): when they are "1," the light goes out (OFF). Assuming that the segment pattern is generated by another processing. Fig. 16.2.11 Example of dynamic lighting for LED Table 16.2.2 Data buffer | Data buffer | | | | | | | | |-------------|-------------------------------------------------|--|--|--|--|--|--| | Digit data | Segment pattern | | | | | | | | 0000001 | | | | | | | | | 00000010 | | | | | | | | | 00000100 | Sagment nettern of the | | | | | | | | 00001000 | Segment pattern of the contents to be displayed | | | | | | | | 00010000 | in each digit | | | | | | | | 00100000 | | | | | | | | | 01000000 | | | | | | | | | 10000000 | | | | | | | | - Notes 1: This applies in the following: - •when the digit data is "0," the light goes out. - •when the digit data is "1," the LED is lighted up. - 2: Assuming that the segment pattern is generated by another processing. ## 16.2 Examples of using DMA controller Fig. 16.2.12 Initial setting example for relevant register (1) Fig. 16.2.13 Initial setting example for relevant register (2) #### 16.3 Comparison of sample program execution rate ## 16.3 Comparison of sample program execution rate Sample program execution rates are compared in this paragraph. The execution time ratio depends on the program or the usage conditions. #### 16.3.1 Differences depending on data bus width and software Wait Internal areas are always accessed with data bus of which width is 16 bits and no software Wait. In the external areas, the external data bus width and software Wait are selectable. Table 16.3.1 lists the sample program (Refer to "Figure 16.3.1.") execution time ratio depending on these selection and usable memory areas. Table 16.3.1 Sample program execution time ratio (external data bus width and software Wait) | Memory area | | External data bus | Software Wait | Sample program execution time ratio | | | | | |--------------------|-----------------------------------------|--------------------|---------------|-------------------------------------|----------|--|--|--| | RAM | ROM | width (unit : bit) | John Walt | Sample A | Sample B | | | | | | al External 8 16 16 16 16 Internal | None | 1.00 | 1.00 | | | | | | | - Cutamal | 10 | Inserted | 1.17 | 1.10 | | | | | Internal | External | 2 | None | 1.19 | 1.08 | | | | | | | 8 | Inserted | 1.67 | 1.46 | | | | | | | 8 16 | None | 1.00 | 1.00 | | | | | | nal External nal Internal | 10 | Inserted | 1.25 | 1.17 | | | | | External | Internai | _ | None | 1.19 | 1.13 | | | | | | | 8 | Inserted | 1.78 | 1.65 | | | | | Calculated value * | | | 0.92 | 0.90 | | | | | Calculated value \* : The value is calculated from the shortest execution cycle number of each instruction described in "7700 Family Software Manual." | Samp | ole A===== | |------------|--------------| | | | | SEP | , | | LDA.B | | | STA | A,DEST+64 | | STA | A,DEST+65 | | STA | A,DEST+66 | | LDX.B | ** | | ITALIC:LDA | A,SOUR,X | | TAY | | | AND.B | A,#00000011B | | STA | A,DEST,X | | TYA | | | AND.B | A,#00001100B | | ORA | A,DEST+1,X | | STA | A,DEST+1,X | | TYA | | | AND.B | A,#00110000B | | ORA | A,DEST+2,X | | STA | A,DEST+2,X | | TYA | | | AND.B | A,#11000000B | | ORA | A,DEST+3,X | | STA | A,DEST+3,X | | DEX | | | BPL | ITALIC | | | | | | | | | | | | | | Samp | le B | |--------------|------------| | SEP | X | | CLM | | | .DATA | 16 | | .INDEX | 8 | | LDY | #69 | | LOOP0:LDX | #69 | | LOOP1:ASL | SOUR,X | | SEM | | | .DATA | 8 | | ROL | SOUR+2,X | | ROL | В | | CLM | | | .DATA | | | ROR | A | | DEX | | | DEX | | | DEX | - 0 0 - 1 | | BNE | LOOP1 | | STA | A,DEST,Y | | SEM | 0 | | .DATA | | | STA | B,DEST+2,Y | | CLM<br>.DATA | 16 | | DEY | ΤΩ | | DEY | | | DEY | | | BNE | LOOP0 | | DIAG | LOOPU | \* SOUR, DEST: Work area (Direct page area: Access this area by using the following modes.) - Direct addressing mode - •Direct Indexed X addressing mode - •Absolute Indexed Y addressing mode Fig. 16.3.1 Sample program list ## 16.3 Comparison of sample program execution rate #### 16.3.2 Comparison between software Wait (f(X<sub>IN</sub>) = 20 MHz) and software Wait + Ready (f(X<sub>IN</sub>) = 25 MHz) Figure 16.3.3 shows the execution time ratio when sample programs in Figure 16.3.1 are executed on the two conditions in Table 16.3.2. Figure 16.3.2 shows the memory assignment at execution rate comparison. The execution time ratio depends on the program or the usage conditions. **Table 16.3.2 Comparison conditions** | Item | Condition ① | Condition ② | |-------------------------|---------------------------|------------------------------------| | Processor mode | Microprocessor mode | Microprocessor mode | | f(X <sub>IN</sub> ) | 20 MHz | 25 MHz | | External data bus width | 16 bits | 16 bits | | Software Wait | Inserted | Inserted | | Ready | Invalid | Valid only for external EPROM area | | Program area | External EPROM | External EPROM | | Work area | Internal or External SRAM | Internal or External SRAM | Fig. 16.3.2 Memory assignment at execution rate comparison ## 16.3 Comparison of sample program execution rate Figure 16.3.3 shows that there is almost no difference between conditions 1 and 2 about the execution time. The bus buffers become unnecessary when using the specified memory. (Refer to "**Table 16.1.6.**") Considering this, the case where software Wait is inserted with $f(X_{IN}) = 20$ MHz (condition 1) is superior in the cost performance. Fig. 16.3.3 Execution time ratio 16.3 Comparison of sample program execution rate **MEMORANDUM** # APPENDIX - Appendix 1. Memory assignment of 7721 Group - Appendix 2. Memory assignment in SFR area - Appendix 3. Control registers - Appendix 4. Package outline - Appendix 5. Examples of handling unused pins - Appendix 6. Machine instructions - Appendix 7. Hexadecimal instruction code table - Appendix 8. Countermeasure against noise - Appendix 9. 7721 Group Q & A - Appendix 10. Differences between 7721 Group and 7720 Group - Appendix 11. Electrical characteristics - Appendix 12. Standard characteristics # Appendix 1. Memory assignment of 7721 Group Microprocessor mode Fig. 1 Memory assignment (microprocessor mode) # Appendix 2. Memory assignment in SFR area #### **Access characteristics** RW: It is possible to read the bit state at reading. The written value becomes valid. RO: It is possible to read the bit state at reading. The written value becomes invalid. WO: The written value becomes valid. It is impossible to read the bit state. : Nothing is assigned. It is impossible to read the bit state. The written value becomes invalid. #### State immediately after reset 0: "0" immediately after reset. 1: "1" immediately after reset. ?: Undefined immediately after reset. 0 : Always "0" at reading. 1 : Always "1" at reading. ? : Always undefined at reading. : "0" immediately after reset. Fix this bit to "0." | Addre | ess Register name | b7 Ac | ccess | charact | terist | ics<br>b0 | ) | St | ate | imm | edia | tely | after | res | et<br>b0 | | |------------------|-------------------------------|-------|-------|-----------|--------|-----------|-----|------|-----|-----|------|------|-------|-----|----------|--| | 016 | | | | | | | ĺ | | | | | ? | | | | | | 116 | | | | | | | 1 1 | ? | | | | | | | | | | 216 | | | | | | | 1 1 | | | | | ? | | | | | | 316 | | | | | | | 1 [ | | | | | ? | | | | | | 416 | | | | | | | 1 [ | | | | | ? | | | | | | 516 | | | | | | | 1 [ | | | | | ? | | | | | | <b>6</b> 16 | | | | | | | ĪĪ | | | | 1 | ? | | | | | | <b>7</b> 16 | | | | | | | 1 [ | | | | | ? | | | | | | 816 | | | | | | | | | | | | ? | | | | | | 916 | | | | | | | | | | | | ? | | | | | | A16 | Port P4 register | | RW | | | | | | | ? | | | 0 | 0 | 0 | | | B16 | Port P5 register | | | RW | | | | | | | • | ? | | | | | | C16 | Port P4 direction register | | RW | | | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | D16 | Port P5 direction register | | | RW | | | | 0016 | | | | | | | | | | E16 | Port P6 register | | | RW | | | | ? | | | | | | | | | | F16 | Port P7 register | | | RW | | | | ? | | | | | | | | | | 1016 | Port P6 direction register | | | RW | | | | | | | 00 | 16 | | | | | | 1116 | Port P7 direction register | | | RW | | | | | | | 00 | 16 | | | | | | 1216 | Port P8 register | | | RW | | | | | | | 7 | > | | | | | | 1316 | Port P9 register | | | RW | | | | | | | 7 | > | | | | | | 1416 | Port P8 direction register | | | RW | | | | | | | 00 | )16 | | | | | | 1516 | Port P9 direction register | | | RW | | | | | | | 00 | )16 | | | | | | <b>16</b> 16 | Port P10 register | | | RW | | | | | | | 7 | ? | | | | | | <b>17</b> 16 | | | | | | | | | | | 7 | ? | | | | | | 1816 | Port P10 direction register | | | RW | | | | | | | | )16 | | | | | | 1916 | | | | | | | | | | | ? | | | | | | | 1A16 | Pulse output data register 0 | | | | W | <u>'O</u> | | | | | ? | | | | | | | 1B16 | | | | | | | | | | | 7 | | | | | | | 1C <sub>16</sub> | Pulse output data register 1 | | W | <u>'O</u> | | | | | | | ? | | | | | | | 1D16 | | | | | ? | | | | | | | | | | | | | <b>1E</b> 16 | A-D control register | | | RW | | | ] [ | 0 | 0 | 0 | 0 | 0 | ? | ? | ? | | | 1F16 | A-D sweep pin select register | | | | | RW | | ? | ? | ? | ? | ? | ? | 1 | 1 | | ## **APPENDIX** ## Appendix 2. Memory assignment in SFR area #### **Access characteristics** RW: It is possible to read the bit state at reading. The written value becomes valid. RO: It is possible to read the bit state at reading. The written value becomes invalid. WO: The written value becomes valid. It is impossible to read the bit state. : Nothing is assigned. It is impossible to read the bit state. The written value becomes invalid. #### State immediately after a reset 0: "0" immediately after reset. 1: "1" immediately after reset. ?: Undefined immediately after reset. 0 : Always "0" at reading. 1 : Always "1" at reading. ? : Always undefined at reading. : "0" immediately after reset. Fix this bit to "0." | Addres | s Register name | | b7 | Access | s cha | ract | erist | ics | b0 | |------------------|---------------------------------------------|--------------|----------------------------------------------|--------|----------|-----------|-------|-----|---------| | 2016 | A-D register 0 | ſ | <u>. </u> | | R | 20 | | | Ĭ | | 2116 | | | | | | | | | | | 2216 | A-D register 1 | Ī | | | R | 20 | | | | | 2316 | • | | | | | | | | | | 2416 | A-D register 2 | | | | R | 20 | | | | | 2516 | | | | | | | | | | | 2616 | A-D register 3 | | | | R | 20 | | | | | 2716 | | | | | | | | | | | 2816 | A-D register 4 | | | | R | 20 | | | | | 2916 | | | | | | | | | | | 2A16 | A-D register 5 | L | | | R | 20_ | | | | | 2B16 | | | | | | | | | | | 2C16 | A-D register 6 | L | | | R | 20 | | | | | 2D16 | | | | | | | | | | | 2E16 | A-D register 7 | L | | | R | 20 | | | | | 2F16 | | | | | | | | | | | 3016 | UART0 transmit/receive mode register | L | | | | W | | | | | 3116 | UART0 baud rate register | | | | | /0_ | | | | | 3216 | UART0 transmit buffer register | | | | <u> </u> | 10 | | | | | 3316 | _ | 4 | | | - | | | | WO | | | UART0 transmit/receive control register 0 | | | | | RO | | RW | | | | UART0 transmit/receive control register 1 | $\downarrow$ | | RC | | | RW | RO | ΚW | | <b>36</b> 16 | UART0 receive buffer register | Н | | | к | 20 | | | | | 3716 | | 4 | | | _ | <u> </u> | | | RO | | 3816 | UART1 transmit/receive mode register | ŀ | | | | .W | | | | | 3916 | UART1 baud rate register | <i>/</i> | | | | <u>/O</u> | | | | | 3A16 | UART1 transmit buffer register | Н | | | | <u>/O</u> | | | WO | | 3B16 | LIADTA transmit/respires control register O | 4 | | | | RO | | RW | | | 3C <sub>16</sub> | UART1 transmit/receive control register 0 | ŀ | | RC | | INO | D\\/ | RO | _ | | 3D16 | UART1 transmit/receive control register 1 | <del>/</del> | | , , C | | 20 | 17.44 | NO | 1 \ V V | | 3F16 | UART1 receive buffer register | 1 | | | | | | | RO | | JI 10 | | \L | | | | | | | | | Sta<br>b7 | ate i | mme | ediat | tely a | after | rese | et<br>b0 | | | | | |-----------|---------------------------------------|-----|-------|--------------------|-------|------|----------|--|--|--|--| | | | | | | | | | | | | | | ? | | | | | | | | | | | | | ? | | | | | | | | | | | | | | ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? | | | | | | | | | | | | | | | ( | ? | | | | | | | | | | | | ? | ? | | | | | | | | | | | | ? | ? | | | | | | | | | | | | ? | ? | | | | | | | | | | | | ( | ? | | | | | | | | | | | | 7 | ? | | | | | | | | | | | | 1 | ? | | | | | | | | | | | | ( | ? | | | | | | | | | | | | - | ? | | | | | | | | | | | | ( | ? | | | | | | | | | | _ | _ | - 1 | ? | _ | _ | _ | | | | | | | | | | ? | | | | | | | | | | | | 00 | )16<br>?<br>?<br>? | | | | | | | | | | | | | ? | | | | | | | | | | | | | ? | | | | | | | | | 2 | 2 | 2 | 2 | | | | | | | | | | ? | ? | ? | ? | 0 | 0 | 0 | 0 | | | | | | 0 | 0 | 0 | 0 | U<br>? | 0 | 1 | 0 | | | | | | 0 | 0 | 0 | 0 | 9 | 0 | 0 | ? | | | | | | U | U | U | | )<br>16 | U | U | • | | | | | | | | | 7 | ) 0 | | | | | | | | | | | | 7 | ? | | | | | | | | | | | | · · | | | | | | | | | | ? | ? | ? | ? | 1 | 0 | 0 | 0 | | | | | | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | | | | | | Ť | | | | ? | | • | | | | | | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | ? | | | | | #### Access characteristics RW: It is possible to read the bit state at reading. The written value becomes valid. RO: It is possible to read the bit state at reading. The written value becomes invalid. WO: The written value becomes valid. It is impossible to read the bit state. Nothing is assigned. It is impossible to read the bit state. The written value becomes invalid. #### State immediately after reset 0: "0" immediately after reset. 1: "1" immediately after reset. ?: Undefined immediately after reset. 0 : Always "0" at reading. 1 : Always "1" at reading. : Always undefined at reading. : "0" immediately after reset. Fix this bit to "0." | Address | Register name | Access characteristics b7 b0 | | | | State immediately | | | | | after | res | et<br>b | | | |--------------|---------------------------|------------------------------|------------|-------|----|-------------------|------|-----|-----|-----|----------|-------------|--------------|--|--| | 4016 | Count start register | RW | | | | | 0016 | | | | | | | | | | 4116 | | | | ? | | | | | | | | | | | | | 4216 | One-shot start register | WO | | | | | ? | | 0 | 0 | 0 | 10 | <b>W</b> | | | | 4316 | | | | | | | | | • | ? | | | | | | | 4416 | Up-down register | WO | RW | | 0 | 0 | 0 | 0 | 0 | 0 | 10 | 1/9 | | | | | <b>45</b> 16 | | | | | | | | | • | ? | | | | | | | <b>46</b> 16 | Timer AO register | | R | 2W | | | | | , | ? | | | | | | | <b>47</b> 16 | Timer A0 register | | R | :W | | | | | , | ? | | | | | | | 4816 | Timer A1 register | | R | 2W | | | | | , | ? | | | | | | | 4916 | Timer A1 register | | R | :W | | | | | , | ? | | | | | | | 4A16 | Timer A2 register | | (No | te 1) | | | | | , | ? | | | | | | | 4B16 | Tiller Az register | | (No | te 1) | | | | | , | ? | | | | | | | 4C16 | Timer A3 register | | (No | te 1) | | ? | | | | | | | | | | | 4D16 | Timer As register | | (No | te 1) | | ? | | | | | | | | | | | 4E16 | Timer A4 register | | | | | | • | ? | | | | | | | | | 4F16 | Timer A4 register | | | ? | | | | | | | | | | | | | 5016 | Timer B0 register | | (No | te 2) | | ? | | | | | <b>1</b> | | | | | | 5116 | Timer bo register | | (No | te 2) | | ? | | | | | | | | | | | 5216 | Timer B1 register | | | te 2) | | | | | • | ? | | | | | | | 5316 | Tiller bi register | | (No | te 2) | | ? | | | | | | | | | | | <b>54</b> 16 | Timer B2 register | | R | 2W | | ? | | | | | | | | | | | 5516 | Timer bz register | | R | :W | | | | | , | ? | | • • • • | | | | | <b>56</b> 16 | Timer A0 mode register | | R | 2W | | 0 | 0 | 10 | 10/ | 10/ | 10/ | 10 | <u> 1</u> /0 | | | | <b>57</b> 16 | Timer A1 mode register | | R | :W | | 0 | 0 | 10/ | 10/ | 10/ | 18/ | Ø/ | 1/0 | | | | 5816 | Timer A2 mode register | | R | 2W | | | | | 00 | 16 | | | | | | | 5916 | Timer A3 mode register | | R | 2W | | | | | 00 | )16 | | | | | | | 5A16 | Timer A4 mode register | | | 2W | | | | | | )16 | | | | | | | 5B16 | Timer B0 mode register | KW | Note<br>3) | RW | | 0 | 0 | ? | ? | 0 | 0 | 0 | 0 | | | | 5C16 | Timer B1 mode register | KW | Note<br>3) | RW | | 0 | 0 | ? | ? | 0 | 0 | 0 | 0 | | | | 5D16 | Timer B2 mode register | RW ( | Note<br>3) | RW | | 0 | 0 | ? | ? | 0 | 0 | 10/ | 1/9 | | | | 5E16 | Processor mode register 0 | RV | <u>V</u> | | RW | 0 | 181 | 0 | 0 | 0 | 0 | 1 | 1/0 | | | | 5F16 F | Processor mode register 1 | | | RW | | | | 1 | ? | | | (Note<br>4) | ? | | | | | | | | | | | | | | | | | | | | - Notes 1: The access characteristics at addresses 4A16 to 4F16 vary according to Timer A's operating mode. (Refer to "CHAPTER 8. TIMER A.") - 2: The access characteristics at addresses 5016 to 5316 vary according to Timer B's operating mode. (Refer to "CHAPTER 9. TIMER B.") - 3: The access characteristics for bit 5 at addresses 5B16 and 5C16 vary according to Timer B's operating mode. Bit 5 at address 5D16 is invalid. (Refer to "CHAPTER 9. TIMER B.") - 4: Bit 1 at address 5F16 becomes "0" immediately after reset. For the M37721S1BFP, fix this bit to # **APPENDIX** ### Appendix 2. Memory assignment in SFR area #### **Access characteristics** RW: It is possible to read the bit state at reading. The written value becomes valid. RO: It is possible to read the bit state at reading. The written value becomes invalid. WO: The written value becomes valid. It is impossible to read the bit state. : Nothing is assigned. It is impossible to read the bit state. The written value becomes invalid. #### State immediately after reset 0: "0" immediately after reset. 1 : "1" immediately after reset.? : Undefined immediately after reset. 0 : Always "0" at reading. 1 : Always "1" at reading. ? : Always undefined at reading. : "0" immediately after reset. Fix this bit to "0." | Addre | ss Register name | b7 | Acces | s cha | racteristics b0 | | State immediat | ely a | ıfter | rese | et<br>b0 | | |------------------------------------------------------|---------------------------------------------|----|---------|-------|-----------------|---|----------------|--------|-------|------|----------|--| | <b>60</b> 16 | Watchdog timer register | | | (No | te 5) | | ?(N | ote 6) | ) | | | | | <b>61</b> 16 | Watchdog timer frequency select register | | | | RW | | ? | | | | 0 | | | <b>62</b> 16 | Real-time output control register | | | | RW | | 0 0 0 0 | 0 | 0 | 0 | 0 | | | 6316 | | | | | | | | ? | | | | | | <b>64</b> 16 | DRAM control register | RW | | | RW | | 0 0 0 0 | 0 | 0 | 0 | 0 | | | <b>65</b> 16 | 6 | | | | | | | ? | | | | | | <b>66</b> 16 | Refresh timer | | | V | /O | | ? | | | | | | | <b>67</b> 16 | | | | | | | | ? | | | | | | <b>68</b> 16 | DMAC control register L | | (Note 7 | ') | RW | | 0 0 0 0 | ? | ? | 0 | 0 | | | 6916 | DMAC control register H | | RW | | WO | | 0 0 0 0 | 0 | 0 | 0 | 0 | | | <b>6A</b> 16 | | | | | | | | ? | | | | | | 6B16 | | | | | | | | ? | | | | | | 6C16 | B16 C16 DMA0 interrupt control register | | | | RW | | ? | 0 | 0 | 0 | 0 | | | 6D16 | DMA1 interrupt control register | | | | RW | | ? | 0 | 0 | 0 | 0 | | | <b>6E</b> 16 | DMA2 interrupt control register | | | | RW | | ? | 0 | 0 | 0 | 0 | | | <b>6F</b> 16 | DMA3 interrupt control register | | RW ? | | | 0 | 0 | 0 | 0 | | | | | 7016 | A-D conversion interrupt control register | | | | RW | | ? | 0 | 0 | 0 | 0 | | | <b>71</b> 16 | UART0 transmit interrupt control register | | | | RW | | ? | 0 | 0 | 0 | 0 | | | 7216 | UART0 receive interrupt control register | | | | RW | | ? | 0 | 0 | 0 | 0 | | | 7316 | UART1 transmit interrupt control register | | | | RW | | ? | 0 | 0 | 0 | 0 | | | <b>74</b> 16 | UART1 receive interrupt control register | | | | RW | | ? | 0 | 0 | 0 | 0 | | | 7516 | Timer A0 interrupt control register | | | | RW | | ? | 0 | 0 | 0 | 0 | | | <b>76</b> 16 | Timer A1 interrupt control register | | | | RW | | ? | 0 | 0 | 0 | 0 | | | 7716 | Timer A2 interrupt control register | | | | RW | | ? | 0 | 0 | 0 | 0 | | | 7816 | Timer A3 interrupt control register | | | | RW | | ? | 0 | 0 | 0 | 0 | | | 7916 | Timer A4 interrupt control register | | | | RW | | ? | 0 | 0 | 0 | 0 | | | <b>7A</b> 16 | Timer B0 interrupt control register | | | | RW | | ? | 0 | 0 | 0 | 0 | | | 7B16 | - | | | | RW | | ? | 0 | 0 | 0 | 0 | | | 7C <sub>16</sub> Timer B2 interrupt control register | | | | | RW | | ? | 0 | 0 | 0 | 0 | | | 7D16 | INTo interrupt control register | | | | RW | | ? 0 0 | 0 | 0 | 0 | 0 | | | 7E16 | INT <sub>1</sub> interrupt control register | | | | RW | | ? 0 0 | 0 | 0 | 0 | 0 | | | 7F16 | INT2 interrupt control register | | | | RW | | ? 0 0 | 0 | 0 | 0 | 0 | | **Notes 5:** By writing dummy data to address 6016, the value "FFF16" is set to the watchdog timer. The dummy data is not retained anywhere. 6: The value "FFF16" is set to the watchdog timer. (Refer to "CHAPTER 15. WATCHDOG TIMER.") 7: It is possible to read the bit state at reading. When writing "0" to this bit, this bit becomes "0." But when writing "1" to this bit, this bit does not change. #### **Access characteristics** RW: It is possible to read the bit state at reading. The written value becomes valid. RO: It is possible to read the bit state at reading. The written value becomes invalid. WO: The written value becomes valid. It is impossible to read the bit state. Nothing is assigned. It is impossible to read the bit state. The written value becomes invalid. #### State immediately after reset 0 : "0" immediately after reset.1 : "1" immediately after reset. ?: Undefined immediately after reset. 0 : Always "0" at reading. 1 : Always "1" at reading. ? : Always undefined at reading. : "0" immediately after reset. Fix this bit to "0." | Address | Register name | Access characteristics b0 | State immediately after reset b0 | |--------------------|--------------------------------|---------------------------|----------------------------------| | 1FC016 | | RW | ? | | 1FC1 <sub>16</sub> | Source address register 0 | RW | ? | | 1FC216 | | RW | ? | | 1FC3 <sub>16</sub> | | | ? | | 1FC416 | | RW | ? | | 1FC516 | Destination address register 0 | RW | ? | | 1FC616 | | RW | ? | | 1FC7 <sub>16</sub> | | | ? | | 1FC8 <sub>16</sub> | | RW | ? | | 1FC9 <sub>16</sub> | Transfer counter register 0 | RW | ? | | 1FCA <sub>16</sub> | | RW | ? | | 1FCB <sub>16</sub> | | | ? | | 1FCC <sub>16</sub> | DMA0 mode register L | RW | 0 0 0 0 0 0 0 | | 1FCD <sub>16</sub> | DMA0 mode register H | RW | 0 0 0 0 0 0 0 | | 1FCE <sub>16</sub> | DMA0 control register | RW | ? ? 0 0 0 0 0 | | 1FCF <sub>16</sub> | | | ? | | 1FD016 | | RW | ? | | 1FD1 <sub>16</sub> | Source address register 1 | RW | ? | | 1FD216 | | RW | ? | | 1FD316 | | | ? | | 1FD416 | | RW | ? | | 1FD516 | Destination address register 1 | RW | ? | | 1FD6 <sub>16</sub> | | RW | ? | | 1FD7 <sub>16</sub> | | | ? | | 1FD8 <sub>16</sub> | | RW | ? | | 1FD916 | Transfer counter register 1 | RW | ? | | 1FDA <sub>16</sub> | | RW | ? | | 1FDB <sub>16</sub> | | | ? | | 1FDC <sub>16</sub> | DMA1 mode register L | RW | 0 0 0 0 0 0 0 | | 1FDD16 | DMA1 mode register H | RW | 0 0 0 0 0 0 0 0 | | 1FDE <sub>16</sub> | DMA1 control register | RW | ? ? 0 0 0 0 0 | | 1FDF <sub>16</sub> | | | ? | | | | | | # **APPENDIX** ### Appendix 2. Memory assignment in SFR area #### **Access characteristics** RW: It is possible to read the bit state at reading. The written value becomes valid. RO: It is possible to read the bit state at reading. The written value becomes invalid. WO: The written value becomes valid. It is impossible to read the bit state. : Nothing is assigned. It is impossible to read the bit state. The written value becomes invalid. #### State immediately after reset 0: "0" immediately after reset. 1: "1" immediately after reset. ?: Undefined immediately after reset. 0 : Always "0" at reading. 1 : Always "1" at reading. ? : Always undefined at reading. : "0" immediately after reset. Fix this bit to "0." | Address | Register name | Access characteristics b0 | State immediately after reset b0 | |--------------------|--------------------------------|---------------------------|----------------------------------| | 1FE0 <sub>16</sub> | | RW | ? | | 1FE1 <sub>16</sub> | Source address register 2 | RW | ? | | 1FE216 | | RW | ? | | 1FE3 <sub>16</sub> | | | ? | | 1FE416 | | RW | ? | | 1FE5 <sub>16</sub> | Destination address register 2 | RW | ? | | 1FE6 <sub>16</sub> | | RW | ? | | 1FE7 <sub>16</sub> | | | ? | | 1FE8 <sub>16</sub> | | RW | ? | | 1FE9 <sub>16</sub> | Transfer counter register 2 | RW | ? | | 1FEA <sub>16</sub> | | RW | ? | | 1FEB <sub>16</sub> | | | ? | | 1FEC <sub>16</sub> | DMA2 mode register L | RW | 0 0 0 0 0 0 0 | | 1FED <sub>16</sub> | DMA2 mode register H | RW | 0 0 0 0 0 0 0 | | 1FEE <sub>16</sub> | DMA2 control register | RW | ? ? 0 0 0 0 0 0 | | 1FEF <sub>16</sub> | | | ? | | 1FF016 | | RW | ? | | 1FF116 | Source address register 3 | RW | ? | | 1FF216 | | RW | ? | | 1FF3 <sub>16</sub> | | | ? | | 1FF416 | | RW | ? | | 1FF516 | Destination address register 3 | RW | ? | | 1FF6 <sub>16</sub> | | RW | ? | | 1FF7 <sub>16</sub> | | | ? | | 1FF816 | | RW | ? | | 1FF9 <sub>16</sub> | Transfer counter register 3 | RW | ? | | 1FFA <sub>16</sub> | | RW | ? | | 1FFB <sub>16</sub> | | | ? | | 1FFC <sub>16</sub> | DMA3 mode register L | RW | 0 0 0 0 0 0 0 | | 1FFD <sub>16</sub> | DMA3 mode register H | RW | 0 0 0 0 0 0 0 | | 1FFE <sub>16</sub> | DMA3 control register | RW | ? ? 0 0 0 0 0 0 | | 1FFF16 | | | ? | # **Appendix 3. Control registers** The control registers allocated in the SFR area are shown on the following pages. Below is the structure diagram for all registers. Blank : Set to "0" or "1" according to the usage. 0 : Set to "0" at writing. 1 : Set to "1" at writing. X : Invalid depending on the mode or state. It may be "0" or "1." : Nothing is assigned. **\***2 0 : "0" immediately after reset. 1 : "1" immediately after reset. Undefined: Undefined immediately after reset. **\***3 RW : It is possible to read the bit state at reading. The written value becomes valid. RO: It is possible to read the bit state at reading. The written value becomes invalid. Accordingly, the written value may be "0" or "1." WO: The written value becomes valid. It is impossible to read the bit state. The value is undefined at reading. However, when ["0" is at reading"] is indicated in the "Function" or "Note" column, the bit is always "0" at reading. (See \*4 above.) - : It is impossible to read the bit state. The value is undefined at reading. However, when ["0" is at reading"] is indicated in the "Function" or "Note" column, the bit is always "0" at reading. (See \*4 above.) The written value becomes invalid. Accordingly, the written value may be "0" or "1." ### Port Pi register Note: For bits 0 to 2 of the port P4 register, nothing is assigned and these bits are fixed to "0" at reading. # Port Pi direction register Note: For bits 0 to 2 of the port P4 direction register, nothing is assigned and these bits are fixed to "0" at reading. ### Pulse output data register 0 Note: Use the LDM or STA instruction for writing to this register ### Pulse output data register 1 $\textbf{Note:} \ \mathsf{Use} \ \mathsf{the} \ \mathbf{LDM} \ \mathsf{or} \ \mathbf{STA} \ \mathsf{instruction} \ \mathsf{for} \ \mathsf{writing} \ \mathsf{to} \ \mathsf{this} \ \mathsf{register}.$ #### A-D control register - Notes 1: These bits are invalid in the single sweep and repeat sweep mode. (They may be either "0" or "1.") - 2: When selecting an external trigger, the AN7 pin cannot be used as an analog input pin. - 3: Writing to each bit (except bit 6) of the A-D control register must be performed while the A-D converter halts ### A-D sweep pin select register - Notes 1: These bits are invalid in the one-shot and repeat modes. (They may be either "0" or "1.") - 2: When selecting an external trigger, the AN7 pin cannot be used as an analog input pin. - **3:** Writing to each bit of the A-D sweep pin select register must be performed while the A-D converter halts. #### A-D register i #### **UARTi** transmit/receive mode register Note: Bits 4 to 6 are invalid in the clock synchronous serial I/O mode. (They may be either "0" or "1.") Additionally, fix bit 7 to "0." ### **UARTi** baud rate register **Note:** Writing to this register must be performed while the transmission/reception halts. Use the **LDM** or **STA** instruction for writing to this register. ### **UARTi transmit buffer register** Note: Use the LDM or STA instruction for writing to this register. # UARTi transmit/receive control register 0 ## **UARTi transmit/receive control register 1** | b7 b6 b5 b4 | TTT U | | ransmit/receive control register<br>ransmit/receive control register | | | | |-------------|----------|-----|----------------------------------------------------------------------|------------------------------------------------------------------------------------------|----------|----| | | | Bit | Bit name | Functions | At reset | RW | | | | 0 | Transmit enable bit | 0 : Transmission disabled<br>1 : Transmission enabled | 0 | RW | | | <u> </u> | 1 | Transmit buffer empty flag | Data present in transmit buffer register No data present in transmit buffer register | 1 | RO | | | | 2 | Receive enable bit | 0 : Reception disabled<br>1 : Reception enabled | 0 | RW | | | · | 3 | Receive complete flag | No data present in receive buffer register Data present in receive buffer register | 0 | RO | | | | 4 | Overrun error flag (Note 1) | 0 : No overrun error<br>1 : Overrun error detected | 0 | RO | | | | 5 | Framing error flag (Notes 1, 2) (Valid in UART mode) | 0 : No framing error<br>1 : Framing error detected | 0 | RO | | | | 6 | Parity error flag (Notes 1, 2) (Valid in UART mode) | 0 : No parity error<br>1 : Parity error detected | 0 | RO | | <u> </u> | | 7 | Error sum flag (Notes 1, 2) (Valid in UART mode) | 0 : No error<br>1 : Error detected | 0 | RO | Notes 1: Bit 4 is cleared to "0" when the receive enable bit is cleared to "0" or when the serial I/O mode select bits (bits 2 to 0 at addresses 30<sub>16</sub>, 38<sub>16</sub>) are cleared to "000<sub>2</sub>." Bits 5 and 6 are cleared to "0" when one of the following is performed: •Clearing the receive enable bit to "0" ### **UARTi** receive buffer register <sup>•</sup>Reading the low-order byte of the UARTi receive buffer register (addresses 3616, 3E16) out <sup>•</sup>Clearing the serial I/O mode select bits (bits 2 to 0 at addresses 30<sub>16</sub>, 38<sub>16</sub>) to "000<sub>2</sub>" Bit 7 is cleared to "0" when all of bits 4 to 6 become "0." <sup>2:</sup> Bits 5 to 7 are invalid in the clock synchronous serial I/O mode. ### Count start register #### One-shot start register ### **Up-down register** Note: Use the LDM or STA instruction for writing to bits 5 to 7. ### Timer Ai register **Notes 1:** The access characteristics for the timer A2 register, timer A3 register, and timer A4 register differ according to Timer A's operating mode. 2: Read from or write to this register in a unit of 16 bits. ## Timer Ai mode register ### **Timer Mode** Note: Read from or write to this register in a unit of 16 bits. | | 0 6 | 4 | b3 | b2 | 0 | 1 | 0 | Timer | Aj mode register (j = 2 to 4) (A | addresses 5816 to 5A16) | | | |---|-----|---|------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|----|----|-------|----------------------------------|--------------------------------|----------|----| | | | | | | | | | Bit | Bit name | Functions | At reset | RW | | | : : | | : | i | | | L | 0 | Operating mode select bits | b1 b0<br>0 0 : Timer mode | 0 | RW | | | | | - | | į | | | 1 | | | 0 | RW | | | L | 2 | Pulse output function select bit | O: No pulse output (TAjour pin functions as a programmable I/O port.) 1: Pulse output (TAjour pin functions as a pulse output pin.) | 0 | RW | | | | | | | | | | | 3 | Gate function select bits | b4 b3 0 0 : No gate function 0 1 : (TAj <sub>IN</sub> pin functions as a programmable I/O port.) 1 0 : Counter counts only while TAj <sub>IN</sub> | 0 | RW | | | | | | | | | 4 | | pin's input signal is at "L" level. 1 1: Counter counts only while TAjiN pin's input signal is at "H" level. | 0 | RW | | | | | | | | | | 5 | Fix this bit to "0" in timer mode. | | 0 | RW | | | | | | | | | | | | | | | | 6 | Count source select bits | b7 b6<br>0 0 : f2<br>0 1 : f16 | 0 | RW | | i | | | | | | | | 7 | | 1 0 : f64<br>1 1 : f512 | 0 | RW | # **APPENDIX** ### Appendix 3. Control registers #### **Event counter mode** Note: Read from or write to this register in a unit of 16 bits. | b7 | b6 | b5 | b4 | b3 | b2 | b1 | b | 0 | | | | | | |----|------------|----|----|-----|-----|----|---|-------|---------|--------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------|----------|----| | X | X | 0 | | | | 0 | ' | 1 - | Timer A | ij mode register (j = 2 to 4) (Ad | dresses 5816 to 5A16) | | | | Ŧ | ` | 1 | - | - | 1 | 1 | • | | | | | | | | | - | | - | | - | - | | | Bit | Bit name | Functions | At reset | RW | | | - | | | - 1 | - { | | | L | 0 | Operating mode select bits | 0 1 : Event counter mode | 0 | RW | | | | i | | - 1 | i | į. | | | 1 | | | 0 | RW | | | | | | | į | | | | 2 | Pulse output function select bit | 0 : No pulse output (ΤΑjουτ pin functions as a programmable I/O port.) 1 : Pulse output (ΤΑjουτ pin functions as a pulse output pin.) | 0 | RW | | | | - | | į | | | | | 3 | Count polarity select bit | Counts at falling edge of external signal Counts at rising edge of external signal | 0 | RW | | | | | Ĺ. | | | | | | 4 | Up-down switching factor select bit | 0 : Contents of up-down register<br>1 : Input signal to TAjou⊤ pin | 0 | RW | | | | Ĺ | | | | | | | 5 | Fix this bit to "0" in event counter | mode. | 0 | RW | | | <u>:</u> - | | | | | | | | 6 | These bits are invalid in event co | unter mode. | 0 | RW | | Ĺ. | | | | | | | | | 7 | | | 0 | RW | ## One-shot pulse mode fi: Frequency of count source (f2 , f16, f64, or f512) Note: Use the LDM or STA instruction for writing to this register. Read from or write to this register in a unit of 16 bits. | 0 1 1 0 | Timer | Aj mode register (j = 2 to 4) (A | ddresses 5816 to 5A16) | | | |---------|-------|--------------------------------------|------------------------------------------------------------------------------------------------------------------|----------|----| | | Bit | Bit name | Functions | At reset | RW | | | 0 | Operating mode select bits | 1 0 : One-shot pulse mode | 0 | RW | | | 1 | | | 0 | RW | | | 2 | Fix this bit to "1" in one-shot puls | e mode. | 0 | RW | | | 3 | Trigger select bits | b4 b3<br>0 0 : Writing "1" to one-shot start register<br>0 1 : (TAjıN pin functions as a prog- | 0 | RW | | | 4 | | rammable I/O port.) 1 0 : Falling edge of TAjın pin's input signal 1 1 : Rising edge of TAjın pin's input signal | 0 | RW | | | 5 | Fix this bit to "0" in one-shot puls | e mode. | 0 | RW | | 1 | 6 | Count source select bits | b7 b6<br>0 0 : f2<br>0 1 : f16 | 0 | RW | | į | 7 | | 1 0 : f <sub>64</sub><br>1 1 : f <sub>512</sub> | 0 | RW | #### Pulse width modulation (PWM) mode <When operating as a 16-bit pulse width modulator> fi: Frequency of count source (f2, f16, f64, or f512) Note: Use the LDM or STA instruction for writing to this register. Read from or write to this register in a unit of 16 bits. <When operating as an 8-bit pulse width modulator> fi: Frequency of count source (f<sub>2</sub>, f<sub>16</sub>, f<sub>64</sub>, or f<sub>512</sub>) Note: Use the LDM or STA instruction for writing to this register. Read from or write to this register in a unit of 16 bits. ### Timer Bi register **Notes 1:** The access characteristics for the timer B0 register and timer B1 register differ according to Timer B's operating mode. 2: Read from or write to this register in a unit of 16 bits. #### Timer Bi mode register Note: Bit 5 is invalid in the timer and event counter modes; its value is undefined at reading. # **APPENDIX** # Appendix 3. Control registers ### Timer mode Note: Read from or write to this register in a unit of 16 bits. | b7 | b6 | b5 | b <sub>4</sub> | × | b2<br><b>X</b> | _ | )1<br>) | 0 | Timer E | i mode register (i = 0 to 2) (Ad | dresses 5B <sub>16</sub> to 5D <sub>16</sub> ) | | | |----|----|----|----------------|------|----------------|---|----------|---|---------|---------------------------------------|-------------------------------------------------|-----------|----| | | | | | | į | | | | Bit | Bit name | Functions | At reset | RW | | į | | į | į | į | į | | | i | 0 | Operating mode select bits | ы ы ы ы ы ы ы ы ы ы ы ы ы ы ы ы ы ы ы | 0 | RW | | | | | | | - | | <u>.</u> | | 1 | | | 0 | RW | | | - | - | | : | į | | | | 2 | These bits are invalid in timer me | ode. | 0 | RW | | - | | | | Ŀ. | | | | | - 3 | | | 0 | RW | | | | | į | <br> | | | | | - 4 | Nothing is assigned. | | Undefined | - | | | | | | <br> | | | | | - 5 | This bit is invalid in timer mode; it | ts value is undefined at reading. | Undefined | RO | | | 1. | | | <br> | | | | | 6 | Count source select bits | b7 b6<br>0 0 : f2<br>0 1 : f16 | 0 | RW | | į | | | | <br> | | | | | 7 | | 1 0 : f <sub>64</sub><br>1 1 : f <sub>512</sub> | 0 | RW | #### **Event counter mode** Note: Read from or write to this register in a unit of 16 bits. | b7 | b6 | 1 | b4 | b3 | b2 | Ť | b | _ | Fimor F | li mada ragiatar (i 0 1) (Addı | rance FD - FC - ) | | | |-------------|----------|-------------|----|----|----|-------------|----------|-----|---------|-----------------------------------------------|----------------------------------------------------------------------------------------------------------|-----------|----| | × | <u>×</u> | <u>×</u> | | Ļ | ۲, | 0 | <u> </u> | Ш ' | imer E | sj mode register (j = 0, 1) (Addr | esses 5B16, 5C16) | | | | | - | !<br>! | | - | - | | | | Bit | Bit name | Functions | At reset | RW | | !<br>!<br>! | ! | !<br>!<br>! | i | - | - | !<br>!<br>! | į | | 0 | Operating mode select bits | b1 b0<br>0 1 : Event counter mode | 0 | RW | | !<br>!<br>! | ! | ! | ÷ | - | - | <u>.</u> | | | 1 | | o i i zioni ocanici meac | 0 | RW | | ! | 1 | ! | | | Ĺ | | | | 2 | Count polarity select bits | b3 b2<br>0 0 : Count at falling edge of external signal<br>0 1 : Count at rising edge of external signal | 0 | RW | | ! | 1 | | | į | | | | | 3 | | 1 0 : Counts at both falling and rising edges of external signal 1 1 : Do not select. | 0 | RW | | | | | į. | | | | | | 4 | Nothing is assigned. | | Undefined | _ | | | 1 | į. | | | | | | | 5 | This bit is invalid in event counter reading. | mode; its value is undefined at | Undefined | RO | | : | - | | | | | | | [ | 6 | These bits are invalid in event co | unter mode. | 0 | RW | | Ŀ. | | | | | | | | [ | 7 | | | 0 | RW | # Pulse period/pulse width measurement mode Note: Read from this register in a unit of 16 bits. | b7 b6 b5 b4 b3 b2 b1 b0 1 0 | Timer | Bj mode register (j = 0, 1) (Add | dresses 5B16, 5C16) | | | |-----------------------------|-------|----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|----| | | Bit | Bit name | Functions | At reset | RW | | | 0 | Operating mode select bits | 1 0 : Pulse period/Pulse width | 0 | RW | | [ | 1 | | measurement mode | 0 | RW | | | 2 | Measurement mode select bits | 0 0 : Pulse period measurement (Interval between falling edges of measurement pulse) 0 1 : Pulse period measurement (Interval between rising edges | 0 | RW | | | 3 | | of measurement pulse) 1 0 : Pulse width measurement (Interval from a falling edge to a rising edge, and from a rising edge to a falling edge of measurement pulse) 1 1 : Do not select. | 0 | RW | | ļ | 4 | Nothing is assigned. | | Undefined | - | | | 5 | Timer Bj overflow flag (Note) | 0 : No overflow<br>1 : Overflowed | Undefined | RO | | | 6 | Count source select bits | 67 66<br>0 0 : f2<br>0 1 : f16 | 0 | RW | | | 7 | | 1 0 : f <sub>64</sub><br>1 1 : f <sub>512</sub> | 0 | RW | **Note:** The timer Bj overflow flag is cleared to "0" at the next count timing of the count source when a value is written to the timer Bj mode register with the count start bit = "1." # Processor mode register 0 | b7 b6 b5 b4 b3 b2 b1 b0 | | | | | | |-------------------------|-------|------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------|----------|----| | 0 0 1 | roces | sor mode register 0 (Address 5 | 5E16) | | | | | | | | | | | | Bit | Bit name | Functions | At reset | RW | | | 0 | Fix this bit to "0." | | 0 | RW | | | 1 | Nothing is assigned.<br>The value is "1" at reading. | | 1 | - | | | 2 | Wait bit | Software Wait is inserted when accessing external area. No software Wait is inserted when accessing external area. | 0 | RW | | <u> </u> | 3 | Software reset bit | The microcomputer is reset by writing "1" to this bit. The value is "0" at reading. | 0 | wo | | | 4 | Interrupt priority detection time select bits | b5 b4<br>0 0 : 7 cycles of φ<br>0 1 : 4 cycles of φ | 0 | RW | | | 5 | | 1 0 : 2 cycles of φ<br>1 1 : Do not select. | 0 | RW | | 1 | 6 | Fix this bit to "0." | | 0 | RW | | <u> </u> | 7 | Stack bank select bit | 0 : Bank 0 <sub>16</sub><br>1 : Bank FF <sub>16</sub> | 0 | RW | # Processor mode register 1 Notes 1: For the M37721S1BFP, fix bit 1 to "0." 2: For the M37721S2BFP, set bit 1 before setting the stack pointer. # Watchdog timer register ## Watchdog timer frequency select register # Real-time output control register Real-time output control register (Address 62<sub>16</sub>) | _ | | | | | | |-----|--------|------------------------------------------------------|--------------------------------------|-----------|----| | | Bit | Bit name | Functions | At reset | RW | | -[ | 0 | Waveform output select bits | See the following Table. | 0 | RW | | -[ | 1 | | | 0 | RW | | - [ | 2 | Pulse output mode select bit | 0 : Pulse mode 0<br>1 : Pulse mode 1 | 0 | RW | | -[ | 7 to 3 | Nothing is assigned.<br>The value is "0" at reading. | | Undefined | _ | **Note:** When using the P6<sub>0</sub>–P6<sub>7</sub> pins as the pulse output pins for real-time output, set the corresponding bits of the port P6 direction register (address 10<sub>16</sub>) to "1." | b1 b0 | 00 | 01 | 10 | 11 | |-------------------------------|----------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------| | When pulse mode 0 | O P67/RTP13 O P66/RTP12 O P65/RTP11 O P64/RTP10 | P67/RTP13 P66/RTP12 P65/RTP11 P64/RTP10 | P67/RTP13 P66/RTP12 P65/RTP11 P64/RTP10 | <ul> <li>─○ P67/RTP13</li> <li>─○ P66/RTP12</li> <li>─○ P65/RTP11</li> <li>─○ P64/RTP10</li> </ul> | | is selected | - P63/RTP03<br>- P62/RTP02<br>- P61/RTP01<br>- P60/RTP00 | P6 <sub>3</sub> /RTP0 <sub>3</sub><br>P6 <sub>2</sub> /RTP0 <sub>2</sub><br>P6 <sub>1</sub> /RTP0 <sub>1</sub><br>P6 <sub>0</sub> /RTP0 <sub>0</sub> | P6 <sub>3</sub> /RTP0 <sub>3</sub><br>P6 <sub>2</sub> /RTP0 <sub>2</sub><br>P6 <sub>1</sub> /RTP0 <sub>1</sub><br>P6 <sub>0</sub> /RTP0 <sub>0</sub> | O P63/RTP03 O P62/RTP02 O P61/RTP01 O P66/RTP00 | | When pulse mode 1 is selected | - P67/RTP13<br>- P66/RTP12<br>- P66/RTP11<br>- P64/RTP10<br>- P63/RTP03<br>- P62/RTP02 | | - P67/RTP13<br>- P66/RTP12<br>- P66/RTP11<br>- P64/RTP10<br>- P63/RTP03<br>- P62/RTP02 | - P67/RTP13<br>- P66/RTP12<br>- P65/RTP11<br>- P64/RTP10<br>- P63/RTP03<br>- P62/RTP02 | | | | | > P6 <sub>1</sub> /RTP0 <sub>1</sub> Port | -O P61/RTP01<br>-O P60/RTP00 RTP | Port : This functions as a programmable I/O port. RTP : This functions as a pulse output pin. #### **DRAM** control register Note: Set the refresh timer (address 66<sub>16</sub>) before setting this bit to "1." #### Refresh timer Note: Use the LDM or STA instruction for writing to this register. Do not set this register to "00<sub>16</sub>." #### **DMAC** control register L Notes 1. The state of bits 4 to 7 are not changed when writing "1" to these bits. - 2. •When writing to this register while any of DMAi enable bits (bits 4 to 7 at address 69<sub>16</sub>) is "1," set m flag to "1" and use the **LDM** or **STA** instruction. When DMAi request bit (bits 4 to 7 at address 68<sub>16</sub>) must not be changed, set DMAi request bit to "1." - •When writing to this register while all of DMAi enable bits (bits 4 to 7 at address 69<sub>16</sub>) are "0," m flag may be "0" or "1." Use the **LDM** or **STA** instruction for writing to this register. When DMAi request bit (bits 4 to 7 at address 68<sub>16</sub>) must not be changed, set DMAi request bit to "1." #### **DMAC** control register H **Note:** When any of bits 4 to 7 is set to "1," use the **CLB** or **SEB** instruction for writing to this register. ### Interrupt control register | | | DMA3, A-D conversion, UART0 and 1<br>control registers (Addresses 6C <sub>16</sub> to 70 | transmit, UART0 and 1 receive, timers A0 | ) to A4, tim | ners B0 to B2 | |---------------------------------------|--------|------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|--------------|---------------| | | Bit | Bit name | Functions | At reset | RW | | \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ | - 0 | Interrupt priority level select bits | b2 b1 b0<br>0 0 0 : Level 0 (Interrupt disabled)<br>0 0 1 : Level 1<br>0 1 0 : Level 2 | 0 | RW | | <u> </u> | - 1 | | 0 1 0 : Level 2<br>0 1 1 : Level 3<br>1 0 0 : Level 4<br>1 0 1 : Level 5 | 0 | RW | | 1 | 2 | | 110: Level 6<br>111: Level 7 | 0 | RW | | | 3 | Interrupt request bit | 0 : No interrupt requested<br>1 : Interrupt requested | 0 | RW | | <u> </u> | 7 to 4 | Nothing is assigned. | | Undefined | _ | Note: The interrupt request bits of INTo to INTo interrupts are invalid when the level sense is selected. ### Source address register i Source address register 0 (Addresses 1FC2<sub>16</sub> to 1FC0<sub>16</sub>) Source address register 1 (Addresses 1FD2<sub>16</sub> to 1FD0<sub>16</sub>) Source address register 2 (Addresses 1FE2<sub>16</sub> to 1FE0<sub>16</sub>) Source address register 3 (Addresses 1FF2<sub>16</sub> to 1FF0<sub>16</sub>) | Bit | Functions | At reset | RW | |-------------|----------------------------------------------------------------------|-----------|----| | <br>23 to 0 | These bits have different functions according to the operating mode. | Undefined | RW | Note: When writing to this register, write to all 24 bits. ## Destination address register i Destination address register 0 (Addresses 1FC6<sub>16</sub> to 1FC4<sub>16</sub>) Destination address register 1 (Addresses 1FD6<sub>16</sub> to 1FD4<sub>16</sub>) Destination address register 2 (Addresses 1FE6<sub>16</sub> to 1FE4<sub>16</sub>) Destination address register 3 (Addresses 1FF6<sub>16</sub> to 1FF4<sub>16</sub>) | Bit | Functions | At reset | RW | |-------------|----------------------------------------------------------------------|-----------|----| | <br>23 to 0 | These bits have different functions according to the operating mode. | Undefined | RW | Note: When writing to this register, write to all 24 bits. #### Transfer counter register i Transfer counter register 0 (Addresses 1FCA<sub>16</sub> to 1FC8<sub>16</sub>) Transfer counter register 1 (Addresses 1FDA<sub>16</sub> to 1FD8<sub>16</sub>) Transfer counter register 2 (Addresses 1FEA<sub>16</sub> to 1FE8<sub>16</sub>) Transfer counter register 3 (Addresses 1FFA<sub>16</sub> to 1FF8<sub>16</sub>) | | Bit | Functions | At reset | RW | |---|---------|----------------------------------------------------------------------|-----------|----| | - | 23 to 0 | These bits have different functions according to the operating mode. | Undefined | RW | Note: When writing to this register, write to all 24 bits. Do not write "00000016" to this register. #### Single transfer mode Source address register 0 (Addresses 1FC2<sub>16</sub> to 1FC0<sub>16</sub>) Source address register 1 (Addresses 1FD2<sub>16</sub> to 1FD0<sub>16</sub>) Source address register 2 (Addresses 1FE2<sub>16</sub> to 1FE0<sub>16</sub>) Source address register 3 (Addresses 1FF2<sub>16</sub> to 1FF0<sub>16</sub>) | Bit | Functions | At reset | RW | |---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|----| | 23 to 0 | [Write] Set the transfer start address of the source. These bits can be set to "00000016" to "FFFFFF16." [Read] The read value indicates the source address of data which is next transferred. | Undefined | RW | Note: When writing to this register, write to all 24 bits. Destination address register 0 (Addresses 1FC616 to 1FC416) Destination address register 1 (Addresses 1FD616 to 1FD416) Destination address register 2 (Addresses 1FE616 to 1FE416) Destination address register 3 (Addresses 1FF616 to 1FF416) | | Bit | Functions | At reset | RW | |---|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|----| | - | 23 to 0 | [Write] Set the transfer start address of the destination. These bits can be set to "00000016" to "FFFFFF16." [Read] The read value indicates the destination address of data which is next transferred. | Undefined | RW | Note: When writing to this register, write to all 24 bits. Transfer counter register 0 (Addresses 1FCA<sub>16</sub> to 1FC8<sub>16</sub>) Transfer counter register 1 (Addresses 1FDA<sub>16</sub> to 1FD8<sub>16</sub>) Transfer counter register 2 (Addresses 1FEA<sub>16</sub> to 1FE8<sub>16</sub>) Transfer counter register 3 (Addresses 1FFA<sub>16</sub> to 1FF8<sub>16</sub>) | Bit | Functions | At reset | RW | |---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|----| | 23 to 0 | [Write] Set the byte number of the transfer data. These bits can be set to "00000116" to "FFFFFF16." [Read] The read value indicates remaining byte number of the transfer data. | Undefined | RW | Note: When writing to this register, write to all 24 bits. Do not set this register to "00000016." #### Repeat transfer mode Source address register 0 (Addresses 1FC2<sub>16</sub> to 1FC0<sub>16</sub>) Source address register 1 (Addresses 1FD2<sub>16</sub> to 1FD0<sub>16</sub>) Source address register 2 (Addresses 1FE2<sub>16</sub> to 1FE0<sub>16</sub>) Source address register 3 (Addresses 1FF2<sub>16</sub> to 1FF0<sub>16</sub>) | Bit | Functions | At reset | RW | |-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|----| | <br>23 to 0 | [Write] Set the transfer start address of the source. These bits can be set to "00000016" to "FFFFFF16." [Read] The read value indicates the source address of data which is next transferred. | Undefined | RW | Note: When writing to this register, write to all 24 bits. Destination address register 0 (Addresses 1FC6<sub>16</sub> to 1FC4<sub>16</sub>) Destination address register 1 (Addresses 1FD6<sub>16</sub> to 1FD4<sub>16</sub>) Destination address register 2 (Addresses 1FE6<sub>16</sub> to 1FE4<sub>16</sub>) Destination address register 3 (Addresses 1FF6<sub>16</sub> to 1FF4<sub>16</sub>) | | Bit | Functions | At reset | RW | |---|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|----| | - | 23 to 0 | [Write] Set the transfer start address of the destination. These bits can be set to "00000016" to "FFFFFF16." [Read] The read value indicates the destination address of data which is next transferred. | Undefined | RW | Note: When writing to this register, write to all 24 bits. Transfer counter register 0 (Addresses 1FCA<sub>16</sub> to 1FC8<sub>16</sub>) Transfer counter register 1 (Addresses 1FDA<sub>16</sub> to 1FD8<sub>16</sub>) Transfer counter register 2 (Addresses 1FEA<sub>16</sub> to 1FE8<sub>16</sub>) Transfer counter register 3 (Addresses 1FFA<sub>16</sub> to 1FF8<sub>16</sub>) | Bit | Functions | At reset | RW | |-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|----| | <br>23 to 0 | [Write] Set the byte number of the transfer data. These bits can be set to "00000116" to "FFFFFF16." [Read] The read value indicates the remaining byte number of the block which is being transferred. | Undefined | RW | **Note:** When writing to this register, write to all 24 bits. Do not write "00000016" to this register. #### Array chain transfer mode Source address register 0 (Addresses 1FC2<sub>16</sub> to 1FC0<sub>16</sub>) Source address register 1 (Addresses 1FD2<sub>16</sub> to 1FD0<sub>16</sub>) Source address register 2 (Addresses 1FE2<sub>16</sub> to 1FE0<sub>16</sub>) Source address register 3 (Addresses 1FF2<sub>16</sub> to 1FF0<sub>16</sub>) | Bit | Functions | At reset | RW | |-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|----| | <br>23 to 0 | [Write] Set the start address of transfer parameter memory. These bits can be set to "00000016" to "FFFFFF16." [Read] •After a value is written to this register and until transfer starts, the read value indicates the written value (the start address of the transfer parameter memory). •After tranfer starts, the read value indicates the source address of data which is next transferred. | Undefined | RW | Note: When writing to this register, write to all 24 bits. Destination address register 0 (Addresses 1FC6<sub>16</sub> to 1FC4<sub>16</sub>) Destination address register 1 (Addresses 1FD6<sub>16</sub> to 1FD4<sub>16</sub>) Destination address register 2 (Addresses 1FE6<sub>16</sub> to 1FE4<sub>16</sub>) Destination address register 3 (Addresses 1FF6<sub>16</sub> to 1FF4<sub>16</sub>) | Bit | Functions | At reset | RW | |---------|------------------------------------------------------------------------------------------------------------------------------------|-----------|----| | 23 to 0 | Need not to set. [Read] After transfer starts, the read value indicates the destination address of data which is next transferred. | Undefined | RW | Transfer counter register 0 (Addresses 1FCA<sub>16</sub> to 1FC8<sub>16</sub>) Transfer counter register 1 (Addresses 1FDA<sub>16</sub> to 1FD8<sub>16</sub>) Transfer counter register 2 (Addresses 1FEA<sub>16</sub> to 1FE8<sub>16</sub>) Transfer counter register 3 (Addresses 1FFA<sub>16</sub> to 1FF8<sub>16</sub>) | Bit | Functions | At reset | RW | |---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|----| | 23 to 0 | [Write] Set the number of transfer blocks. These bits can be set to "00000116" to "FFFFFF16." [Read] •After a value is written to this register and until transfer starts, the read value indicates the written value (the transfer block number). •After transfer starts, the read value indicates the remaining byte number of the block which is being transferred. | Undefined | RW | Note: When writing to this register, write to all 24 bits. Do not write "00000016" to this register. #### Link array chain transfer mode Source address register 0 (Addresses 1FC2<sub>16</sub> to 1FC0<sub>16</sub>) Source address register 1 (Addresses 1FD2<sub>16</sub> to 1FD0<sub>16</sub>) Source address register 2 (Addresses 1FE2<sub>16</sub> to 1FE0<sub>16</sub>) Source address register 3 (Addresses 1FF2<sub>16</sub> to 1FF0<sub>16</sub>) | Bit | Functions | At reset | RW | |-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|----| | <br>23 to 0 | [Write] Set the start address of transfer parameter memory of block which is first transferred. These bits can be set to "00000016" to "FFFFFF16." [Read] •After a value is written to this register and until transfer starts, the read value indicates the written value (the start address of the transfer parameter memory of block which is first transferred). •After transfer starts, the read value indicates the source address of data which is next transferred. | Undefined | RW | Note: When writing to this register, write to all 24 bits. Destination address register 0 (Addresses 1FC6<sub>16</sub> to 1FC4<sub>16</sub>) Destination address register 1 (Addresses 1FD6<sub>16</sub> to 1FD4<sub>16</sub>) Destination address register 2 (Addresses 1FE6<sub>16</sub> to 1FE4<sub>16</sub>) Destination address register 3 (Addresses 1FF6<sub>16</sub> to 1FF4<sub>16</sub>) | | Bit | Functions | | RW | |----|-----|------------------------------------------------------------------------------------------------------------------------------------|--|----| | 23 | | Need not to set. [Read] After transfer starts, the read value indicates the destination address of data which is next transferred. | | RW | Transfer counter register 0 (Addresses 1FCA<sub>16</sub> to 1FC8<sub>16</sub>) Transfer counter register 1 (Addresses 1FDA<sub>16</sub> to 1FD8<sub>16</sub>) Transfer counter register 2 (Addresses 1FEA<sub>16</sub> to 1FE8<sub>16</sub>) Transfer counter register 3 (Addresses 1FFA<sub>16</sub> to 1FF8<sub>16</sub>) | Bit | Functions | At reset | RW | |---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|----| | 23 to 0 | [Write] Set the dummy data. These bits can be set to "00000116" to "FFFFFF16." [Read] •After a value is written to this register and until transfer starts, the read value indicates the written value (dummy data). •After transfer starts, the read value indicates the remaining byte number of the block which is being transferred. | Undefined | RW | Note: When writing to this register, write to all 24 bits. Do not write "00000016" to this register. #### DMAi mode register L Note: When the external data bus has a width of 8 bits and 1-bus cycle transfer is selected, set bit 0 to "1." ### DMAi mode register H Notes 1: Set bit 0 to "0" in 2-bus cycle transfer. 2: Bits 4 and 5 are valid to the external and internal areas. However, DRAM area is always handled with "Wait" regardless of the contents of these bits. The wait bit (bit 2 at address 5E<sub>16</sub>) is invalid in DMA transfer. # **DMAi** control register | | | Bit | Bit name | Functions | At reset | RW | |----------|----------|-----|--------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------|-----------|----| | | | 0 | DMA request source select bits (Note) | b3b2b1b0<br>0 0 0 0 : Do not select.<br>0 0 0 1 : External source (DMAREQi)<br>0 0 1 0 : Software DMA source | 0 | RW | | <u> </u> | | 1 | | 0 0 1 1 : Timer A0<br>0 1 0 0 : Timer A1<br>0 1 0 1 : Timer A2<br>0 1 1 0 : Timer A3<br>0 1 1 1 : Timer A4 | 0 | RW | | | | 2 | | 1 0 0 0 : Timer B0<br>1 0 0 1 : Timer B1<br>1 0 1 0 : Timer B2<br>1 0 1 1 : UART0 receive | 0 | RW | | | - | 3 | | 1 1 0 0 : UART0 transmit<br>1 1 0 1 : UART1 receive<br>1 1 1 0 : UART1 transmit<br>1 1 1 1 : A-D conversion | 0 | RW | | | <u>'</u> | 4 | Edge sense/Level sense select<br>bit (Used when external source<br>and burst transfer mode are<br>selected) (Note) | 0 : Edge sense (Falling edge)<br>1 : Level sense ("L" level) | 0 | RW | | | <u>.</u> | 5 | DMAACKi validity bit | 0 : Invalid (The pin functions as a programmable I/O port.) 1 : Valid (The pin functions as DMAACKi.) | 0 | RW | | | | | Nothing is assigned. | | Undefined | _ | transfer mode are selected. Note: When a certain source other than an external source is selected by bits 0 to 3 or when the cycle-steal transfer mode is selected, set bit 4 to "0." Level sense can be selected only when both of the external source and the burst # Appendix 4. Package outline ## Appendix 5. Examples of handling unused pins Examples of handling unused pins are described below. These descriptions are just examples. <u>The user shall modify them according to the actual application and test them.</u> Table 1 Examples of handling unused pins | Pins | Handling example | | | | |------------------------------------------------------------------------------|--------------------------------------------------------|--|--|--| | P4 <sub>3</sub> to P4 <sub>7</sub> , P5 to P10 | Connect these pins to the Vcc or Vss pin via resistors | | | | | | after these pins are set to the input mode, or leave | | | | | | these pins open after they are set to the output mode | | | | | | (Notes 1, 2). | | | | | $\overline{\text{BLE}}$ , $\overline{\text{BHE}}$ , ALE, $\phi_1$ , ST0, ST1 | Leave this pin open. | | | | | Xout (Note 3) | Leave this pin open. | | | | | HOLD, RDY | Connect these pins to the Vcc pin via resistors (These | | | | | | pins are pulled high.) (Note 2) | | | | | CNVss | Connect this pin to the Vcc pin or Vss pin. | | | | | AVcc | Connect this pin to the Vcc pin. | | | | | AVSS, VREF | Connect these pins to the Vss pin. | | | | - **Notes 1:** When leaving these pins open after they are set to the output mode, note the following: these pins function as input ports from reset until they are switched to the output mode by software. Therefore, voltage levels of these pins are undefined and the power source current may increase while these pins function as input ports. Accordingly, set these ports to the output mode immediately after reset. Software reliability can be enhanced when the contents of the above ports' direction registers are set periodically. This is because these contents may be changed by noise, a program runaway which occurs to noise, etc. - 2: For unused pins, use the shortest possible wiring (within 20 mm from the microcomputer's pins). - 3: This applies when a clock externally generated is input to the X<sub>IN</sub> pin. Fig. 2 Examples of handling unused pins ## **Appendix 6. Machine instructions** | | | | | | _ | | | _ | | | | , | Add | ress | sing | m | ode | es | | | | | | | _ | _ | |--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|-----|---------|-----|----------------|-----|---|----|------------|-----|------|---------|-----|------------|-----|--------|---|----------------|---------|-----|------|----------------|-----| | Symbol | Functions | Details | 11 | MP | | IM | М | | Α | | D | IR | D | IR,b | | DIF | R,X | | DIR, | Υ | (DI | R) | (DI | R,X) | (DI | R), | | | | | ор | n | # o | p r | n # | б | n | # | ор | n # | ор | n | # ( | ор | n # | ‡ c | p n | # | ор | n # | ор | n # | ор | n | | ADC<br>(Notes 1,2) | Acc,C←Acc+M+C | Adds the carry, the accumulator and the memory contents. The result is entered into the accumulator. When the D flag is "0," binary additions is done, and when the D flag is "1," decimal addition is done. | | | 4 | $\perp$ | 2 2 | 1 | | | _ | 4 2<br>6 3 | 1 | | 4 | _ | 5 2<br>7 3 | 1 | | | 72<br>42<br>72 | | | 9 3 | 71<br>42<br>71 | | | AND<br>(Notes 1,2) | Acc←Acc∧M | Obtains the logical product of the contents of the accumulator and the contents of the memory . The result is entered into the accumulator. | | | L | 2 4 | 2 2 | 1 | | | _ | 4 2<br>6 3 | 1 | | 2 | | 5 2<br>7 3 | 1 | | | 32<br>42<br>32 | 8 3 | | 9 3 | 31<br>42<br>31 | 10 | | ASL<br>(Note 1) | $m=0$ $C \leftarrow b_{15} \cdots b_{0} \leftarrow 0$ $m=1$ $C \leftarrow b_{7} \cdots b_{0} \leftarrow 0$ | Shifts the accumulator or the memory contents one bit to the left. "0" is entered into bit 0 of the accumulator or the memory. The contents of bit 15 ( bit 7 when the m flag is "1") of the accumulator or memory before shift is entered into the C flag. | | | | | | 0A<br>42<br>0A | 2 4 | 1 | 06 | 7 2 | : | | 1 | 16 | 7 2 | 2 | | | | | | | | | | BBC<br>(Notes 3,5) | Mb=0? | Tests the specified bit of the memory. Branches when all the contents of the specified bit is "0." | | | | | | | | | | | | | | | | | | | | | | | П | _ | | BBS<br>(Notes 3,5) | Mb=1? | Tests the specified bit of the memory. Branches when all the contents of the specified bit is "1." | | | | | | | | | | | | | | | | | | | | | | | П | | | BCC<br>(Note 3) | C=0? | Branches when the contents of the C flag is "0." | | | | | | | | | | | | | | | | | | | | | | | | | | BCS<br>(Note 3) | C=1? | Branches when the contents of the C flag is "1." | | | | | | | | | | | | | | | | | | | | | | | | | | BEQ<br>(Note 3) | Z=1? | Branches when the contents of the Z flag is "1." | | | | | | | | | | | | | | | | | | | | | | | | | | BMI<br>(Note 3) | N=1? | Branches when the contents of the N flag is "1." | | | I | | | | | | | | | | | | | | | | | | | | | | | BNE<br>(Note 3) | Z=0? | Branches when the contents of the Z flag is "0." | | | | | | | | | | | | | | | | | | | | | | | | | | BPL<br>(Note 3) | N=0? | Branches when the contents of the N flag is "0." | | | | | | | | | | | | | | | | | | | | | | | | | | BRA<br>(Note 4) | PC←PC±offset<br>PG←PG+1<br>(when carry occurs)<br>PG←PG-1<br>(when borrow occurs) | Jumps to the address indicated by the program counter plus the offset value. | | | | | | | | | | | | | | | | | | | | | | | | | | BRK | $\begin{array}{l} PC \leftarrow PC + 2 \\ M(S) \leftarrow PG \\ S \leftarrow S - 1 \\ M(S) \leftarrow PCH \\ S \leftarrow S - 1 \\ M(S) \leftarrow PCL \\ S \leftarrow S - 1 \\ M(S) \leftarrow PS + \\ S \leftarrow S - 1 \\ M(S) \leftarrow PS + \\ S \leftarrow S - 1 \\ M(S) \leftarrow PS + \\ S \leftarrow S - 1 \\ I \leftarrow 1 \\ PC \leftarrow ADL \\ PC \leftarrow ADL \\ PC \leftarrow ADH \\ PG \leftarrow O016 \\ \end{array}$ | Executes software interruption. | 00 | 15 | 2 | | | | | | | | | | | | | | | | | | | | | | | BVC<br>(Note 3) | V=0? | Branches when the contents of the V flag is "0." | | | | | | | | | | | | | | | | | | | | | | | | | | BVS<br>(Note 3) | V=1? | Branches when the contents of the V flag is "1." | | | I | | | | | | | | | | | | | | | | | | | | | | | CLB<br>(Note 5) | Mb←0 | Makes the contents of the specified bit in the memory "0." | | | I | | | | | | | | 14 | 8 | 3 | | | | | | | | | | | | | CLC | C←0 | Makes the contents of the C flag "0." | _ | 2 | _ | | | L | | Ц | | | | Ш | | | | 1 | | Ц | | | Ш | | Ц | | | CLI | I←0 | Makes the contents of the I flag "0." | 58 | 2 | 1 | 1 | 1 | L | | Ц | | | | Ц | 1 | 4 | 1 | 1 | _ | Ц | | | Ц | 1 | Ц | _ | | CLM | m←0 | Makes the contents of the m flag "0." | D8 | 2 | 1 | $\perp$ | | L | | Ц | | | L | Ш | $\perp$ | | | | | Ц | | $\perp$ | Ш | | Ц | | | CLP | PSb←0 | Specifies the bit position in the processor status register by the bit pattern of the second byte in the instruction, and sets "0" in that bit. | | | С | 2 4 | 1 2 | 2 | | | | | | | | | | | | | | | | | | | | CLV | V←0 | Makes the contents of the V flag "0." | B8 | 2 | 1 | T | | | | П | | | | | T | | | | $\top$ | | | | | | П | | | CMP<br>(Notes 1,2) | Acc-M | Compares the contents of the accumulator with the contents of the memory. | | | 4 | | 2 2 | 1 | | П | | 4 2 | 1 | | 4 | | 5 2<br>7 3 | | | Ш | | 6 2 | | | D1 | | | | | | | | | | | | | | | | | | | | | | | _ | hΑ | dre | 222 | in | n r | no | de | <u> </u> | | | | | | | | | | | | | | | | | | | | $\neg$ | Г | —<br>Pro | | | r st | | s re | onis | ter | ٦ | |----------|----------------|---------------|-------------|--------------|-----------|---|----------|----------|---|----------|----|----|---------------|-----------|-----|-----------|-----------|--------------|----------|---|----------|----------|----------|--------------|-----|--------|--------------|----------|-----------|--------------|-----|---|----------|-----|---|----|-------------|---|----------|-----------|--------------|-----------|---|-------------|-----------|--------------|-----|---------------|-----------|-----------|---------------|---------------|------|--------------|---------|---------|----------|---------------| | 1.0 | DIR) | Lια | י (אוח | γĪ | AB | S | ΙΔ | BS | h | A | BS | × | ΙΔ | ıRS | . Y | T | AE | RI | ΤΔ | | _ | _ | | _ | _ | | s) (a | | S X | م | ST | ĸ | T | REL | | וח | R h | R | ARS | S,b,F | T | SR | | (SR | ) Y | T | BLK | $\overline{}$ | 10 | | | | | | | | | _ | | $\vdash$ | n # | ┺ | | _ | | | ┖ | | | ــــ | | | ┸ | _ | | ┸ | _ | | _ | | _ | Ь. | | _ | | _ | _ | | | 1 | | | ᆫ | | | ᆫ | | _ | | | | | | Ь. | | _ | | | - | PL | | | | | x D | | | | | $\vdash$ | $\vdash$ | + | + | + | + | + | ⊢ | n | - | ⊢ | - | + | - | - | + | - | - | _ | - | - | $\vdash$ | $\vdash$ | n | # | Jh | 11 3 | # 0 | ν r | 1 7 | + of | - r | # | op | n | # | op | II) | # | oh | n # | - | + | - | $\vdash$ | + | + | 'n | # | ₩. | | $\rightarrow$ | $\rightarrow$ | + | + | - | + | $\vdash$ | $\dashv$ | | | 10 2 | 1 | | | | | | | | l | | | ı | | | 1 | | | 7F | | | | | | | | | | | | | | | | | | | | | | | | | 73 | | | | | $ \cdot $ | $ \cdot $ | | N | ۷ | <u>'</u> | • | • | Z | C | | 67 | | 77 | | 6[ | 기 | | | | | 42<br>7D | 8 | 4 | 4:<br>7: | 2 8<br>9 | 4 | 42<br>61 | 2 E | 3 5 | 42<br>7F | 9 | 5 | | | | | | | | | | | | | | | | | | | | 42<br>63 | 2 7 | 3 | 42<br>73 | 10 3 | 3 | | | | | | | | | | | | | | 27 | 10 2 | 37 | 11 2 | 2 20 | ) 4 | 3 | | | | 3D | 6 | 3 | 39 | 9 6 | 3 | 3 2 | F 6 | 6 4 | 3F | 7 | 4 | | | | | | | | | | | | Г | | | | | | | | 2 | 3 5 | 2 | 33 | 8 2 | 2 | | | | $\cdot$ | • | N | • | • | • | • | z | - | | 42<br>27 | 12 3 | 3<br>42<br>37 | 13 3 | 3 4: | 2 6<br>D | 4 | 1 | | | 42<br>3D | 8 | 4 | 4: | 2 8 | 4 | 42 | 2 E | 3 5 | 42<br>3F | 9 | 5 | | | | | | | | | | | | | | | | | | | | 4: | 2 7 | 3 | 42<br>33 | 10 3 | 3 | | | | | | | | | | | | | | | | T | | 0 | E 7 | 3 | | | | 1E | 8 | 3 | | | | t | t | | | | | П | | | | 1 | T | | | T | | | ı | | | | | ı | | | T | | | | | T | | П | • | • | • | N | • | , | | • | z | С | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | $\vdash$ | | ┞ | H | + | | | | | | L | - | | - | | | - | + | + | | | | H | | - | | | + | 1 | | + | | | L | | | 34 | 7 | 4 | 3C | 8 5 | + | | | | | + | | Н | | | | + | | <del> </del> | | | | $\frac{1}{2}$ | | | | L | | + | | | | | | L | ŀ | | ŀ | | ŀ | + | + | + | | | | | | 1 | | | + | | - | + | | | L | | | | | | | 8 5 | | | | | _ | $\downarrow$ | | Н | | | | | | | | | | $\frac{1}{2}$ | | | | L | | 1 | | | L | | | L | | | | | | L | | | | | | | | 1 | | 1 | 1 | | | 1 | | | L | | | 24 | <u> </u> | 4 | 20 | 8 3 | 1 | | | | | L | | | Ш | | | | | | | | | ] | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | L | | 2 | | | | | | | | | | | | | | | • | | | | | • | | • | • | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | ВС | 4 | 2 | | | | | | | | | | | | | | • | • | • | • | • | • | • • | • | • | $\cdot$ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | F | 4 | 2 | | | | | | | | | | | | | | • | • | • | • | • | | • | • | • | • | | | | T | Ħ | l | | l | | | | | İ | l | Ī | | İ | T | T | T | | | | | | 1 | | 1 | T | | T | T | | | 30 | 4 | 2 | | П | | 1 | 1 | l | | | | | T | | П | • | | • | • | • | | • | • | • | - | | | $\parallel$ | T | $\parallel$ | l | $\dagger$ | | | | | r | t | | t | $\dagger$ | I | $\dagger$ | $\dagger$ | $\dagger$ | | | | H | | $\dagger$ | | + | $\dagger$ | | | $\dagger$ | | | DO | 4 | 2 | | $\parallel$ | 1 | $\dashv$ | $\dagger$ | t | $\dagger$ | | | $\dagger$ | t | | Н | • | $ \cdot $ | • | + | • | + | • | • | • | 1 | | | | $\vdash$ | $\parallel$ | $\dagger$ | + | H | | | | $\vdash$ | t | | | $\dagger$ | + | $\dagger$ | $\dagger$ | + | | | | H | | $\dagger$ | + | | $\dagger$ | + | $\dagger$ | $\dagger$ | | | 10 | 4 | 2 | | | + | 1 | | $\dagger$ | | | $\parallel$ | $\dagger$ | $\dagger$ | | $\vdash$ | • | • | • | • | • | + | • • | • | • | 1 | | | | $\vdash$ | | - | + | | | | | | | | | + | | + | $\dagger$ | + | | | | H | | $\dagger$ | 1 | + | $\dagger$ | | + | $\dagger$ | | | 80 | 4 | 2 | | | + | | | + | + | | H | + | $\dagger$ | + | $\vdash$ | | - | • | • | • | + | | • | • | $\cdot$ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 82 | 4 | 3 | | | | | | | | | | | | | | | | | | | | | | | | | | | $\vdash$ | H | - | | | | | | H | H | | - | | | | + | | | | | H | | + | + | + | + | + | + | + | | + | F | ľ | H | | | + | $\dashv$ | + | - | | | dash | + | + | | H | | | • | + | | + | | | • | • | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | l | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | l | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | l | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | l | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | П | T | | l | | l | | | | | İ | l | Ī | T | I | T | T | T | | | | | | T | | ı | T | İ | Ì | T | | | 50 | 4 | 2 | | П | | | 1 | İ | | | | $\dagger$ | T | | | • | • | • | • | • | • | • | • | • | • | | | $\parallel$ | | $\parallel$ | | | | | | | | İ | | | | | | Ì | | | | | | | 1 | | 1 | $\dagger$ | | | $\dagger$ | | | 70 | 4 | 2 | | | | | | l | | | | $\dagger$ | | | П | • | • | • | • | • | • | • | • | • | • | | | | t | $\dagger$ | l | $\dagger$ | l | IC | 9 | 4 | | H | | | $\dagger$ | | $\dagger$ | $\dagger$ | $\dagger$ | | | | H | | $\dagger$ | 1 | + | $\dagger$ | l | $\dagger$ | $\dagger$ | | | H | | | | H | 1 | + | $\dagger$ | ŀ | $\dagger$ | | $\parallel$ | $\dagger$ | t | | Н | • | • | • | • | • | • | • | • | | • | | $\vdash$ | $\dashv$ | + | H | + | + | | H | | | $\vdash$ | H | | $\frac{1}{1}$ | | + | + | + | + | | | | H | 1 | + | + | + | + | + | + | + | | | $\vdash$ | | | _ | $\parallel$ | + | $\dashv$ | + | $\dagger$ | + | | $\vdash$ | + | $\dagger$ | + | $\forall$ | | • | • | • | • | | | • | • | 0 | | T | $ \uparrow $ | T | $\sqcap$ | t | T | T | T | T | | T | | T | Ť | T | Ť | Ť | Ť | t | T | T | | П | 1 | † | 1 | † | t | T | t | Ť | t | T | T | T | П | | Ħ | 1 | 1 | 1 | t | T | | П | T | Ť | T | П | • | • | - | • | • | | | 0 | • | • | | | Ħ | T | Ħ | T | T | T | T | | | T | | T | T | T | Ť | Ť | Ť | T | T | T | П | П | | Ť | T | T | T | T | Ť | Ť | T | T | T | T | Ħ | Г | П | 1 | | T | T | T | П | | $\dagger$ | Ť | | П | | | | | | 0 . | | | | • | | | $\parallel$ | T | Ħ | l | | l | | | | | t | | t | | t | t | t | | | | | | | 1 | 1 | 1 | T | 1 | İ | T | | | T | | Ħ | | H | | 1 | 1 | t | | | | $\dagger$ | T | | П | Н | • | + | Sp | | fied | d fl | | ш | - | | | | $\perp$ | $\parallel$ | $\downarrow$ | + | | L | | | $\vdash$ | L | | - | + | - | + | + | $\downarrow$ | | | | Ц | | $\downarrow$ | | + | $\downarrow$ | - | - | $\downarrow$ | | _ | L | | | | | | _ | + | $\downarrow$ | + | | Ц | $\perp$ | $\downarrow$ | | Н | Ц | | 1 | | | | _ | | | | | _ | 10 0 | 1- | | 1 | | - | $\vdash$ | $\vdash$ | | - | 1- | 1- | - | 1. | 1 | 1 | _ | + | | 1 | <u> </u> | Н | $\dashv$ | + | + | + | + | + | + | + | + | + | $\vdash$ | + | H | L | Н | + | - | + | 1 | 1- | | | 1 | + | + | Н | Н | Н | $\vdash$ | _ | 0 | + | • • | $\perp$ | | _ | | 1 | 10 2 | | 1 1 | 1 | | 1 | | | | ı | | | ı | | | | | | DF | | | ı | | | | | | | | | | | | | | | | | | | L | | | D3 42 | | ┚ | | | $ \cdot $ | • | $ \cdot $ | N | • | ' ' | • | | Z | С | | 42<br>C7 | 12 3 | D7 | 13 | CI | ב<br>D | 4 | L | | | DD | 0 | 4 | D: | 9 | 14 | C | F E | <u></u> | 42<br>DF | a | ာ | | | $\perp$ | | | | | | | | | L | | | | | | | | 4.<br>C | 3 / | 3 | D3 | 10 3 | Ĺ | | | Ш | Ш | $\rfloor$ | $ \bot $ | | $\perp$ | $\perp$ | | Ц | | | | | | Г | | | | | | | | | | A | Addı | ess | ing | m | ode | s | | | | | | | | | ٦ | |---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|---|----------|----|---|----------------|-----|---|------------|-----|------|------|------------|-----|------|----|------|---|------------|-----|----------|------|---------|-------------|---| | Symbol | Functions | Details | 1 | MP | | IN | ИΜ | | | A | | DI | R | D | IR,b | 1 | DIF | R,X | [ | DIR, | Y | (DI | R) | (DI | R,X) | ([ | OIR), | Y | | | | | ор | n | # | ор | n | # | ор | n i | # | ор | n # | ор | n # | <b>#</b> 0 | ı | n # | op | n | # | op l | n # | ор | n # | e or | n | # | | CPX<br>(Note 2) | X-M | Compares the contents of the index register X with the contents of the memory. | | | | E0 | 2 | 2 | | | ı | E4 4 | 4 2 | | | | | | | | | | | | | | | | | CPY<br>(Note 2) | Y–M | Compares the contents of the index register Y with the contents of the memory. | | | | C0 | 2 | 2 | | | ( | C4 4 | 1 2 | | | | | | | | | | | | | | | | | DEC<br>(Note 1) | Acc←Acc−1 or<br>M←M−1 | Decrements the contents of the accumlator or memory by 1. | | | | | | - | 1A<br>42<br>1A | 4 | 4 | C6 | 7 2 | | | D | 6 | 7 2 | | | | | | | | | | | | DEX | X←X−1 | Decrements the contents of the index register X by 1. | CA | 2 | 1 | | | ı | | Ī | T | | | | | T | | | Ī | | | | | | | T | П | _ | | DEY | Y←Y−1 | Decrements the contents of the index register Y by 1. | 88 | 2 | 1 | | | | | | 1 | | | | | | | | | | | | | | | | П | | | DIV<br>(Notes 2,10) | A(quotient)←B,A/M<br>B(remainder) | The numeral that places the contents of accumlator B to the higher order and the contents of accumulator A to the lower order is divided by the contents of the memory. The quotient is entered into accumulator A and the remainder into accumulator B. | | | | 89<br>29 | 27 | 3 | | | | 89 2<br>25 | 9 3 | | | 3: | | 30 3 | | | | 89 3<br>32 | 1 3 | 89<br>21 | 32 3 | 3: | 9 33 : | 3 | | EOR<br>(Notes 1,2) | Acc←Acc <del>∨</del> M | Logical exclusive sum is obtained of the contents of the accumulator and the contents of the memory. The result is placed into the accumulator. | | | | 49 | 2 | 2 | | | | 45 | 1 2 | | | 5 | 5 5 | 5 2 | | | Ļ | | | | | L | 1 8 : | | | | | praced into the accumulator. | | | | 42<br>49 | 4 | 3 | | | | 42<br>45 | 3 | | | 4:<br>5: | | 7 3 | | | | 42 8<br>52 | 3 | 42<br>41 | 9 3 | 42<br>5 | 2 10 :<br>1 | 3 | | INC<br>(Note 1) | Acc←Acc+1 or<br>M←M+1 | Increments the contents of the accumulator or memory by 1. | | | | | | | 3A<br>42<br>3A | 4 | | E6 · | 7 2 | | | F | 6 | 7 2 | | | | | | | | | | _ | | INX | X←X+1 | Increments the contents of the index register X by 1. | E8 | 2 | 1 | | | Ť | | + | 1 | 1 | | | | t | | | | | | | | H | | t | Ħ | - | | INY | Y←Y+1 | Increments the contents of the index register Y by 1. | C8 | 2 | 1 | | | 1 | | 1 | T | Ì | | | | İ | | | | | | | | | | T | Ħ | 1 | | JSR | ABS PCL←ADL PCH←ADH ABL PCL←ADL PCH←ADH PG←ADG (ABS) PCL←(ADH, ADL) PCH←(ADH, ADL+1) L(ABS) PCL←(ADH, ADL+1) PCH←(ADH, ADL+1) PCH←(ADH, ADL+1) PC+(ADH, ADL+1) PC+(ADH, ADL+1) PC+(ADH, ADL+1) PC+(ADH, ADL+1) PC+(ADH, ADL+X) PC+(ADH, ADL+X) PC+(ADH, ADL+X) PC+(ADH, ADL+X) | Places a new address into the program counter and jumps to that new address. Saves the contents of the program counter (also the con- | | | | | | | | | | | | | | | | | | | | | | | | | | | | JJR | ABS M(S)←PCH S←S−1 M(S)←PCL S←S−1 PCL←ADL PCH←ADL PCH←ADH ABL M(S)←PG S←S−1 M(S)←PCH S←S−1 M(S)←PCH S←S−1 PCL←ADL PCH←ADH PCH←ADH PG←ADG (ABS, X) M(S)←PCH S←S−1 M(S)←PCH S←S−1 PCH←ADH PG←ADH PCH←ADH PCH←ADH PCH←ADH PCH←ADH PCH←(ADH, ADL+X) | Saves the contents of the program counter (also the contents of the program bank register for ABL) into the stack, and jumps to the new address. | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Α | dd | lre | ssi | inç | g n | 10 | des | 5 | | | | | | | | | | | | | | | | | | | | | Τ | Pr | 006 | ess | or s | stat | us | reg | ist | er | ٦ | |-----|------|----|------|------|----|--------|---|----|-----------|---------|---------|-----|----------|-----|--------|----|----|-----------|-----|------|-----------|------|-----|-----|-----|-----------|------|-----|---------|----|-----|---|----------|----|---|-----|---------|--------|-----|-------|------|-----|---------|----------|------|-----------|----|-----|--------------|-----|---------|-----|--------|------|----|-----|-------|--------------|-----------| | L(C | IR) | L( | DIR | t),Y | A | BS | П | AB | S,b | А | BS | S,X | Al | BS, | Y, | Δ | BL | | AE | 3L,) | <u> </u> | (AE | 3S) | L | (Al | 38) | (A | BS | ,X) | | STI | < | R | EL | | DIF | R,b,l | R / | ABS | S,b,F | 2 | SF | ? | (SI | R),` | Y | ВІ | K | 1 | 0 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 ( | 0 | | ор | n # | ор | n | # | ор | n | # | ор | n # | е ор | n | # | ор | n | # | ор | n | # | ор | n | # 0 | ıp I | n # | # 0 | р | 1 # | ŧ o | n | # | ор | n | # | ор | n | # | ор | n # | # | ор | n # | e op | n | # | ор | n | # ( | ор | n # | # | ΙP | L | N | ٧ | m | х | D | 1 | z | С | | | | l | | | EC | 4 | 3 | | | | | | | | | | | | | | T | | | T | | T | l | Ī | | | | | | | | | | | | | | | | | | 1 | | | 1. | | • | N | | • | | • | • | zί | С | | 4 | | L | - | - | | Н | 4 | 4 | + | + | L | - | L | | Ц | | 4 | 4 | _ | 4 | 4 | 4 | 4 | + | 4 | 1 | ╀ | + | | L | - | | | | | | | + | 4 | + | ╀ | + | | | 4 | 4 | 4 | + | + | + | ╀ | | | | | 4 | + | 4 | 4 | | | | | | | СС | 4 | 3 | | | | | | | | | | | | | | 1 | | | | | | | | | | | | | | | | | | | | | | | | | 1 | | | | ' | • | N | • | • | • | • | 1 | Z | C | | 1 | | t | t | t | CE | 7 | 3 | | $\dagger$ | DE | 8 | 3 3 | T | П | H | | 1 | 1 | | 1 | t | Ť | 1 | t | 1 | $\dagger$ | t | t | t | t | | | | | | | | t | 1 | | t | t | t | | | † | | T | ١. | | | N | | | | | • ; | z i | | | | | | | | | | | | | | | | | | | | | | | | 1 | | | | | | | | | | | | | | | | | | | | | | | | | 1 | | | | | | | | | | | | | ı | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 1 | | | | | | | | | | | | | | | | | | | | | | | | | 1 | | | ŀ | • | • | N | • | • | • | • | • 2 | z٠ | ٠ | | | | | | | | | Ī | | | | | | | | | | | | | | T | | | T | | T | | | | | | | | | | | | | | | | | | | | T | | | 1 | • | • | N | • | • | • | • | • 2 | z , | $\cdot$ | | | 35 3 | 89 | 36 | 3 | 89 | 29 | 4 | | | 89 | 31 | 1 4 | 89 | 31 | 4 | 89 | 31 | | | 32 | 5 | | | Ī | | | Ī | | | | | | | | | | | Ī | | | | | 3 | 89 | 33 | 3 | | | 1 | | • | N | ٧ | • | • | • | • | zσ | С | | 27 | | 37 | | | 2D | | | | | 3D | " | | 39 | | | 2F | | | 3F | | 1 | | | | | | | | | | | | | | | | | | | | 23 | 3 | | 33 | | 1 | | | | | | | | | | | | | ı | | _ | | | | | | | _ | | 1 | | | | | | | | | | | | 1 | | | 1 | | 1 | L | | | L | | | | | | | | 1 | _ | | L | 1 | | | | 1 | | | 1 | | L | | | | | | 1 | 1 | | | 47 | 10 2 | 57 | 11 | 1 2 | 4D | 4 | 3 | | | 5D | 6 | 3 | 59 | 6 | 3 | 4F | 6 | 4 | 5F | 7 | 4 | | | | | | | | | | | | | | | | | | | | 43 | 3 5 | 2 | 53 | 8 | 2 | | | ŀ | • | • | N | · | • | • | • | • | z · | ٠ | | 42 | 12 3 | 42 | 2 13 | 3 3 | 42 | 6 | 4 | | | 42 | 8 | 4 | 42<br>59 | 8 | 4 | 42 | 8 | 5 | 42 | 9 | 5 | | | | | | | | | | | | | | | | | | | | 42 | 2 7 | 3 | 42<br>53 | 10 | 3 | | | | | | | | | | | | | ı | | 47 | | 57 | _ | - | _ | - | _ | _ | + | | | | | | | 4F | 4 | 4 | 5F | _ | 4 | 4 | 4 | + | 4 | + | ╀ | + | - | L | | | | | | | | + | 4 | + | 43 | 3 | | 53 | | 4 | | + | $\downarrow$ | _ | + | | | | | | + | $\downarrow$ | 4 | | | | | | | EE | 7 | 3 | | | FE | 8 | 3 | | | | | | | | | 1 | | | | | | | | | | | | | | | | | | | | | | | | | 1 | | | | ' | • | N | • | • | • | • | • - | z • | ١. | | | | | | | | | | | | | | | | | | | | | | | 1 | | | | | | | | | | | | | | | | | | | | | | | | | 1 | | | | | | | | | | | | | ı | | + | | H | + | + | H | Н | + | + | + | + | + | + | H | Н | Н | | + | $\forall$ | 1 | + | + | + | + | + | + | + | t | + | + | ╁ | - | | $\vdash$ | | - | Н | + | + | + | + | t | + | + | | + | + | | + | ┿. | | | N | | | | | • | + | $\exists$ | | + | | H | + | + | | Н | + | | + | + | $\perp$ | | H | Н | Н | | + | + | _ | | + | + | + | + | + | + | H | + | $\perp$ | ╁ | | | | | | Н | | + | + | | H | + | $\perp$ | | - | + | | | _ | | $\perp$ | N | $\Box$ | | | _ | _ | _ | _ | | + | | ┝ | + | + | 40 | 2 | 1 | + | + | ╁ | + | + | ┝ | Н | Н | 5C | 1 | 1 | _ | _ | + | , | 4 / | 1 | | 1 | 3 70 | | 1 | ┝ | | | | | | | $\perp$ | + | + | + | + | + | $\perp$ | | + | + | | + | | | | • | | | | • | | _ | $\exists$ | | | | | | | 40 | | 3 | | | | | | | | | 50 | 4 | 4 | | | 1 | | 4 | الا | | 3 | 1 | اٰ | 3 | | | | | | | | | | | | | | | | | 1 | | | | | • | • | • | • | • | • | • | • | | | | | | | | | | | | | | | | | | | | | | | | 1 | | | ı | | | | | | | | | | | | | | | | | | | | | | 1 | | | | | | | | | | | | | ١ | | | | | | | | | | | | | | | | | | | | | | | 1 | | | ı | | | | | | | | | | | | | | | | | | | | | | 1 | | | | | | | | | | | | | ١ | | | | | | | | | | | | | | | | | | | | | | | 1 | | | | | | | | | | | | | | | | | | | | | | | | | 1 | | | | | | | | | | | | | ı | | | | | | | | | | | | | | | | | | | | | | | 1 | | | ı | | | | | | | | | | | | | | | | | | | | | | 1 | | | | | | | | | | | | | ١ | | | | | | | | | | | | | | | | | | | | | | | 1 | | | ı | | | | | | | | | | | | | | | | | | | | | | 1 | | | | | | | | | | | | | ١ | | | | | | | | | | | | | | | | | | | | | | | 1 | | | | | | | | | | | | | | | | | | | | | | | | | 1 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 1 | | | ı | | | | | | | | | | | | | | | | | | | | | | 1 | | | | | | | | | | | | | ı | | | | | | | | | | | | | | | | | | | | | | | 1 | | | ı | | | | | | | | | | | | | | | | | | | | | | 1 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 1 | | | ı | | | | | | | | | | | | | | | | | | | | | | 1 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 1 | | | ı | | | | | | | | | | | | | | | | | | | | | | 1 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 1 | | | ı | | | | | | | | | | | | | | | | | | | | | | 1 | | | | | | | | | | | | | ı | | + | | H | + | t | 20 | 6 | 3 | + | + | + | t | | H | Н | Н | 22 | 8 | 4 | 1 | | $\dagger$ | + | + | t | + | $\dagger$ | F | 2 8 | 3 | H | | | | | | | | $^{+}$ | + | + | t | + | + | | 1 | $\dagger$ | | + | Ϊ. | | | | | | | | | | | | | | | | | | | ۱ | | | | | | | | | | | | | | 1 | | | | | | ľ | | ľ | | | | | | | | | | | | | | | | | 1 | | | | | | | | | | | | | ı | | | | | | | | | | | | | | | | | | | | | | | 1 | | | ı | | | | | | | | | | | | | | | | | | | | | | 1 | | | | | | | | | | | | | ١ | | | | | | | | | | | | | | | | | | | | | | | 1 | | | ı | | | | | | | | | | | | | | | | | | | | | | 1 | | | | | | | | | | | | | ١ | | | | | | | | | | | | | | | | | | | | | | | 1 | | | ı | | | | | | | | | | | | | | | | | | | | | | 1 | | | | | | | | | | | | | ı | | | | | | | | | | | | | | | | | | | | | | | 1 | | | ı | | | | | | | | | | | | | | | | | | | | | | 1 | | | | | | | | | | | | | ı | | | | | | | | | | | | | | | | | | | | | | | 1 | | | ı | | | | | | | | | | | | | | | | | | | | | | 1 | | | | | | | | | | | | | ı | | | | | | | | | | | | | | | | | | | | | | | 1 | | | ı | | | | | | | | | | | | | | | | | | | | | | 1 | | | | | | | | | | | | | ı | | | | | | | | | | | | | | | | | | | | | | | 1 | | | ı | | | | | | | | | | | | | | | | | | | | | | 1 | | | | | | | | | | | | | ١ | | | | | | | | | | | | | | | | | | | | | | | 1 | | | ı | | | | | | | | | | | | | | | | | | | | | | 1 | | | | | | | | | | | | | ١ | | | | | | | | | | | | | | | | | | | | | | | 1 | | | ı | | | | | | | | | | | | | | | | | | | | | | 1 | | | | | | | | | | | | | ١ | | | | | | | | $ \ $ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | $ \ $ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | $ \ $ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | $ \ $ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | L | | | ட | Ш | ᆚ | | $\perp$ | $\perp$ | $\perp$ | | 1 | | $\Box$ | | | | - 1 | | -1 | | | L | | | 1 | 1 | | L | 1 | ı | ı | Ιl | | | | 1 | | - 1 | | | | | | | | - 1 | 1 | 1 | | | | | | | -1 | - 1 | | | | | | Г | | | | | | | | | - | Add | ress | ing | mc | odes | 3 | | | | | | _ | | | |---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|----------|-----|-----|----|---|---|--------------------|-----|-----|------|----------|-----|------|----|-----|-----|-------|-----|----------|------|-----|---------| | Symbol | Functions | Details | II | MР | | IMI | М | | Α | T | DI | R | D | IR,b | С | IR | ,Х | D | IR, | Y | (DII | R) | (DI | R,X) | ) ( | DIR), | | | | | ор | n | y or | r | n # | ор | n | # | op 1 | n # | ор | n # | ≠ op | n | # | ор | n | # 0 | op n | # | ор | n ; | # 0 | p n ; | | LDA<br>(Notes 1,2) | Acc←M | Enters the contents of the memory into the accummulator. | | | L | 1 | 2 2 | | | 4 | | 2 | 1 | | L | | 3 | | | 4 | 12 8 | | Ш | | 1 | 2 10 | | LDM<br>(Note 5) | M←IMM | Enters the immediate value into the memory. | | | AS | 9 | | | | + | A5<br>64 4 | 3 | | | 74 | + | 3 | | | E | 32 | | A1 | + | В | 1 | | LDT | DT←IMM | Enters the immediate value into the data bank regiater. | | | 89<br>C2 | | 5 3 | | | 1 | | | | | | | | | | | | | | | | | | LDX<br>(Note 2) | X←M | Enters the contents of the memory into index register X. | | | A2 | 2 2 | 2 2 | | | F | A6 4 | 2 | | | | | | В6 | 5 | 2 | | | | | | $\prod$ | | LDY<br>(Note 2) | Y←M | Enters the contents of the memory into index register Y. | | | A | 2 | 2 2 | | | , | A4 4 | 1 2 | | | B4 | 1 5 | 2 | | | | | | | | | | | LSR<br>(Note 1) | $ \begin{array}{c} m=0 \\ 0 \rightarrow \boxed{b_{15} \cdots b_0} \rightarrow C \\ m=1 \\ 0 \rightarrow \boxed{b_7 \cdots b_0} \rightarrow C \end{array} $ | Shifts the contents of the accumulator or the contents of the memory one bit to the right. The bit 0 of the accumulator or the memory is entered into the C flag. "0" is entered into bit 15 (bit 7 when the m flag is "1.") | | | | | | | 4 | | 46 7 | 2 | | | 56 | 6 7 | 2 | | | | | | | | | | | MPY<br>(Notes 2,11) | B, A←A <b>*</b> M | Multiplies the contents of accumulator A and the contents of the memory. The higher order of the result of operation are entered into accumulator B, and the lower order into accumulator A. | | | 89 | | 6 3 | | | | 89 1<br>05 | 8 3 | | | 89<br>15 | | 9 3 | | | 1 | 39 20 | 0 3 | 89<br>01 | 21 : | 3 8 | 9 22 3 | | MVN<br>(Note 8) | Mn+i←Mm+i | Transmits the data block. The transmission is done from the lower order address of the block. | | | | | | | | | | | | | | | | | | | | | | Ī | | | | MVP<br>(Note 9) | Mn–i←Mm–i | Transmits the data block. Transmission is done form the higher order address of the data block. | | | | | | | | | | | | | | | | | | | | | | Ī | | | | NOP | PC←PC+1 | Advances the program counter, but pertorms nothing else. | EΑ | 2 | 1 | | | | | Ī | | | | | | | | | | | | | | T | T | П | | ORA<br>(Notes 1,2) | Acc←AccVM | Logical sum per bit of the contents of the accumulator and the contents of the memory is obtained. The result is entered into the accumulator. | | | | | 2 2 | | | 4 | 05 4<br>42 6<br>05 | | | | | 2 7 | 3 | | | 4 | | | Ш | | | 1 8 2 | | PEA | $\begin{array}{c} M(S){\leftarrow}IMM_2\\ S{\leftarrow}S{-}1\\ M(S){\leftarrow}IMM_1\\ S{\leftarrow}S{-}1 \end{array}$ | The 3rd and the 2nd bytes of the instruction are saved into the stack, in this order. | | | | | | | | | | | | | | | | | | | - | | 01 | 1 | | | | PEI | $\begin{array}{c} M(S) \leftarrow M((DPR) + IMM \\ +1) \\ S \leftarrow S - 1 \\ M(S) \leftarrow M((DPR) + IMM) \\ S \leftarrow S - 1 \end{array}$ | Specifies 2 sequential bytes in the direct page in the 2nd byte of the instruction, and saves the contents into the stack. | | | | | | | | | | | | | | | | | | | | | | | | | | PER | EAR←PC+IMM2,IMM1<br>M(S)←EARH<br>S←S-1<br>M(S)←EARL<br>S←S-1 | Regards the 2nd and 3rd bytes of the instruction as 16-bit numerals, adds them to the program counter, and saves the result into the stack. | | | | | | | | | | | | | | | | | | | | | | | | | | РНА | m=0<br>M(S)←AH<br>S←S-1<br>M(S)←AL<br>S←S-1<br>m=1<br>M(S)←AL<br>S←S-1 | Saves the contents of accumulator A into the stack. | | | | | | | | | | | | | | | | | | | | | | | | | | РНВ | m=0<br>M(S)←BH<br>S←S-1<br>M(S)←BL<br>S←S-1<br>m=1<br>M(S)←BL<br>S←S-1 | Saves the contents of accumuator B into the stack. | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Ad | dr | es | ssi | nę | j 1 | no | od | es | | | | | | | | | | | | | | | | | | | | | | | | | T | Р | roc | es | S0 | r s | tat | us | reç | gis | ter | ٦ | |----------|-----|----|----------|------|-----|----------|-----|---|----|---|-----|---|----------|----|----|-----|--------|----|---|----------|----|----------|-----------|----------|-----|----|----|----|-----|-----|-----|----|----------|----|----|-----|---|-----|----|-----------|----|----|---|----|------|----|----------|-----|-----|----------|----|----|----------|----|----|----|---------|---|--------------|----|-----|-----|----|-----|-----|----|-----|-----|-----|--------------------| | L( | DIR | ?) | L(E | DIR) | ),Y | A | ۱B۵ | S | A | В | S,t | , | ΑE | 38 | ,Х | 1 | ۱B | S, | Υ | Γ. | AΒ | L | T | ΑE | ЗL, | Х | (/ | ۱B | S) | L | (A | В | 3) | (A | BS | ,X) | | S | ΓK | | R | EL | _ | DI | IR,t | ,R | Al | BS, | b,R | | SF | ξ. | (S | R) | ,Υ | | BL | K | 1 | 0 | 9 8 | 3 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | ор | n | # | ор | n | # | ор | n | # | op | r | 1 | # | ор | n | # | 9 | р | n | # | ор | n | # | ŧ | ор | n | # | ор | n | ı # | ‡ ( | р | n | # | op | n | # | 0 | р | n | # | ор | n | # | ор | n | # | op | r | n # | ор | n | # | ор | n | # | ор | n | # | ŧ | İF | PL. | ١ | ١, | V | m | х | D | ı | z | С | | A7 | 10 | 2 | В7 | 11 | 2 | AD | 4 | 3 | | | | ı | BD | 6 | 3 | В | 9 | 6 | 3 | ΑF | 6 | 4 | | 3F | 7 | 4 | | | | | | | | | | | | | | | | | | | | | | | | А3 | 5 | 2 | ВЗ | 8 | 2 | | | | ŀ | • | • | • 1 | 7 | • | • | • | • | • | z | • | | 42<br>A7 | 12 | 3 | 42<br>B7 | 13 | 3 | 42<br>AD | 6 | 4 | | | | ľ | 42<br>BD | 8 | 4 | 4 A | 2 | 8 | 4 | 42<br>AF | 8 | 5 | 5 4 | 42<br>3F | 9 | 5 | | | | | | | | | | | l | | | | | | | | | | | | | 42<br>A3 | 7 | 3 | 42<br>B3 | 10 | 3 | | | | | | | | | | | | | | | | | | | | | | - | 9C | - | 4 | | Ī | | _ | 9E | - | _ | _ | Ī | | | | | | T | | | | | | Ī | Ī | | | | | | | T | | | Ī | | | | | | | | | l | | | | | | | | | | 1 | • | • | • | • | • | • | • | • | • | • | $\overline{\cdot}$ | | | | | | | | | | | | | | | | | | | | | | | | | 1 | | | | | | | l | | | 1 | | | | t | | | 1 | | | | | | | | | | | | | | | | | | | † | | • | • | • | • | • | • | • | • | • | - | | | | 1 | | | | ΑE | 4 | 3 | | | | 1 | | | | В | E | 6 | 3 | | | | $\dagger$ | | | | | | | t | | | 1 | | | | t | | | + | | | | | | | | | | | | | | | | | | | † | • | + | • 1 | V | • | • | • | • | • | z | $\overline{\cdot}$ | | | | 1 | | | | AC | 4 | 3 | | 1 | | - | вс | 6 | 3 | 3 | 1 | | | | | | $\dagger$ | | | | | | 1 | ł | | | $\dashv$ | | | | ł | | | + | | | | | | | <u> </u> | | | | | | | | | | | | + | • | • • | • 1 | ٧ | • | • | • | • | • | z | $\overline{\cdot}$ | | H | | + | | | | 4E | 7 | 3 | ŀ | + | + | + | 5E | 8 | 3 | 3 | + | | | L | _ | <u> </u> | + | | | | | _ | + | ł | + | - | + | | | | + | + | + | + | | + | | | | | H | + | + | ┝ | | | L | | | | | | <del> </del> | | • | • ( | ) | • | • | • | • | • | z | С | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 89<br>07 | 24 | 3 | 89<br>17 | 25 | 3 | 89<br>0D | 18 | 4 | | | | | 89<br>1D | 20 | 4 | 8 | 9 | 20 | 4 | 89<br>0F | 20 | 5 | 5 | 89<br>1F | 21 | 5 | | | | Ì | | | | | | | T | | | | | | | | | | | | | 89<br>03 | 19 | 3 | 89<br>13 | 22 | 3 | | | | 1 | • | • | 1 | 1 | • | • | • | • | • | z | 0 | | | | | | | | | | | | | | | | | | | | | | | | | İ | | | | | | | Ì | | | | | | | T | | | | | | | | | | | | | | | | | | | | 7 + 1 > | | 1 | • | • | | • | • | • | ٠ | • | • | • | • | | | | | | | | | | | | | | | | | | | | | | | | | 1 | | | | | | | l | | | | | | | l | | | | | | | | | | | | | | | | | | | 44 | | 3 | 3 | • | | | • | • | • | • | • | • | • | • | | | | | | | | | | | L | 1 | | | | | | - | 1 | | | | | | $\dagger$ | | | | | | + | ł | | | 1 | | | | t | | | $\dagger$ | | | | | | | l | | | | | | | | | | 2 ′ | T | † | • | • . | • | | • | • | • | • | • | • | $\overline{\cdot}$ | | 07 | 10 | 2 | 17 | 11 | 2 | 0D | 4 | 3 | | l | | | 1D | 6 | 3 | 3 1 | 9 | 6 | 3 | 0F | 6 | 4 | 1 | 1F | 7 | 4 | | | T | Ī | | | | | | | T | | | T | | | | | | | | | l | 03 | 5 | 2 | 13 | 8 | 2 | | | | ŀ | • | • | • 1 | ٧ | • | • | ٠ | • | • | Z | - | | 42<br>07 | 12 | 3 | 42<br>17 | 13 | 3 | 42<br>0D | 6 | 4 | | | | | 42<br>1D | 8 | 4 | 4 | 2<br>9 | 8 | 4 | 42<br>0F | 8 | 5 | 5 | 42<br>1F | 9 | 5 | | | | | | | | | | | | | | | | | | | | | | | | 42<br>03 | 7 | 3 | 42<br>13 | 10 | 3 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | F | 4 | 5 | 3 | | | | | | | | | | | | | | | | | | | | • | • | • | • | • | • | • | • | • | • | • | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | D | 4 | 6 | 2 | | | | | | | | | | | | | | | | | | | ľ | • | • | • | • | • | • | • | • | • | • | • | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 6 | 2 | 5 | 3 | | | | | | | | | | | | | | | | | | | | • | • • | • | • | • | • | • | • | • | • | • | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | l | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | _ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 4 | 8 | 4 | 1 | | | | | | | | | | | | | | | | | | | | • | • | | • | • | • | • | • | • | • | • | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 4 | 2 8 | 6 | 2 | | | | | | | | | | | | | | | | | | | , | • | • | • | • | • | • | • | • | • | • | • | | | | | | | | | | | | | | | Add | ress | ing | mo | ode | s | | | | | | | | |--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------|----|----|---|------|-----|-----|-----|-----|----|-----|-----|------|-----|-----|-----|----|------|------|------|------|------|-----|-----------| | Symbol | Functions | Details | II | MP | | IM | 1М | | Α | | С | IR | D | IR,b | [ | DIR | ,Х | D | IR,Y | ([ | OIR) | (D | IR,X | ) ( | (DIR),Y | | | | | ор | n | # | op 1 | n # | # 0 | p n | n # | ор | n # | ор | n # | ‡ o | p n | 1 # | ор | n # | e op | n # | ŧ op | n ; | # 0 | PP n # | | PHD | M(S)←DPRн<br>S←S−1<br>M(S)←DPRL<br>S←S−1 | Saves the contents of the direct page register into the stack. | | | | | | | | | | | | | | | | | | | | | | | | | PHG | M(S)←PG<br>S←S–1 | Saves the contents of the program bank register into the stack. | | | | | | | | | | | | | | | | | | | | | | | | | PHP | M(S)←PSH<br>S←S-1<br>M(S)←PSL<br>S←S-1 | Saves the contents of the program status register into the stack. | | | | | | | | | | | | | | | | | | | | | | | | | PHT | M(S)←DT<br>S←S−1 | Saves the contents of the data bank register into the stack. | | | | | | | | | | | | | | | | | | | | | | | $\prod$ | | РНХ | $ \begin{array}{l} x{=}0 \\ M(S){\leftarrow}X{+} \\ S{\leftarrow}S{-}1 \\ M(S){\leftarrow}X{L} \\ S{\leftarrow}S{-}1 \\ x{=}1 \\ M(S){\leftarrow}X{L} \\ S{\leftarrow}S{-}1 \end{array} $ | Saves the contents of the index register X into the stack. | | | | | | | | | | | | | | | | | | | | | | | | | PHY | $ \begin{array}{c} x{=}0 \\ M(S){\leftarrow}Y{+} \\ S{\leftarrow}S{-}1 \\ M(S){\leftarrow}Y{L} \\ S{\leftarrow}S{-}1 \\ x{=}1 \\ M(S){\leftarrow}Y{L} \\ S{\leftarrow}S{-}1 \end{array} $ | Saves the contents of the index register Y into the stack. | | | | | | | | | | | | | | | | | | | | | | | | | PLA | $ \begin{aligned} & m{=}0 \\ & S{\leftarrow}S{+}1 \\ & A{\perp}{\leftarrow}M(S) \\ & S{\leftarrow}S{+}1 \\ & A{+}{\leftarrow}M(S) \\ & m{=}1 \\ & S{\leftarrow}S{+}1 \\ & A{\perp}{\leftarrow}M(S) \end{aligned} $ | Restores the contents of the stack on the accumulator A. | | | | | | | | | | | | | | | | | | | | | | | | | PLB | $ \begin{tabular}{ll} $m{=}0$ & $S{\leftarrow}S{+}1$ & $B{\perp}{\leftarrow}M(S)$ & $S{\leftarrow}S{+}1$ & $B{+}{\leftarrow}M(S)$ & $m{=}1$ & $S{\leftarrow}S{+}1$ & $B{\perp}{\leftarrow}M(S)$ $B{\perp}{\leftarrow}M$ | Restores the contents of the stack on the accumulator B. | | | | | | | | | | | | | | | | | | | | | | | | | PLD | S←S+1<br>DPRL←M(S)<br>S←S+1<br>DPRH←M(S) | Restores the contents of the stack on the direct page register. | | | | | | | | | | | | | | | | | | | | | | | | | PLP | $\begin{array}{c} S \leftarrow S+1 \\ PSL \leftarrow M(S) \\ S \leftarrow S+1 \\ PSH \leftarrow M(S) \end{array}$ | Restores the contents of the stack on the processor status register. | | | | | | | | | | | | | | | | | | | | | | | | | PLT | S←S+1<br>DT←M(S) | Restores the contents of the stack on the data bank register. | | | | | | | | | | | | | | | | | | | | | | | | | PLX | x=0<br>S←S+1<br>XL←M(S)<br>S←S+1<br>XH←M(S) | Restores the contents of the stack on the index register X. | | | | | | | | | | | | | | | | | | | | | | | | | | S←S+1<br>XL←M(S) | | | | | | | | | | | | | | | | | | | | | | | | $\coprod$ | | Γ | | | | | | | | | | | | | | | | | | | | | | | | Α | dd | re | SS | in | g | m | od | es | | | | | | | | | | | | | | | | | | | | | | | | T | F | Proc | es | SOI | r si | tatı | ıs ı | reg | iste | er | |----|------|-----|------|-------|-----|-----|-----|------------|----|----|----|----|-----|-----|-----|----|-----|---|----|----|---|----|-----|-----|-----|-----|----|----|----|----|----|----|----|-----|----------|-------|-----|---|-----|-----|-----|-----|-----|----|----|------|----|----|-----|-----|-----|------|---|----|-----|---|----|------|-----|-----|------|------|------|-----|------|------------| | L( | DIR) | L | .(DI | R),` | Y | ΑI | BS | | ΑE | 38 | ,b | A | ABS | 3,X | < | ΑE | BS, | Υ | Å | ٩В | L | А | ιBL | _,X | | (AE | 38 | ) | L( | AΒ | S) | (A | BS | ,X) | | ST | K | I | R | EL | | DIF | R,b | ,R | AB | 3S,b | ,R | 9 | R | | (SR | ۲),۱ | Y | ВІ | K | 1 | 0 | 9 8 | 3 | 7 6 | 6 | 5 | 4 | 3 | 2 1 | 1 0 | | ор | n # | ŧ o | P n | n # | ¥ o | p I | n i | <b>#</b> ( | ор | n | # | ор | n | 1 , | # 0 | ор | n | # | ор | n | # | ор | n | # | E 0 | Р | n | # | op | n | # | ор | n | # | ор | n | # | 0 | p r | 1 # | ¥ ( | ор | n | # | ор | n | # | ор | n # | # 0 | р | n i | # | ор | n # | # | II | PL | | N | V | m | х | D | I Z | z c | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 0B | 3 4 | . 1 | ı | | | | | | | | | | | | | | | | | | | • | • | • | • | • | • | • | • | • | • | | | | | | | | | | | | | | | | | | | | | | | | | İ | | İ | | | | | | | | | | 4E | 3 3 | 3 1 | | | | | | | | | | | | | | | | | | | | • | • | • | • | • | • | • | • | 1 | • | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 08 | 4 | 1 1 | ı | | | | | | | | | | | | | | | | | | | • | • | • | • | • | • | • | • | • | • | | | | | | | İ | | | | | | | | | | | | | | | | | | | | İ | | | | | | | | | | | 3 3 | | | | | | | | | | | | | | | | | | | | | • | • | • | • | • | • | • | • | • | • | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | D₽ | 4 | . 1 | l | | | | | | | | | | | | | | | | | | | • | • | - | • | • | • | • | • | • | • | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 5A | 4 | 1 | | | | | | | | | | | | | | | | | | | | • | • | • | • | • | • | • | • | - | • | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 68 | 5 5 | 1 | ı | | | | | | | | | | | | | | | | | | | • | • | • 1 | 7 | • | • | • | • | • 2 | 7 • | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 42<br>68 | 72. 7 | 2 | 2 | | | | | | | | | | | | | | | | | | | • | • | • ! | N | • | • | • | • | • 2 | 7 • | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 2B | 5 | 1 | ı | | | | | | | | | | | | | | | | | | | • | • | • | • | • | • | • | • | • | • | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 28 | 6 | 1 | 1 | | | | | | | | | | | | | | | | | | | Va | lue | S | ave | ed | in | sta | ck. | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 3 6 | | ı | | | | | | | | | | | | | | | | | | | | • | | | | | | | | <u>z</u> • | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | FA | N 5 | 1 | | | | | | | | | | | | | | | | | | | | • | • | • [ | N | • | • | • | •] | • 2 | Z • | | | | | Г | | | | | | | | | | Add | res | sing | g m | node | es | | | | | | | | | |--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|----|---|----------|---------------|----------------|-----|---|------------|-----|-----|------|------|----------|------|-----|------|---|--------------|-----|----------|------|-----|-------------| | Symbol | Functions | Details | II. | MP | ٦ | IN | 1M | Τ | Α | | D | IR | _ | IR,I | _ | _ | R,X | _ | DIR, | Υ | (DI | R) | (DI | R,X) | ([ | OIR),Y | | | | | ор | n | # | ор | n # | <sub>‡</sub> 0 | p n | # | ор | n # | ор | n | # | ор | n # | # O | p n | # | op r | n # | ор | n # | e o | n # | | PLY | | Restores the contents of the stack on the index register Y. | | | | | | | | | | | | | | | | | | | | | | | | | | PSH<br>(Note 6) | M(S)←A, B, X··· | Saves the registers among accumulator, index register, direct page register, data bank register, program bank register, or processor status register, specified by the bit pattern of the second byte of the instruction into the stack. | | | | | | | | | | | | | | | | | | | | | | | | | | PUL<br>(Note 7) | A, B, X···←M(S) | Restores the contents of the stack to the registers among accumulator, index register, direct page register, data bank register, or processor status register, specified by the bit pattern of the second byte of the instruction. | | | | | | | | | | | | | | | | | | | | | | | | | | RLA<br>(Note 13) | m=0 n bit rotate left bis bo m=1 n bit rotate left b7 bo | Rotates the contents of the accumulator A, n bits to the left. | | | | 89 49 | 6 3<br>+<br>i | 3 | | | | | | | | | | | | | | | | | | | | ROL<br>(Note 1) | m=0<br>← b15 ··· b0 ← C ←<br>m=1<br>← b7 ··· b0 ← C ← | Links the accumulator or the memory to C flag, and rotates result to the left by 1 bit. | | | | | | L | 2 4 | | 26 | 7 2 | | | 3 | 36 | 7 2 | 2 | | | | | | | | | | ROR<br>(Note 1) | $\begin{array}{c} m=0 \\ \hline \downarrow C \rightarrow b_{15} \cdots b_{0} \\ \hline \\ m=1 \\ \hline \downarrow C \rightarrow b_{7} \cdots b_{0} \\ \hline \end{array}$ | Links the accumulator or the memory to C flag, and rotates result to the right by 1 bit. | | | | | | 6 <i>i</i> | 2 4 | 1 | 66 | 7 2 | | | • | 76 | 7 2 | 2 | | | | | | | | | | RTI | S←S+1 PSL←M(S) S←S+1 PSH←M(S) S←S+1 PCL←M(S) S←S+1 PC+M(S) S←S+1 PC+M(S) S←S+1 PG←M(S) | Returns from the interruption routine. | 40 | 11 | 1 | | | | | | | | | | | | | | | | | | | | | | | RTL | $\begin{array}{c} S \leftarrow S+1 \\ PCL \leftarrow M(S) \\ S \leftarrow S+1 \\ PCH \leftarrow M(S) \\ S \leftarrow S+1 \\ PG \leftarrow M(S) \end{array}$ | Returns from the subroutine. The contents of the program bank register are also restored. | 6B | 8 | 1 | | | | | | | | | | | | | | | | | | | | | | | RTS | S←S+1<br>PCL←M(S)<br>S←S+1<br>PCH←M(S) | Returns from the subroutine. The contents of the program bank register are not restored. | 60 | 5 | 1 | | | | | | | | | | | | | | | | | | | | | | | SBC<br>(Notes 1,2) | Acc, C←Acc−M−C | Subtracts the contents of the memory and the borrow from the contents of the accumulator. | | | l | E9 : | | | | | | 4 2 | J | | | | 5 2 | | | | | | | | | 18 2 | | | | | | | | 42<br>E9 | 4 3 | Ì | | | 42 (<br>E5 | 6 3 | | | | 12<br>F5 | 7 3 | | | | 42 8<br>F2 | 3 | 42<br>E1 | 9 3 | F | 2 10 3<br>1 | | | | | | | | | | | | | | | | | | | | | | | | | P | ١d٥ | dre | es | sir | ng | m | 10 | de | s | | | | | | | | | | | | | | | | | | | | | | | | | T | P | roc | es | so | r s | tat | us | re | gis | ter | ٦ | |--------------------|------|------|------|----|-----|-----|----------|----|----|----|----|-----|-----|-----|----|----|----|----|----|-----|--------------|-----|-----|-----|-----|----|-----|----|-----|-----|----|----|----|-----|---------|-------------------|-------------|---|----|----|---|-----|-----|----|----|-----|-----|----|----|---|----|-----|-----|------------|-----|-----|---|-----------------|-----------------------------|----------------|-----------|-----|-----|-----|-----|------------|-----|---| | L(DIR | () L | _(DI | R),\ | 1 | ΑE | 38 | I | ΑE | 38 | ,b | 1 | ٩B | S, | x | Αŀ | 38 | ,Υ | | ΑE | BL. | Ţ, | AB | L, | ×Τ | (A | В | 3) | L | (Al | BS | 5) | AE | 38 | ,X) | | ST | K | I | RE | ΞL | | DIF | R,b | ,R | AE | BS, | b,R | I | SF | ₹ | (5 | SR) | ),Y | Τ | BL | K | 1 | 0 ! | 9 8 | 3 . | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | op n | # 0 | p r | n # | op | r | 1 # | <i>‡</i> | ор | n | # | op | r | n i | # | ор | n | # | ot | r | 1 # | 0 | n q | n : | # | ор | n | # | oį | r | n # | # | ор | n | # | ор | r | 1 # | 0 | р | n | # | ор | n | # | ор | n | # | op | n | # | ор | n | # | <i>‡</i> 0 | p I | n # | ŧ | IF | PL | Ī | N | v | m | х | D | ı | z | С | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 7A | . 5 | 5 | 1 | | | | | | | | | | | | | | | | | | | | • | • | • 1 | N | • | • | • | • | • | Z | • | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | EB | 3 1;<br>2i1· | 2 :<br>+i2 | 2 | | | | | | | | | | | | | | | | | | | | • | • | • | • | • | • | • | • | • | • | • | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | FB<br>3 | 3 1.<br>H<br>Si1+ | 4 :<br>-4i: | 2 | | | | | | | | | | | | | | | | | | | | PS<br>An<br>cha | est<br>b, it<br>d th<br>ang | b<br>ne<br>je. | ec<br>oth | om | ca | it | s \ | /al<br>are | ne | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | • | • . | | • | • | • | • | • | • | • | | | | | | | 2 | E 7 | 7 3 | 3 | | | | 38 | Ξ 8 | В | 3 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | • | • | • 1 | N | • | • | • | • | • | Z | C | | | | | | 6 | E 7 | 7 3 | 3 | | | | 76 | Ξ 8 | В | 3 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | • | • | • | N | • | • | • | • | • | z | С | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Va | lue | Sé | ave | ed | in | sta | ack | ζ. | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | • • | | • | | | • | • | • | • | • | | | | | | | | | | | | | | | | | | | | | | | $\downarrow$ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | • • | | | | | • | | | | | | E710<br>4212<br>E7 | | | | ı | | | П | | | | ı | | | - 1 | | | | L | | | П | F 7 | | - 1 | | | | | | | | | | | | | | | | | | | | | | | | ı | | 3 | | | | П | | | | • | • . | . 1 | N | V | • | • | • | • | Z | С | | | | | | | | | | | | | | | A | ddr | ess | ing | m | ode | es | | | | | _ | | | | |-----------------|-----------|------------------------------------------------------------------------------------|----------|----|----------|----|----|---|-----------|-----|----------------|-----|----------|-----|-----|-------|-----------|------------|-----|-----|---|----|-----------|------------|-------------|-----------|-----------| | Symbol | Functions | Details | ⊢ | ИP | $\dashv$ | _ | ΜN | + | A | | + | DIR | $\dashv$ | _ | R,b | + | _ | R,X | ┸ | DIR | _ | Ľ | IR) | + | OIR,X | + | (DIR | | | | | op | n | # | ор | n | # | op I | n # | ≠ op | n | # | ор | n # | # 0 | р | n # | ‡ º | P n | # | ор | n : | <b>#</b> 0 | n | # 0 | )P r | | SEB<br>(Note 5) | Mb←1 | Makes the contents of the specified bit in the memory "1." | | | | | | | | | | | | 04 | 8 3 | 3 | | | | | | | | | | | | | SEC | C←1 | Makes the contents of the C flag "1." | 38 | 2 | 1 | | | | | | | | | | | | | | | | | | | | | $\perp$ | | | SEI | I←1 | Makes the contents of the I flag "1." | 78 | 2 | 1 | | | | | | | | | | | | | | | | | | | | | ╛ | | | SEM | m←1 | Makes the contents of the m flag "1." | F8 | 2 | 1 | | | | | | | | | | | | | | | | | | | | Ш | ╛ | $\perp$ | | SEP | PSb←1 | Set the specified bit of the processor status register's lower byte (PSL) to "1." | | | | E2 | 3 | 2 | | | | | | | | | | | | | | | | | | | | | STA<br>(Note 1) | M←Acc | Stores the contents of the accumulator into the memory. | | | | | | | | | 85<br>42<br>85 | Ц | 3 | | | 9 4 9 | 2 | 5 2<br>7 3 | 1 | | | | | $\perp$ | 7 | 3 4 | | | STP | | Stops the oscillation of the oscillator. | DB | 3 | 1 | | 7 | T | | | | | 1 | | | Ť | Ť | | t | | | - | | Ť | П | Ť | Τ | | STX | M←X | Stores the contents of the index register X into the memory. | | | T | | 1 | 1 | | | 86 | 4 | 2 | | | Ť | t | | 96 | 5 5 | 2 | T | | t | П | † | T | | STY | M←Y | Stores the contents of the index register Y into the memory. | | | $\dashv$ | | + | 1 | $\dagger$ | | 84 | 4 | 2 | | | 9 | 4 | 5 2 | 2 | | | | $\dagger$ | $\dagger$ | H | † | + | | TAD | DPR←A | Transmits the contents of the accumulator A to the direct page register. | 5B | 2 | 1 | | 1 | | | | | | | | | T | $\dagger$ | | T | | | | | | $\parallel$ | † | + | | TAS | S←A | Transmits the contents of the accumulator A to the stack pointer. | 1B | 2 | 1 | | 7 | 1 | | | T | | 7 | | | Ť | 1 | | T | | | | | Ť | $\prod$ | † | $\dagger$ | | TAX | X←A | Transmits the contents of the accumulator A to the index register X. | AA | 2 | 1 | | | | | | | | | | | | | | | | | | | | | 1 | | | TAY | Y←A | Transmits the contents of the accumulator A to the index register Y. | А8 | 2 | 1 | | | | | | | | | | | | | | | | | | | | | T | T | | TBD | DPR←B | Transmits the contents of the accumulator B to the direct page register. | 42<br>5B | 4 | 2 | | | | | | | | | | | | | | | | | | | | | 1 | | | TBS | S←B | Transmits the contents of the accumulator B to the stack pointer. | 42<br>1B | 4 | 2 | | | | | | | | | | | | | | | | | | | | | | | | ТВХ | Х←В | Transmits the contents of the accumulator B to the index register X. | 42<br>AA | 4 | 2 | | | | | | | | | | | | | | | | | | | | | | | | TBY | Y←B | Transmits the contents of the accumulator B to the index register Y. | 42<br>A8 | 4 | 2 | | | | | | | | | | | | | | | | | | | | | | | | TDA | A←DPR | Transmits the contents of the direct page register to the accumulator A. | 7B | 2 | 1 | | | | | | | | | | | | | | | | | | | | | ╛ | | | TDB | B←DPR | Transmits the contents of the direct page register to the accumulator B. | 42<br>7B | 4 | 2 | | | | | | | | | | | | | | | | | | | | | | | | TSA | A←S | Transmits the contents of the stack pointer to the accumulator A. | ЗВ | 2 | 1 | | | | | | | | | | | | | | | | | | | | | ╛ | $\perp$ | | TSB | B←S | Transmits the contents of the stack pointer to the accumulator B. | 42<br>3B | 4 | 2 | | | | | | | | | | | | | | | | | | | | | | | | TSX | X←S | Transmits the contents of the stack pointer to the index register X. | ВА | | | | | | | | | | | | | | | | | | | | | | | | | | TXA | A←X | Transmits the contents of the index register X to the accumulator A. | 8A | 2 | 1 | | | | | | | | | | | | | | | | | | | | | | | | ТХВ | В←Х | Transmits the contents of the index register X to the accumulator B. | 8A | 4 | ╛ | | | | | | | | | | | | | | | | | | | | | | | | TXS | S←X | Transmits the contents of the index register X to the stack pointer. | 9A | 2 | 1 | | | | | | | | | | | | | | | | | | | | | ╛ | 1 | | TXY | Y←X | Transmits the contents of the index register X to the index register Y. | 9B | | | | | | | | | | | | | | | | | | | | | | | | | | TYA | A←Y | Transmits the contents of the index register Y to the accumulator A. | 98 | 2 | 1 | | | | | | | | | | | | | | | | | | | | | $\rfloor$ | | | ТҮВ | В←Ү | Transmits the contents of the index register Y to the accumulator B. | 42<br>98 | 4 | 2 | | | | | | | | | | | | | | | | | | | | | | | | TYX | X←Y | Transmits the contents of the index register Y to the index register X. | ВВ | | | | | | | | | | | | | | | | | | | | | | | | | | WIT | | Stops the internal clock. | СВ | 3 | 1 | | | | | | Ĺ | Ц | | | | | | | | | | | Щ | | П | | 1 | | XAB | A≒B | Exchanges the contents of the accumulator A and the contents of the accumulator B. | 89<br>28 | 6 | 2 | | | | | | | | | | | | | | | | | | | | | | | | Г | | | | | | | | | | | | | | | | | | | | | | | | | A | dd | re | s | sir | ng | m | 100 | de | s | | | | | | | | | | | | | | | | | | | | | | | | Γ | Pr | 006 | ess | or | sta | atu | ıs r | eg | ist | er | 7 | |----------|------|----------|---------|-----|----------|----|---|-----|-----------|----|-----|----------|----|----|----------------|--------|----|---|----------|--------|---|----|----------|----|-----|--------------|-----------|----|-----|----|-----|-----|------|-----------|-----|-----------|---|----|----|----|---|---|-----------|--------------|-----------|----|------|----|----------|----|---|----------|-----|---|---|-----|----------|----|----|---------|---------|-------|-----|---------|------|-----|-----|---------------|---| | L([ | DIR) | L(I | DIR) | ),Y | F | \B | s | T , | ۱B | S, | b | Al | BS | ,Х | T <sub>A</sub> | ٩B | S, | Y | <i>-</i> | AB | L | I | Al | BL | .,X | T | (AI | BS | 3) | L | (AE | 38 | ) (, | AΒ | S,X | 0 | S | TK | | RE | L | T | DIR | R,b,l | R | AE | 3S,b | ,R | | SR | | (SI | R), | Υ | E | 3Lł | <u> </u> | 10 | 9 | 8 8 | 7 | 7 6 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | n # | | | | | n | # | - | - | - | _ | ор | n | # | op | р | n | # | ор | n | # | _ | | | | _ | | | | | | | _ | | | _ | | | ор | n | | _ | | | _ | | | | | n | | | | | _ | n | | | IP | L | 1 | ų v | V r | m | х | D | ı | Z | | | | | | | | | | | 00 | | 9 | 4 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | ŀ | • | • | - | ٠ ٠ | • | • | • | • | • | • | ٠ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | • | 1 | - 1 | - 1 | - 1 | - 1 | - 1 | ٠ | - 1 | | - 1 | 1 | | Ц | | L | Ц | | | | | L | | 1 | | | | | L | | _ | | | | | 1 | | | | 1 | | | | | L | | | | | 1 | | | | | | 1 | 1 | | 1 | | | | Ц | | | | | | L | | | ŀ | _ | _ | | | | | ٠ | - | - | $\rightarrow$ | | | Ц | | Ļ | Ц | | | | | L | 1 | 1 | 4 | | | | L | _ | 4 | | | 1 | | 4 | | | | 1 | 1 | 4 | | L | 1 | 1 | ļ | | 1 | 1 | | | | | _ | ļ | 1 | | 4 | | | | Ц | 1 | | | | | L | | | ŀ | | | | | • | | | | • | | | | | | | Ш | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | + | + | + | + | _ | _ | _ | flag | _ | _ | _ | - | | | 10 2 | | | | | | | ı | | | - 1 | 9D | | | L | | | | ı | | | -1 | | | | Т | | | | | | | | | | | | | | | | | | | | | | | 83 | | | | | | | | | ŀ | • | • | | ١. | • | • | • | • | • | • | • | | 42<br>87 | 12 3 | 42<br>97 | 13 | 3 | 42<br>8D | 7 | 4 | | | | | 42<br>9D | 7 | 4 | 42<br>99 | 2<br>9 | 7 | 4 | 42<br>8F | 8 | 5 | 5 | 42<br>9F | 9 | 5 | | | | | | | | | | | | | | | | | | | | | | | | 42<br>83 | 7 | 3 | 42<br>93 | 10 | 3 | L | | | L | | | | | | | | | | | | | Ц | | | Ц | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Ц | | | | | | L | | | ŀ | | | | | | | ٠ | | | Н | ٠ | | Ц | | L | Ц | | 8E | _ | _ | ┺ | 1 | | | | | | | | | | | | | 1 | | | | $\downarrow$ | 1 | | | | | | L | | | 1 | | | | | | 1 | | | | | | | | | | | | | L | | | • | 1 | | | | | - 1 | ٠ | _ | | • | ٠ | | Н | | - | Н | | 8C | 5 | 3 | | 1 | | 4 | | | | | | 4 | | | - | | 4 | | | | 1 | + | | | | - | - | l | | | + | | | | | - | 1 | - | | 4 | | | | | | | | | | L | | | • | | | | | • | | • | | | • | | | | | | Ш | | | | | | | | | | | | | | | | | | | | | | | 1 | | | | | | | | | | | | | | | | 1 | | | | | | | | | | | | | L | | | ŀ | | | | | | | | | | | | | Ц | | - | Н | | | | | L | 1 | 1 | _ | | | | ļ | | | | | _ | | 4 | | | | 1 | 1 | _ | | L | | | ļ | 1 | 1 | 1 | | _ | | | 1 | 1 | 1 | | 4 | | | | Ш | 4 | | | | | L | | | ┸ | _ | $\perp$ | $\perp$ | _ | _ | $\perp$ | • | _ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | L | | | | | | | | | | ٠ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | • | • | ١ | 1 | • | • | • | • | • | Z | • | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | • | • | - | • • | • | • | • | • | • | • | ٠ | | | | | | | | | | | | | | | | | | | | | | | | | | | | Ī | | | | | | | | | | | | | | | | Ī | | | | | | | | | | | | | | | | • | • | • | • | | • | • | • | • | • | • | • | | | | | | | | | | | | | | | | | | | | | | | | | | | | Ī | Ī | | | | | | l | | | Ī | | | | | | Ī | | | | | | | | | | | | | | | | • | • | • | ١ | 1 | • | • | • | • | • | z | • | | | | | | | | | | | | | | | | | | | | | | | | | | | | Ī | | | | | | | | | | | | | | | | Ī | | | ĺ | | | | | | | | | | | | | • | • | • | ١ | 1 | • | • | • | • | • | z | • | | | | | | | | | | | | | | | | | | | | | | | | | | | | Ī | Ī | | | | | | | | | | | | | | | ĺ | | | Ì | | | | | | | | | | | | | • | • | • | ١ | 1 | • | • | • | • | • | z | • | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Ī | | | | | | | | | | | | | | | | | • | • | ١ | 1 | • | • | • | • | • | z | • | | | | | | | | | | İ | İ | | | | | | t | | | | | | | Ī | | | | t | t | | | | | | t | | t | İ | | | | | | İ | Ì | | 1 | | | | | | | | | | İ | | | | | | | | | | • | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | • | • | • | Ν | 1 | • | • | • | - 1 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Ν | 1 | • | • | • | • | • | z | ٠ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | • | • | • | ١ | 1 | • | • | • | • | • | z | • | | | | | | | | | | | | | | | | | l | | | | | | | Ī | | | | Ī | Ī | | | | | | l | | | Ī | | | | | | Ī | | | | | | | | | | | | | | | | • | • | 1 | ١ | 1 | • | ٠ | ٠ | • | • | z | • | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | ĺ | | | | | | | | | | | | | | | | • | • | • | | | • | • | • | • | • | • | • | | | | | | | | | | | 1 | | | | | | | | | | | | | | | | | 1 | 1 | | | | | | l | | | 1 | | | | | | t | | | 1 | | | | | | | | | | | | | • | • | • | ١ | 1 | • | • | • | • | • | z | • | | | | | $\prod$ | | | | | l | 1 | | | | | | l | 1 | 1 | | | | | 1 | | | | $\dagger$ | † | | | l | | | Ì | 1 | | 1 | | | | | | t | $\dagger$ | | 1 | | | | | | | | | | T | | | • | • | | ١ | 1 | • | • | • | • | • | z | • | | | | | | | | | | T | 1 | | | | | | İ | 1 | 1 | | | | | 1 | | | | $\dagger$ | † | | | | | | t | $\dagger$ | | † | | | | | | t | $\dagger$ | | † | | | | | | | | | | T | | | • | | | ١ | 1 | • | • | • | • | • | z | • | | | | | $\prod$ | | | | | f | $\dagger$ | + | 1 | | | | t | 1 | 1 | | | t | | 1 | | | | $\dagger$ | $\dagger$ | | | l | | | t | $\dagger$ | | $\dagger$ | | | | | | t | $\dagger$ | $\dagger$ | $\dagger$ | | | | | | | | | | T | | | | | | ١ | 1 | • | • | • | • | • | z | • | | | | | | | | | | | 1 | 1 | 1 | | | | l | | 1 | | | $\mid$ | | 1 | | | | $\dagger$ | $\dagger$ | | | | | | t | | t | $\dagger$ | | | | | | t | | $\downarrow$ | 1 | | | | | | | | | | L | | | | | | | | | | • | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | • | • | ١ | ١ | • | • | • | • | • | Z | ٠ | #### **Appendix 6. Machine instructions** The number of cycles shown in the table is described in the case of the fastest mode for each instruction. The number of cycles shown in the table is calculated for DPRL=0. The number of cycles in the addressing mode concerning the DPR when DPRL 0 must be incremented by 1. The number of cycles shown in the table differs according to the bytes fetched into the instruction queue buffer, or according to whether the memory read/write address is odd or even. It also differs when the external region memory is accessed by BYTE="H." - **Notes 1.** The operation code at the upper row is used for accumulator A, and the operation at the lower row is used for accumulator B. - 2. When setting flag m=0 to handle the data as 16-bit data in the immediate addressing mode, the number of bytes increments by 1. - 3. The number of cycles increments by 2 when branching. - **4.** The operation code on the upper row is used for branching in the range of -128 to +127, and the operation code on the lower row is used for branching in the range of -32768 to +32767. - 5. When handling 16-bit data with flag m=0, the byte in the table is incremented by 1. 6. | Type of register | Α | В | Χ | Υ | DPR | DT | PG | PS | |------------------|---|---|---|---|-----|----|----|----| | Number of cycles | 2 | 2 | 2 | 2 | 2 | 1 | 1 | 2 | The number of cycles corresponding to the register to be pushed are added. The number of cycles when no pushing is done is 12. in indicates the number of registers among A, B, X, Y, DPR, and PS to be saved, while i2 indicates the number of registers among DT and PG to be saved. 7. | Г | Type of register | Α | В | Х | Υ | DPR | DT | PS | |---|------------------|---|---|---|---|-----|----|----| | | Number of cycles | 3 | 3 | 3 | 3 | 4 | 3 | 3 | The number of cycles corresponding to the register to be pulled are added. The number of cycles when no pulling is done is 14. it indicates the number of registers among A, B, X, Y, DT, and PS to be restored, while i2=1 when DPR is to be restored. **8.** The number of cycles is the case when the number of bytes to be transferred is even. When the number of bytes to be transferred is odd, the number is calculated as; $$7 + (i/2) \times 7 + 4$$ Note that, (i/2) shows the integer part when i is divided by 2. 9. The number of cycles is the case when the number of bytes to be transferred is even. When the number of bytes to be transferred is odd, the number is calculated as; $$9 + (i/2) \times 7 + 5$$ Note that, (i/2) shows the integer part when i is divided by 2. - **10.** The number of cycles is the case in the 16-bit ÷ 8-bit operation. The number of cycles is incremented by 16 for 32-bit ÷ 16-bit operation. - 11. The number of cycles is the case in the 8-bit X 8-bit operation. The number of cycles is incremented by 8 for 16-bit X 16-bit operation. - 12. When setting flag x=0 to handle the data as 16-bit data in the immediate addressing mode, the number of bytes increments by 1 - 13. When flag m is 0, the byte in the table is incremented by 1. ## **Appendix 6. Machine instructions** ## Symbols in machine instructions table | Symbol | Description | Symbol | Description | |-------------|------------------------------------------------|-----------------|---------------------------------------------------------------------------| | IMP | Implied addressing mode | $\forall$ | Exclusive OR | | IMM | Immediate addressing mode | _ | Negation | | Α | Accumulator addressing mode | $\leftarrow$ | Movement to the arrow direction | | DIR | Direct addressing mode | Acc | Accumulator | | DIR, b | Direct bit addressing mode | Ассн | Accumulator's upper 8 bits | | DIR, X | Direct indexed X addressing mode | Accl | Accumulator's lower 8 bits | | DIR, Y | Direct indexed Y addressing mode | Α | Accumulator A | | (DIR) | Direct indirect addressing mode | Ан | Accumulator A's upper 8 bits | | (DIR,X) | Direct indexed X indirect addressing mode | AL | Accumulator A's lower 8 bits | | (DIR), Y | Direct indirect indexed Y addressing mode | В | Accumulator B | | L (DIR) | Direct indirect long addressing mode | Вн | Accumulator B's upper 8 bits | | L (DIR),Y | Direct indirect long indexed Y addressing mode | BL | Accumulator B's lower 8 bits | | ABS | Absolute addressing mode | Х | Index register X | | ABS, b | Absolute bit addressing mode | Хн | Index register X's upper 8 bits | | ABS, X | Absolute indexed X addressing mode | XL | Index register X's lower 8 bits | | ABS, Y | Absolute indexed Y addressing mode | Υ | Index register Y | | ABL | Absolute long addressing mode | Yн | Index register Y's upper 8 bits | | ABL, X | Absolute long indexed X addressing mode | YL | Index register Y's lower 8 bits | | (ABS) | Absolute indirect addressing mode | S | Stack pointer | | L (ABS) | Absolute indirect long addressing mode | PC | Program counter | | (ABS, X) | Absolute indexed X indirect addressing mode | РСн | Program counter's upper 8 bits | | STK | Stack addressing mode | PC∟ | Program counter's lower 8 bits | | REL | Relative addressing mode | PG | Program bank register | | DIR, b, REL | Direct bit relative addressing mode | DT | Data bank register | | ABS, b, REL | Absolute bit relative addressing mode | DPR | Direct page register | | SR | Stack pointer relative addressing mode | DPRH | Direct page register's upper 8 bits | | (SR), Y | Stack pointer relative indirect indexed Y | DPR∟ | Direct page register's lower 8 bits | | | addressing mode | PS | Processor status register | | BLK | Block transfer addressing mode | PSн | Processor status register's upper 8 bits | | С | Carry flag | PS∟ | Processor status register's lower 8 bits | | Z | Zero flag | PS <sub>b</sub> | Processor status register's b-th bit | | I | Interrupt disable flag | M(S) | Contents of memory at address indicated by | | D | Decimal operation mode flag | | stack pointer | | х | Index register length selection flag | Mb | b-th memory location | | m | Data length selection flag | ADG | Value of 24-bit address's upper 8-bit (A23-A16) | | V | Overflow flag | ADн | Value of 24-bit address's middle 8-bit (A <sub>15</sub> -A <sub>8</sub> ) | | N | Negative flag | ADL | Value of 24-bit address's lower 8-bit (A7-A0) | | IPL | Processor interrupt priority level | ор | Operation code | | + | Addition | n | Number of cycle | | - | Subtraction | # | Number of byte | | * | Multiplication | i | Number of transfer byte or rotation | | / | Division | İ1, İ2 | Number of registers pushed or pulled | | ^ | Logical AND | | | | <b>V</b> | Logical OR | | | ## Appendix 7. Hexadecimal instruction code table **INSTRUCTION CODE TABLE-1** | NOIKU | cno | N CC | ノレヒ | IABL | E-1 | | | | | | | | | | | | | |-------|------------------------|------|------------|------------|------------|---------|-----------|-------|----------------|------|---------|------|------|-----------|---------|-------|---------| | | D3-D0 | 0000 | 0001 | 0010 | 0011 | 0100 | 0101 | 0110 | 0111 | 1000 | 1001 | 1010 | 1011 | 1100 | 1101 | 1110 | 1111 | | D7-D4 | exadecimal<br>notation | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | Α | В | С | D | Е | F | | 0000 | 0 | DDK | ORA | | ORA | SEB | ORA | ASL | ORA | PHP | ORA | ASL | PHD | SEB | ORA | ASL | ORA | | 0000 | 0 | BRK | A,(DIR,X) | | A,SR | DIR,b | A,DIR | DIR | A,L(DIR) | PHP | A,IMM | Α | PHD | ABS,b | A,ABS | ABS | A,ABL | | 0004 | | BPL | ORA | ORA | ORA | CLB | ORA | ASL | ORA | CLC | ORA | DEC | TAS | CLB | ORA | ASL | ORA | | 0001 | 1 | DPL | A,(DIR),Y | A,(DIR) | A,(SR),Y | DIR,b | A,DIR,X | DIR,X | A,L(DIR),Y | CLC | A,ABS,Y | Α | IAS | ABS,b | A,ABS,X | ABS,X | A,ABL,X | | 0040 | | JSR | AND | JSR | AND | BBS | AND | ROL | AND | PLP | AND | ROL | PLD | BBS | AND | ROL | AND | | 0010 | 2 | ABS | A,(DIR,X) | ABL | A,SR | DIR,b,R | A,DIR | DIR | A,L(DIR) | PLP | A,IMM | Α | PLD | ABS,b,R | A,ABS | ABS | A,ABL | | | | | AND | AND | AND | BBC | AND | ROL | AND | 0=0 | AND | INC | | BBC | AND | ROL | AND | | 0011 | 3 | BMI | A,(DIR),Y | A,(DIR) | A,(SR),Y | DIR,b,R | A,DIR,X | DIR,X | A,L(DIR),Y | SEC | A,ABS,Y | Α | TSA | ABS,b,R | A,ABS,X | ABS,X | A,ABL,X | | | | | EOR | | EOR | | EOR | LSR | EOR | | EOR | LSR | 50 | JMP | EOR | LSR | EOR | | 0100 | 4 | RTI | A,(DIR,X) | Note 1 | A,SR | MVP | A,DIR | DIR | A,L(DIR) | PHA | A,IMM | Α | PHG | ABS | A,ABS | ABS | A,ABL | | | | | EOR | EOR | EOR | | EOR | LSR | EOR | | EOR | | | JMP | EOR | LSR | EOR | | 0101 | 5 | BVC | A,(DIR),Y | A,(DIR) | A,(SR),Y | MVN | A,DIR,X | DIR,X | A,L(DIR),Y | CLI | A,ABS,Y | PHY | TAD | ABL | A,ABS,X | ABS,X | A,ABL,X | | | | | ADC | | ADC | LDM | ADC | ROR | ADC | | ADC | ROR | | JMP | ADC | ROR | ADC | | 0110 | 6 | RTS | A,(DIR,X) | PER | A,SR | DIR | A,DIR | DIR | A,L(DIR) | PLA | A,IMM | Α | RTL | (ABS) | A,ABS | ABS | A,ABL | | | | | ADC | ADC | ADC | LDM | ADC | ROR | ADC | | ADC | | | JMP | ADC | ROR | ADC | | 0111 | 7 | BVS | A,(DIR),Y | A,(DIR) | A,(SR),Y | DIR,X | A,DIR,X | DIR,X | A,L(DIR),Y | SEI | A,ABS,Y | PLY | TDA | (ABS,X) | A,ABS,X | ABS,X | A,ABL,X | | | | BRA | STA | BRA | STA | STY | STA | STX | STA | | | | | STY | STA | STX | STA | | 1000 | 8 | REL | A,(DIR,X) | REL | A,SR | DIR | A,DIR | DIR | A,L(DIR) | DEY | Note 2 | TXA | PHT | ABS | A,ABS | ABS | A,ABL | | | | | STA | STA | STA | STY | STA | STX | STA | | STA | | | LDM | STA | LDM | STA | | 1001 | 9 | BCC | A,(DIR),Y | A,(DIR) | A,(SR),Y | DIR,X | A,DIR,X | DIR,Y | A,L(DIR),Y | TYA | A,ABS,Y | TXS | TXY | ABS | A,ABS,X | ABS,X | A,ABL,X | | | | LDY | LDA | LDX | LDA | LDY | LDA | LDX | LDA | | LDA | | | LDY | LDA | LDX | LDA | | 1010 | Α | IMM | A,(DIR,X) | IMM | A,SR | DIR | A,DIR | DIR | A,L(DIR) | TAY | A,IMM | TAX | PLT | ABS | A,ABS | ABS | A,ABL | | | | | LDA | LDA | LDA | LDY | LDA | LDX | LDA | | LDA | | | LDY | LDA | LDX | LDA | | 1011 | В | BCS | A,(DIR),Y | A,(DIR) | A,(SR),Y | DIR,X | A,DIR,X | DIR,Y | A,L(DIR),Y | CLV | A,ABS,Y | TSX | TYX | ABS,X | A,ABS,X | ABS,Y | A,ABL,X | | | | CPY | CMP | CLP | CMP | CPY | CMP | DEC | CMP | | CMP | | | CPY | CMP | DEC | CMP | | 1100 | С | IMM | A,(DIR,X) | IMM | A,SR | DIR | A,DIR | DIR | A,L(DIR) | INY | A,IMM | DEX | WIT | ABS | A,ABS | ABS | A,ABL | | | | | CMP | CMP | CMP | | CMP | DEC | CMP | | CMP | | | JMP | CMP | DEC | CMP | | 1101 | D | BNE | A,(DIR),Y | A,(DIR) | A,(SR),Y | PEI | A,DIR,X | DIR,X | A,L(DIR),Y | CLM | A,ABS,Y | PHX | STP | L(ABS) | A,ABS,X | ABS,X | A,ABL,X | | | | CPX | SBC | SEP | SBC | CPX | SBC | INC | SBC | | SBC | | | CPX | SBC | INC | SBC | | 1110 | Е | IMM | A,(DIR,X) | IMM | A,SR | DIR | A,DIR | DIR | A,L(DIR) | INX | A,IMM | NOP | PSH | ABS | A,ABS | ABS | A,ABL | | | | 1 | SBC | SBC | SBC | | SBC | INC | SBC | | SBC | | | JSR | SBC | INC | SBC | | 1111 | F | BEQ | A,(DIR),Y | A,(DIR) | A,(SR),Y | PEA | A,DIR,X | DIR.X | A,L(DIR),Y | SEM | A,ABS,Y | PLX | PUL | (ABS,X) | A,ABS,X | ABS,X | A,ABL,X | | | | | ,(=111/),1 | / ',(5111) | ,(311/), 1 | l | . ,,=,,/( | 2,. | , , L(DIIV), I | L | ,, 1 | | | (,,,,,,,, | ,50,/ | 20,7 | ,,/\ | **Notes 1:** 4216 specifies the contents of the INSTRUCTION CODE TABLE-2. About the second word's codes, refer to the INSTRUCTION CODE TABLE-2. <sup>2: 89&</sup>lt;sub>16</sub> specifies the contents of the INSTRUCTION CODE TABLE-3. About the second word's codes, refer to the INSTRUCTION CODE TABLE-2. | INSTRUCTION CODE TABLE-2 (The first word's code of each instruct | tion is | instruction | s 4216) | |------------------------------------------------------------------|---------|-------------|---------| |------------------------------------------------------------------|---------|-------------|---------| | ORA B,(DIR),Y B,(DIR) B,(SR),Y B,DIRX B,L(DIR),Y B,ABS,Y B B,ABS,X B,ABL,X | INSTRU | | N CC | JUE | IABL | .E-2 ( | ıne | tirst | wora | s coo | ne or | eacn | ınst | ructio | n is | 4216) | | | |------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|------|-----------|---------|----------|------|---------|------|------------|-------|---------|------|--------|------|---------|------|---------| | 17-14 | | D3-D0 | 0000 | 0001 | 0010 | 0011 | 0100 | 0101 | 0110 | 0111 | 1000 | 1001 | 1010 | 1011 | 1100 | 1101 | 1110 | 1111 | | 0000 | D7-D4 | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | Α | В | С | D | Е | F | | B_(DIRX) | 0000 | 0 | | ORA | | ORA | | ORA | | ORA | | ORA | ASL | | | ORA | | ORA | | 0001 | 0000 | 0 | | B,(DIR,X) | | B,SR | | B,DIR | | B,L(DIR) | | B,IMM | В | | | B,ABS | | B,ABL | | B_(DIR)Y B_(DIR)Y B_(DIR) B_(SR)Y B_DIRX B_DIRX B_DIRYY B_ABS,Y B_AND AND AND AND AND AND AND AND AND AND | 0001 | 1 | | ORA | ORA | ORA | | ORA | | ORA | | ORA | DEC | TDC | | ORA | | ORA | | 0010 2 | 0001 | ' | | B,(DIR),Y | B,(DIR) | B,(SR),Y | | B,DIR,X | | B,L(DIR),Y | | B,ABS,Y | В | 103 | | B,ABS,X | | B,ABL,X | | B,(Dir,X) | 0010 | 2 | | AND | | AND | | AND | | AND | | AND | ROL | | | AND | | AND | | 0011 3 | 0010 | 2 | | B,(DIR,X) | | B,SR | | B,DIR | | B,L(DIR) | | B,IMM | В | | | B,ABS | | B,ABL | | B, D(R), Y, B, D(R) B, SR, Y | 0011 | | | AND | AND | AND | | AND | | AND | | AND | INC | TCD | | AND | | AND | | 0100 | 0011 | 3 | | B,(DIR),Y | B,(DIR) | B,(SR),Y | | B,DIR,X | | B,L(DIR),Y | | B,ABS,Y | В | 198 | | B,ABS,X | | B,ABL,X | | B,(DIR,X) | 0400 | | | EOR | | EOR | | EOR | | EOR | חום | EOR | LSR | | | EOR | | EOR | | 0101 5 | 0100 | 4 | | B,(DIR,X) | | B,SR | | B,DIR | | B,L(DIR) | РНВ | B,IMM | В | | | B,ABS | | B,ABL | | B_(DIR),Y B_(DIR) B_(SR),Y B_DIR,X B_LDIR,Y B_DIR,X B_LDIR,Y B_DIR,X B_LDIR,Y B_DIR,X B_LDIR,Y B_DIR,X B_LDIR,Y B_DIR,X B_LDIR,Y B_DIR,X B_DIR | 0404 | _ | | EOR | EOR | EOR | | EOR | | EOR | | EOR | | TDD | | EOR | | EOR | | O110 6 | 0101 | 5 | | B,(DIR),Y | B,(DIR) | B,(SR),Y | | B,DIR,X | | B,L(DIR),Y | | B,ABS,Y | | IBD | | B,ABS,X | | B,ABL,X | | B,(Dir, X) | 0440 | | | ADC | | ADC | | ADC | | ADC | DI D | ADC | ROR | | | ADC | | ADC | | O111 | 0110 | 6 | | B,(DIR,X) | | B,SR | | B,DIR | | B,L(DIR) | PLB | B,IMM | В | | | B,ABS | | B,ABL | | B_(DIR),Y B_(DIR) B_(SR),Y B_DIR,X B_L(DIR),Y B_ABS,Y B_ABS,X B_ABS,X B_ABL,Y | | _ | | ADC | ADC | ADC | | ADC | | ADC | | ADC | | | | ADC | | ADC | | 1000 8 | 0111 | / | | B,(DIR),Y | B,(DIR) | B,(SR),Y | | B,DIR,X | | B,L(DIR),Y | | B,ABS,Y | | IDB | | B,ABS,X | | B,ABL,X | | B,(DIR,X) | | | | STA | | STA | | STA | | STA | | | | | | STA | | STA | | 1001 9 | 1000 | 8 | | B,(DIR,X) | | B,SR | | B,DIR | | B,L(DIR) | | | TXB | | | B,ABS | | B,ABL | | B,(DIR),Y B,(DIR) B,(SR),Y B,DIR,X B,L(DIR),Y B,ABS,Y B,ABS,X B,ABL,X B,ABL, | | _ | | STA | STA | STA | | STA | | STA | | STA | | | | STA | | STA | | 1010 | 1001 | 9 | | B,(DIR),Y | B,(DIR) | B,(SR),Y | | B,DIR,X | | B,L(DIR),Y | TYB | B,ABS,Y | | | | B,ABS,X | | B,ABL,X | | B,(DIR,X) | | _ | | LDA | | LDA | | LDA | | LDA | | LDA | | | | LDA | | LDA | | 1011 B | 1010 | A | | B,(DIR,X) | | B,SR | | B,DIR | | B,L(DIR) | TBY | B,IMM | TBX | | | B,ABS | | B,ABL | | B,(DIR),Y B,(DIR) B,(SR),Y B,DIR,X B,L(DIR),Y B,ABS,Y B,ABS,X B,ABL,Y CMP | | | | LDA | LDA | LDA | | LDA | | LDA | | LDA | | | | LDA | | LDA | | 1100 C | 1011 | В | | B,(DIR),Y | B,(DIR) | B,(SR),Y | | B,DIR,X | | B,L(DIR),Y | | B,ABS,Y | | | | B,ABS,X | | B,ABL,X | | B,(DIR,X) | | | | CMP | | CMP | | CMP | | CMP | | CMP | | | | CMP | | CMP | | 1101 D | 1100 | C | | B,(DIR,X) | | B,SR | | B,DIR | | B,L(DIR) | | B,IMM | | | | B,ABS | | B,ABL | | B,(DIR),Y B,(DIR) B,(SR),Y B,DIR,X B,L(DIR),Y B,ABS,Y B,ABS,X B,ABL,X | | | | CMP | CMP | CMP | | CMP | | СМР | | CMP | | | | CMP | | CMP | | SBC | 1101 | D | | B,(DIR),Y | B,(DIR) | B,(SR),Y | | B,DIR,X | | B,L(DIR),Y | | B,ABS,Y | | | | B,ABS,X | | B,ABL,X | | B,(DIR,X) | | | | | | | | | | | | | | | | | | | | SBC SBC SBC SBC SBC SBC SBC SBC | 1110 | E | | B,(DIR,X) | | B,SR | | B,DIR | | B,L(DIR) | | B,IMM | | | | B,ABS | | B,ABL | | | | | | - | SBC | | | · · | | , | | - | | | | - | | | | 1111 F B,(DIR),Y B,(DIR) B,(SR),Y B,DIR,X B,L(DIR),Y B,ABS,Y B,ABS,X B,ABL,X | 1111 | F | | B,(DIR),Y | B,(DIR) | B,(SR),Y | | B,DIR,X | | B,L(DIR),Y | | B,ABS,Y | | | | B,ABS,X | | B,ABL,X | ## Appendix 7. Hexadecimal instruction code table | INSTRU | <u>ICTIO</u> | N CC | DDE . | TABL | E-3 ( | The | first v | word' | s coc | le of | each | inst | uctio | n is | 8916) | | | |--------|------------------------|------|---------|-------|--------|------|---------|-------|----------|-------|-------|------|-------|------|-------|------|-------| | | D3-D0 | 0000 | 0001 | 0010 | 0011 | 0100 | 0101 | 0110 | 0111 | 1000 | 1001 | 1010 | 1011 | 1100 | 1101 | 1110 | 1111 | | D7-D4 | exadecimal<br>notation | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | А | В | С | D | Е | F | | 0000 | 0 | | MPY | | MPY | | MPY | | MPY | | MPY | | | | MPY | | MPY | | 0000 | 0 | | (DIR,X) | | SR | | DIR | | L(DIR) | | IMM | | | | ABS | | ABL | | 0001 | 1 | | MPY | MPY | MPY | | MPY | | MPY | | MPY | | | | MPY | | MPY | | 0001 | ' | | (DIR),Y | (DIR) | (SR),Y | | DIR,X | | L(DIR),Y | | ABS,Y | | | | ABS,X | | ABL,X | | 0010 | 2 | | DIV | | DIV | | DIV | | DIV | XAB | DIV | | | | DIV | | DIV | | 0010 | | | (DIR,X) | | SR | | DIR | | L(DIR) | AAD | IMM | | | | ABS | | ABL | | 0011 | 3 | | DIV | DIV | DIV | | DIV | | DIV | | DIV | | | | DIV | | DIV | | 0011 | 3 | | (DIR),Y | (DIR) | (SR),Y | | DIR,X | | L(DIR),Y | | ABS,Y | | | | ABS,X | | ABL,X | | 0100 | 4 | | | | | | | | | | RLA | | | | | | | | 0100 | | | | | | | | | | | IMM | | | | | | | | 0101 | 5 | | | | | | | | | | | | | | | | | | 0110 | 6 | | | | | | | | | | | | | | | | | | 0111 | 7 | | | | | | | | | | | | | | | | | | 1000 | 8 | | | | | | | | | | | | | | | | | | 1001 | 9 | | | | | | | | | | | | | | | | | | 1010 | А | | | | | | | | | | | | | | | | | | 1011 | В | | | | | | | | | | | | | | | | | | 1100 | С | | | LDT | | | | | | | | | | | | | | | 1101 | D | | | | | | | | | | | | | | | | | | 1110 | Е | | | | | | | | | | | | | | | | | | 1111 | F | | | | | | | | | | | | | | | | | #### Appendix 8. Countermeasure against noise General countermeasure examples against noise are described below. Although the effect of these countermeasure depends on each system, refer to the following when an noise-related problem occurs. #### 1. Short wiring length The wiring on a printed circuit board may function as an antenna which feeds noise into the microcomputer. The shorter the total wiring length (by mm unit), the less possibility of noise insertion into the microcomputer. #### (1) Wiring for RESET pin Make the length of wiring connected to the $\overline{RESET}$ pin as short as possible. In particular, connect a capacitor between the $\overline{RESET}$ pin and the Vss pin with the shortest possible wiring (within 20 mm). **Reason:** If noise is input to the RESET pin, the microcomputer restarts operation before the internal state of the microcomputer is completely initialized. This may cause a program runaway. Fig. 3 Wiring for RESET pin #### (2) Wiring for clock input/output pins - Make the length of wiring connected to the clock input/output pins as short as possible. - Make the length of wiring between the grounding lead of the capacitor, which is connected to the oscillator, and the Vss pin of the microcomputer, as short as possible (within 20 mm). - Separate the Vss pattern for oscillation from all other Vss patterns. (Refer to "Figure 11.") **Reason:** The microcomputer's operation synchronizes with a clock generated by the oscillation circuit. If noise enters clock I/O pins, clock waveforms may be deformed. This may cause a malfunction or a program runaway. Also, if the noise causes a potential difference between the Vss level of the microcomputer and the Vss level of an oscillator, the correct clock will not be input in the microcomputer. Fig. 4 Wiring for clock input/output pins #### Appendix 8. Countermeasure against noise #### (3) Wiring for CNVss pin Connect CNVss pin to the Vss pin with the shortest possible wiring. Reason The processor mode of the microcomputer is influenced by a potential at the CNVss pin when the CNVss pin and the Vcc or Vss pin are connected. If the noise causes a potential difference between the CNVss pin and the Vss or Vcc pin, the processor mode may become unstable. This may cause a microcomputer malfunction or a program runaway. Fig. 5 Wiring for CNVss pin #### 2. Connection of bypass capacitor between Vss and Vcc lines Connect an approximate 0.1 $\mu$ F bypass capacitor as follows: - Connect a bypass capacitor between the Vss and Vcc pins, at equal lengths. - The wiring connecting the bypass capacitor between the Vss and Vcc pins should be as short as possible. - Use thicker wiring for the Vss and Vcc lines than that for the other signal lines. Fig. 6 Bypass capacitor between Vss and Vcc lines - 3. Wiring for analog input pins, analog power source pins, etc. - (1) Processing for analog input pins - Connect a resistor to the analog signal line, which is connected to an analog input pin, in series. Additionally, connect the resistor to the microcomputer as close as possible. - Connect a capacitor between the analog input pin and the AVss pin, as close to the AVss pin as possible. **Reason:** A signal which is input to the analog input pin is usually an output signal from a sensor. The sensor, which detects changes in status, is installed far from the microcomputer's printed circuit board. Therefore, this long wiring between them becomes an antenna which picks up noise and feeds it into the microcomputer's analog input pin. If a capacitor between an analog input pin and the AVss pin is grounded far away from the AVss pin, noise on the GND line may enter the microcomputer through the capacitor. **Notes 1 :** Design an external circuit for the ANi pin so that charge/discharge is available within 1 cycle of $\phi$ AD. 2: This resistor and thermistor are used to divide resistance. Fig. 7 Countermeasure example against noise for analog input pin using thermistor #### Appendix 8. Countermeasure against noise - (2) Processing for analog power source pins, etc. - Use independent power sources for the Vcc, AVcc and VREF pins. - Insert capacitors between the AVcc and AVss pins, and between the VREF and AVss pins. Reasons: Prevents the A-D converter from noise on the Vcc line. Fig. 8 Processing for analog power source pins, etc. #### 4. Oscillator protection The oscillator, which generates the basic clock for the microcomputer operations, must be protected from the affect of other signals. #### (1) Distance oscillator from signal lines with large current flows Install the microcomputer, especially the oscillator, as far as possible from signal lines which handle currents larger than the microcomputer current value tolerance. Reason: The microcomputer is used in systems which contain signal lines for controlling motors, LEDs, thermal heads, etc. Noise occurs due to mutual inductance when a large current flows through the signal lines. Fig. 9 Wiring for signal lines where large current flows #### (2) Distance oscillator from signal lines with frequent potential level changes - Install an oscillator and its wiring pattern away from signal lines where potential levels change frequently. - Do not cross these signal lines over the clock-related or noise-sensitive signal lines. Reason: Signal lines with frequently changing potential levels may affect other signal lines at a rising or falling edge. In particular, if the lines cross over a clock-related signal line, clock waveforms may be deformed, which causes a microcomputer malfunction or a program runaway. Fig. 10 Wiring for signal lines where potential levels frequently change # (3) Oscillator protection using Vss pattern Print a Vss pattern on the bottom (soldering side) of a double-sided printed circuit board, under the oscillator mount position. Connect the Vss pattern to the Vss pin of the microcomputer with the shortest possible wiring, separating it from other Vss patterns. Fig. 11 Vss pattern underneath mounted oscillator #### Appendix 8. Countermeasure against noise #### 5. Setup for I/O ports Setup I/O ports by hardware and software as follows: #### <Hardware protection> lacktriangle Connect a resistor of 100 $\Omega$ or more to an I/O port in series. #### <Software protection> - Read the data of an input port several times to confirm that input levels are equal. - Since the output data may reverse because of noise, rewrite data to the output port's Pi register periodically. - Rewrite data to port Pi direction registers periodically. Fig. 12 Setup for I/O ports #### 6. Reinforcement of the power source line - For the Vss and Vcc lines, use thicker wiring than that of other signal lines. - When using a multilayer printed circuit board, the Vss and Vcc patterns must each be one of the middle layers - The following is necessary for double-sided printed circuit boards: - •On one side, the microcomputer is installed at the center, and the Vss line is looped or meshed around it. The vacant area is filled with the Vss line. - •On the opposite side, the Vcc line is wired the same as the Vss line. - •The power source lines of external devices which are connected by bus to the microcomputer must be connected to the microcomputer's power source lines with the shortest possible wiring. **Reasons:** With external devices connected to the microcomputer, the levels of many of the signal lines (total external address buses: 24 bits) may change simultaneously, causing noise on the power source line. #### Appendix 9. 7721 Group Q & A Information which may be helpful in fully utilizing the 7721 Group is provided in Q & A format. In Q & A, as a rule, one question and its answer are summarized within one page. The upper box on each page is a question, and a box below the question is its answer. (If a question or an answer extends to two or more pages, there is a page number at the lower right corner.) At the upper right corner of each page, the main function related to the contents of description in that page is listed. #### Appendix 9. 7721 Group Q & A SFR Q Is there any SFR to which a certain instruction cannot be used for writing? # A (1) Use the LDM or STA instruction to write to the registers or the bits listed below. Do not use read-modify-write instructions (i.e., CLB, SEB, ASL, ASR, DEC, INC, LSR, ROL, and ROR). Pulse output data register 0, 1 (addresses $1A_{16}$ , $1C_{16}$ ) UARTO, 1 baud rate register (addresses $31_{16}$ , $39_{16}$ ) UARTO, 1 transmit buffer register (addresses $33_{16}$ , $32_{16}$ , $3B_{16}$ , $3A_{16}$ ) Timer A2-A4 two-phase pulse signal processing select bit (bits 5-7 at address $44_{16}$ ) Timer A2-A4 register (addresses $4A_{16}$ - $4F_{16}$ ; one-shot pulse mode or pulse width modulation mode) Refresh timer (address $66_{16}$ ) (2) Use the SEB or CLB instruction to write to the following register. DMAC control register H (address $69_{16}$ ; when any of bits 4 to 7 = "1") #### Appendix 9. 7721 Group Q & A Reset, STP instruction, WIT instruction Q Is it possible to distinguish power-on reset from hardware reset for terminating the stop or wait mode ? The contents of the internal RAM is undefined after power-on reset. On the other hand, the contents of the internal RAM are retained when performing hardware reset in the stop or wait mode with $Vcc \ge 2 \ V$ . Accordingly, write a certain data to the internal RAM before executing **STP** or **WIT** instruction, and judge by checking the contents of the internal RAM after hardware reset. #### Appendix 9. 7721 Group Q & A Interrupt Q If an interrupt request (b) occurs while executing an interrupt routine (a), is it true that the main routine is not executed at all from when the execution of the interrupt routine (a) is completed until the execution of the INTACK sequence for the next interrupt (b) starts? #### Conditions: - I is cleared to "0" by executing the RTI instruction. - linterrupt priority level of interrupt (b) is higher than IPL of main routine. - Interrupt priority detection time is 2 cycles of $\phi$ . # A Sampling for interrupt requests is performed by sampling pulses generated synchronously with the CPU's op-code fetch cycles. (1) If the next interrupt request (b) occurs before sampling pulse ① for the RTI instruction is generated, the microcomputer executes the INTACK sequence for (b) without executing the main routine (not even one instruction). It is because that sampling is completed while executing the RTI instruction. (2) If the next interrupt request (b) occurs immediately after sampling pulse ① is generated, the microcomputer executes one instruction of the main routine before executing the INTACK sequence for (b). It is because that the interrupt request is sampled by the next sampling pulse ②. ✓ Interrupt request (b) Interrupt Q Suppose that there is a routine which should not accept one certain interrupt request. (The other interrupt request are acceptable). Although when the interrupt priority level select bits for the above interrupt are set to "0002," in other words, when this interrupt is set to be disabled, this interrupt request is actually accepted immediately after change of the priority level. Why did this occur and what should I do about it? Interrupt request is accepted in this → Clears interrupt request bit to "0."; Writes "0002" to interrupt priority level select bits. ; Clears interrupt request bit to "0." ; Instruction at the beginning of the routine which should not accept one certain interrupt request. A As for the change of the interrupt priority level, when the following are met, the microcomputer may pretend to accept an interrupt request immediately after this interrupt is set to be disabled: - •The next instruction (in the above example, it is the **LDA** instruction) is already stored into a instruction queue buffer for the BIU. - •Conditions for accepting the instruction which should not be accepted are satisfied immediately before the next instruction in the instruction queue buffer is executed. When writing to a memory or an I/O, the CPU passes the address and data to the BIU. Then, the CPU executes the next instruction in the instruction queue buffer while the BIU is writing data into the actual address. Detection of interrupt priority level is performed at the beginning of each instruction. In the above case, the CPU executes the next instruction before the BIU completes the change of the interrupt priority level. Therefore, when the interrupt priority level is detected synchronously with the execution of the next instruction, the interrupt priority level before the change is detected and its interrupt request is accepted. (1/2) #### Appendix 9. 7721 Group Q & A Interrupt To prevent this problem, after change of the interrupt priority level is completed, use software to execute the routine that should not accept a certain interrupt request. The following shows a sample program. #### [Sample program] After an instruction which writes "0002" to the interrupt priority level select bits, fill the instruction queue buffer with the **NOP** instruction to make the next instruction not to be executed before the writing is completed. : LDM #00H, XXXIC; Sets the interrupt priority level select bits to "0002." NOP ; NOP ; NOP LDA A,DATA ; Instruction at the beginning of the routine that should not accept a certain interrupt request (2/2) Interrupt Q - (1) Which timing of clock $\phi_1$ is the external interrupts (input signals to the $\overline{INT_i}$ pin) detected? - (2) How can four or more external interrupt input pins (INT<sub>i</sub>) be used? # A - (1) In both the edge sense and level sense, external interrupt requests occur when the input signal to the $\overline{INT_i}$ pin changes its level. This is independent of clock $\phi_1$ . In the edge sense, the interrupt request bit is set to "1" at this time. - (2) There are two methods: one uses external interrupt's level sense, and the other uses the timer's event counter mode. #### ① Method using external interrupt's level sense As for hardware, input a logical sum of multiple interrupt signals (e.g., 'a', 'b', and 'c') to the INT<sub>i</sub> pin, and input each signal to each corresponding port. As for software, check the ports' input levels in the $\overline{INT_i}$ interrupt routine in order to detect which signal ('a', 'b', or 'c') was input. #### 2 Method using timer's event counter mode As for hardware, input interrupt signals to the TAin pins or TBin pins. As for software, set the timer's operating mode to the event counter mode. Then, set a value "000016" into the timer register and select the valid edge. The timer's interrupt request occurs when an interrupt signal (selected valid edge) is input. #### Appendix 9. 7721 Group Q & A Stack, DRAM Q What are there the stack bank select bit (bit 7 at address 5E<sub>16</sub>) for? It is supposed that DRAM is used as the stack area. When connecting DRAM, the stack pointer addressing mode or stack operation instruction etc. can be used. It is because all of 64 Kbytes can be used as the stack area when bank FF<sub>16</sub> which is assigned to DRAM is set as the stack area. (The internal RAM also functions as the temporary area or the register file which is accessed frequently because the internal RAM can be accessed with no Wait. Accordingly, it is expected that the capacity will lack to be used as the stack area. As for the M37721, DRAM area can be set as the stack area because cheap DRAM can be connected.) Use bank 0 which is assigned to the internal RAM area as the stack area when DRAM is not connected or the internal RAM is sufficient to be used as the stack area. ## Appendix 9. 7721 Group Q & A DRAM, WIT instruction | | | • | |---|----|---| | 1 | r | 7 | | ١ | L, | 4 | | • | • | - | Are there methods to refresh DRAM in the wait mode? # Α In the wait mode, DRAM refresh function does not operate, but the watchdog timer, timer A, and timer B operate. Accordingly, DRAM can be refreshed by using these timers and ports. (1) Method using watchdog timer Return from the wait mode by the watchdog timer interrupt. Control ports P10<sub>4</sub>, P10<sub>5</sub> by software and perform the CAS-before-RAS-refresh. | Interval of watchdog timer interrupt | | | | | | | | | | | |--------------------------------------|---|--------------------------|---------------------------|--|--|--|--|--|--|--| | f(X <sub>IN</sub> ) | | f <sub>32</sub> selected | f <sub>512</sub> selected | | | | | | | | | 25 MH | Z | 2.621 ms | 41.943 ms | | | | | | | | | 16 MH | z | 4.096 ms | 65.536 ms | | | | | | | | - **Example 1:** A case in 1024 refresh cycles, every 16.4 ms, $f(X_{IN}) = 16$ MHz, watchdog timer count source = $f_{32}$ - •DRAM refresh is performed 256 times. This refresh is performed by every watchdog timer interrupt. (See flow chart ①.) (1/2) DRAM, WIT instruction # A (2) Method using timer A or timer B Return from the wait mode by a timer A ( or timer B) interrupt every definite time. Control ports P10<sub>4</sub>, P10<sub>5</sub> by software and perform the CAS-before-RAS-refresh. **Example 2:** A case in 512 refresh cycles, every 64 ms, f(X<sub>IN</sub>) = 25 MHz, timer A0 used •DRAM refresh is performed 512 times by timer A0 interrupts. This interrupt occurs every 64 ms. (See flow chart ②.) #### Appendix 9. 7721 Group Q & A DRAM Q How is the program execution time affected when using DRAM? When the M37721 uses DRAM, the execution time is affected as follows: - •CPU stops and DRAM refresh cycle is inserted. - •1-bus cycle becomes $3\phi$ when accessing DRAM. - (1) Refresh method of the M37721's DRAMC is the dispersion refresh and 5 cycles of $\phi$ are necessary for one refresh. The rate occupied by the DRAM refresh cycle during the program execution time is described below. Rate occupied by DRAM refresh cycle during program execution time | Defrach interval | Rate occupied by DRAM refresh cyc | | | | | |-------------------------------------------|-----------------------------------|------------------------------|--|--|--| | Refresh interval | $f(X_{IN}) = 25 \text{ MHz}$ | $f(X_{IN}) = 16 \text{ MHz}$ | | | | | 15.625 μs | 2.6 % | 4.2 % | | | | | (Case of 512 refresh cycles, every 8 ms) | 2.0 % | 1.2 70 | | | | | 125 µs | 0.3 % | 0.5 % | | | | | (Case of 512 refresh cycles, every 64 ms) | | 0.0 70 | | | | (2) The comparison results of two sample programs' execution times are listed below; one is for the case where SRAM is used and the other is for the case where DRAM is used. Use conditions: Execution program Sample program B (See (2/2)) $f(X_{IN})$ 16 MHz External data bus width 16 bits Refresh interval 13 $\mu$ s | Memory used as work area | Software wait valid area | Execution time | Speed comparison | |-------------------------------|--------------------------|----------------|------------------| | SRAM | Nothing | 3.4 ms | 1.00 | | SRAM | ROM and RAM | 5.0 ms | 1.47 | | DRAM (bank FF <sub>16</sub> ) | Nothing | 3.9 ms | 1.15 | | DRAM (bank FF <sub>16</sub> ) | ROM | 5.2 ms | 1.53 | (1/2) DRAM ``` A ●Sample program B SEP X CLM .DATA 16 .INDEX 8 LDY #69 LOOP0: #69 LDX LOOP1: ASL SOUR, X SEM .DATA ROL SOUR+2, X ROL CLM .DATA 16 ROR Α DEX DEX DEX LOOP1 BNE STA A, DEST, Y SEM .DATA STA B, DEST+2, Y CLM .DATA 16 DEY DEY DEY BNE LOOP0 * SOUR, DEST: Work areas (2/2) ``` ### Appendix 9. 7721 Group Q & A Watchdog timer Q When detecting the software runaway by the watchdog timer, if the same value as the contents of the reset vector address is set to the watchdog timer interrupt vector address, not performing software reset, how does it result in? When branching to the reset branch address within the watchdog timer interrupt routine, how does it result in? The CPU registers and the SFR are not initialized in the above-mentioned way. Accordingly, the user must initialize all of them by software. Note that the processor interrupt priority level (IPL) retains "7" of the watchdog timer interrupt priority level and is not initialized. Consequently, all interrupt requests cannot be accepted. When rewriting the IPL by software, save once the 16-bit immediate value to the stack area and then restore that 16-bit immediate value to all bits of the processor status register (PS). When a software runaway occurs, we recommend to use software reset in order to initialize the microcomputer. # Appendix 10. Differences between 7721 Group and 7720 Group Table 2 Differences between M37721S2BFP and M37720S1AFP | | Item | M37721S2BFP | M37720S1AFP | |---------------------|-------------------------------------------------|-----------------------------------------|-------------------------------| | Interna | al RAM size | 1024 bytes (Note) | 512 bytes | | Extern | al clock input frequency | 25 MHz (maximum) | 16 MHz (maximum) | | Instruc | ction execution time (minimum) | 160 ns | 250 ns | | ا يو | Bit configuration of | 4 bits X 2 channels, or | 4 bits X 2 channels | | ti di | real-time output channel | 6 bits X 1channel and 2 bits X 1channel | | | Real-time<br>output | Port latch state after | Retains the value before using | Undefined | | ∞ o | using real-time output | real-time output | | | Limitat | ion for instruction used when writing | Nothing (LDM, STA instructions | Exists (LDM, STA instructions | | to inte | rrupt control register | can be used.) | cannot be used.) | | Tim | ing when overrun error flag | One of the following: | One of the following: | | bec | omes "0" | •When setting the receive enable | •When setting the receive | | | | bit to "0" | enable bit to "0" | | | | •When setting the serial I/O mode | •When setting the serial I/O | | 0 | | select bits to "0002" | mode select bits to "0002" | | <u>-</u> | | | •When reading the receive | | erial I/O | | | buffer register | | | nditions for outputting "L" of $\overline{RTS}$ | When all of the following are | When all of the following are | | sign | nal in clock synchronous serial I/O | satisfied: | satisfied: | | mod | de | •Receive enable bit = "1" | •Receive enable bit = "1" | | | | •Reception is stopped. | •Reception is stopped. | | | | •Dummy data is present in the | | | | | transmit buffer register | | | DMA s | shortest transfer rate | 12.5 Mbytes/sec | 8 Mbytes/sec | | (At 1-b | ous cycle transfer) | | | Note: 512 bytes can be selected by software. For the M37721S1BFP, its internal RAM size is 512 bytes. # Appendix 11. Electrical characteristics ### **Appendix 11. Electrical characteristics** The electrical characteristics of the M37721S2BFP are described below. For the latest data, inquire of addresses described last (**\*\*\*CONTACT ADDRESSES FOR FURTHER INFORMATION\*\*)**. Absolute maximum ratings | Symbol | | Parameter | Conditions | Ratings | Unit | |--------|---------------------|---------------------------------------------------------------------------------------------------------------------------------------|------------|-----------------|------| | Vcc | Power source volta | ge | | -0.3 to 7 | V | | AVcc | Analog power source | ce voltage | | -0.3 to 7 | V | | Vı | Input voltage | RESET, CNVss, BYTE | | -0.3 to 12 | V | | Vı | Input voltage | A8/D8-A15/D15, A16/D0-A23/D7, | | | | | | | P4 <sub>3</sub> -P4 <sub>7</sub> , P5 <sub>0</sub> -P5 <sub>7</sub> , P6 <sub>0</sub> -P6 <sub>7</sub> , | | | | | | | P7 <sub>0</sub> -P7 <sub>7</sub> , P8 <sub>0</sub> -P8 <sub>7</sub> , P9 <sub>0</sub> -P9 <sub>7</sub> , | | -0.3 to Vcc+0.3 | V | | | | P100–P107, $\overline{RDY}$ , $\overline{HOLD}$ , $X_{IN}$ , $V_{REF}$ | | | | | Vo | Output voltage | A <sub>0</sub> /MA <sub>0</sub> –A <sub>7</sub> /MA <sub>7</sub> , A <sub>8</sub> /D <sub>8</sub> –A <sub>15</sub> /D <sub>15</sub> , | | | | | | | $A_{16}/D_0-A_{23}/D_7$ , $P4_3-P4_7$ , | | | | | | | P5 <sub>0</sub> -P5 <sub>7</sub> , P6 <sub>0</sub> -P6 <sub>7</sub> , P7 <sub>0</sub> -P7 <sub>7</sub> , | | | | | | | P80-P87, P90-P97, P100-P107, | | -0.3 to Vcc+0.3 | V | | | | $\phi_1$ , $\overline{RESETout}$ , $Xout$ , $\overline{E}$ , $ST0$ , | | | | | | | ST1, ALE, BLE, BHE, R/W | | | | | Pd | Power dissipation | | Ta = 25 °C | 300 | mW | | Topr | Operating temperat | ure | | -20 to 85 | °C | | Tstg | Storage temperatur | e | | -40 to 150 | °C | ### Appendix 11. Electrical characteristics Recommended operating conditions ( $Vcc = 5 V \pm 10 \%$ , Ta = -20 to 85 °C, unless otherwise noted) | Symbol | Parameter | | | Limits | | | |-----------|--------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|---------|--------|----------|------| | | | | Min. | Тур. | Max. | Unit | | Vcc | Power source voltage | | 4.5 | 5.0 | 5.5 | V | | AVcc | Analog power source volta | age | | Vcc | | V | | Vss | Power source voltage | | | 0 | | V | | AVss | Analog power source volta | age | | 0 | | V | | VIH | High-level input voltage | P4 <sub>3</sub> -P4 <sub>7</sub> , P5 <sub>0</sub> -P5 <sub>7</sub> , P6 <sub>0</sub> -P6 <sub>7</sub> , P7 <sub>0</sub> -P7 <sub>7</sub> , | | | | | | | | P80-P87, P90-P97, P100-P107, RDY, | 0.8 Vcc | | Vcc | V | | | | HOLD, BYTE, CNVss, RESET, XIN, VREF | | | | | | $V_{IH}$ | High-level input voltage | $A_8/D_8$ - $A_{15}/D_{15}$ , $A_{16}/D_0$ - $A_{23}/D_7$ | 0.5 Vcc | | Vcc | V | | VIL | Low-level input voltage | P4 <sub>3</sub> -P4 <sub>7</sub> , P5 <sub>0</sub> -P5 <sub>7</sub> , P6 <sub>0</sub> -P6 <sub>7</sub> , P7 <sub>0</sub> -P7 <sub>7</sub> , | | | | | | | | P80-P87, P90-P97, P100-P107, RDY, | 0 | | 0.2 Vcc | V | | | | HOLD, BYTE, CNVSS, RESET, XIN, | | | 0.2 000 | V | | | | V <sub>REF</sub> | | | | | | $V_{IL}$ | Low-level input voltage | $A_8/D_8-A_{15}/D_{15}$ , $A_{16}/D_0-A_{23}/D_7$ | 0 | | 0.16 Vcc | V | | OH (peak) | High-level peak output current | Ao/MAo-A7/MA7, A8/D8-A15/D15, | | | | | | | | $A_{16}/D_0-A_{23}/D_7$ , $P4_3-P4_7$ , $P5_0-P5_7$ , | | | | | | | | P60-P67, P70-P77, P80-P87, | | | -10 | mΑ | | | | $P9_0-P9_7$ , $P10_0-P10_7$ , $\phi_1$ , $\overline{RESET_{OUT}}$ , | | | | | | | | ST0, ST1, ALE, BLE, BHE, R/W | | | | | | OH (avg) | High-level average output | Ao/MAo-A7/MA7, A8/D8-A15/D15, | | | | | | | current | $A_{16}/D_0-A_{23}/D_7$ , $P4_3-P4_7$ , $P5_0-P5_7$ , | | | | | | | | P60-P67, P70-P77, P80-P87, | | | -5 | mΑ | | | | $P9_0-P9_7$ , $P10_0-P10_7$ , $\phi_1$ , $RESET_{OUT}$ , | | | | | | | | ST0, ST1, ALE, BLE, BHE, R/W | | | | | | OL (peak) | Low-level peak output current | $A_0/MA_0-A_7/MA_7$ , $A_8/D_8-A_{15}/D_{15}$ , | | | | | | | | $A_{16}/D_0-A_{23}/D_7$ , $P4_3-P4_7$ , $P5_0-P5_7$ , | | | | | | | | P6 <sub>0</sub> –P6 <sub>7</sub> , P7 <sub>0</sub> –P7 <sub>7</sub> , P8 <sub>0</sub> –P8 <sub>7</sub> , | | | 10 | mΑ | | | | P90-P97, P100-P107, $\phi_1$ , RESETOUT, | | | | | | | | ST0, ST1, ALE, BLE, BHE, R/W | | | | | | OL (avg) | Low-level average | Ao/MAo-A7/MA7, A8/D8-A15/D15, | | | | | | | output current | $A_{16}/D_0-A_{23}/D_7$ , $P4_3-P4_7$ , $P5_0-P5_7$ , | | | | | | | | P6 <sub>0</sub> –P6 <sub>7</sub> , P7 <sub>0</sub> –P7 <sub>7</sub> , P8 <sub>0</sub> –P8 <sub>7</sub> , | | | 5 | mA | | | | $P9_0-P9_7$ , $P10_0-P10_7$ , $\phi_1$ , $RESET_{OUT}$ , | | | | | | | | ST0, ST1, ALE, BLE, BHE, R/W | | | | | | f(XIN) | External clock input freque | ency | | | 25 | MHz | Notes 1: Average output current is the average value of a 100 ms interval. <sup>2:</sup> The sum of $I_{OL(peak)}$ for P8, P9, A<sub>0</sub>/MA<sub>0</sub>-A<sub>7</sub>/MA<sub>7</sub>, A<sub>8</sub>/D<sub>8</sub>-A<sub>15</sub>/D<sub>15</sub>, A<sub>16</sub>/D<sub>0</sub>-A<sub>23</sub>/D<sub>7</sub>, ST0, ST1, ALE, BLE, BHE, and R/W must be 80 mA or less; the sum of $I_{OH(peak)}$ for P8, P9, A<sub>0</sub>/MA<sub>0</sub>-A<sub>7</sub>/MA<sub>7</sub>, A<sub>8</sub>/D<sub>8</sub>-A<sub>15</sub>/D<sub>15</sub>, A<sub>16</sub>/D<sub>0</sub>-A<sub>23</sub>/D<sub>7</sub>, ST0, ST1, ALE, BLE, BHE, and R/W must be 80 mA or less; the sum of $I_{OL(peak)}$ for P4, P5, P6, P7, P10, and $\phi_1$ must be 80 mA or less; the sum of $I_{OH(peak)}$ for P4, P5, P6, P7, P10, and $\phi_1$ must be 80 mA or less. # Appendix 11. Electrical characteristics | 0 | Danamatan | | T ( | Limits | | | 1.1 | |----------------------------------|---------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------|--------|------|------|------| | Symbol | | Parameter | Test conditions | Min. | Тур. | Max. | Unit | | Vон | High-level output voltage | A <sub>0</sub> /MA <sub>0</sub> –A <sub>7</sub> /MA <sub>7</sub> , A <sub>8</sub> /D <sub>8</sub> –A <sub>15</sub> /D <sub>15</sub> , A <sub>16</sub> /D <sub>0</sub> –A <sub>23</sub> /D <sub>7</sub> , P4 <sub>3</sub> –P4 <sub>7</sub> , P5 <sub>0</sub> –P5 <sub>7</sub> , P6 <sub>0</sub> –P6 <sub>7</sub> , P7 <sub>0</sub> –P7 <sub>7</sub> , P8 <sub>0</sub> –P8 <sub>7</sub> , P9 <sub>0</sub> –P9 <sub>7</sub> , P10 <sub>0</sub> –P10 <sub>7</sub> , φ <sub>1</sub> , RESET <sub>0UT</sub> , ST0, ST1, ALE, BLE, BHE, R/W | Iон = -10 mA | 3 | | | V | | Vон | High-level output voltage | A <sub>0</sub> /MA <sub>0</sub> –A <sub>7</sub> /MA <sub>7</sub> , A <sub>8</sub> /D <sub>8</sub> –A <sub>15</sub> /D <sub>15</sub> , A <sub>16</sub> /D <sub>0</sub> –A <sub>23</sub> /D <sub>7</sub> , MA <sub>8</sub> , MA <sub>9</sub> , RAS, CAS, $\phi_1$ , ST0, ST1, BLE, BHE, R/W | Ioн = -400 μA | 4.7 | | | V | | Vон | High-level output | ALE | Iон = −10 mA | 3.1 | | | | | | voltage | | $I_{OH} = -400 \ \mu A$ | 4.8 | | | V | | Vон | High-level output | Ē | $I_{OH} = -10 \text{ mA}$ | 3.4 | | | | | | voltage | | $I$ он = $-400 \mu A$ | 4.8 | | | V | | Vol | Low-level output voltage | A <sub>0</sub> /MA <sub>0</sub> –A <sub>7</sub> /MA <sub>7</sub> , A <sub>8</sub> /D <sub>8</sub> –A <sub>15</sub> /D <sub>15</sub> ,<br>A <sub>16</sub> /D <sub>0</sub> –A <sub>23</sub> /D <sub>7</sub> , P4 <sub>3</sub> –P4 <sub>7</sub> , P5 <sub>0</sub> –P5 <sub>7</sub> , P6 <sub>0</sub> –P6 <sub>7</sub> ,<br>P7 <sub>0</sub> –P7 <sub>7</sub> , P8 <sub>0</sub> –P8 <sub>7</sub> , P9 <sub>0</sub> –P9 <sub>7</sub> , P1 <sub>0</sub> <sub>0</sub> –P10 <sub>7</sub> , φ <sub>1</sub> ,<br>RESET <sub>0</sub> , ST0, ST1, ALE, BLE, BHE, R/W | loL = 10 mA | | | 2 | V | | Vol | Low-level output voltage | $\begin{array}{c} A_0/MA_0-A_7/MA_7,\ A_8/D_8-A_{15}/D_{15},\\ \underline{A_{16}/D_0-A_{23}/D_7,\ \underline{MA_8},\ MA_9,\ \overline{RAS},\ \overline{CAS},\ \phi_1,\ ST0,\ ST1,}\\ \overline{BLE,\ \overline{BHE},\ R/W} \end{array}$ | IoL = 2 mA | | | 0.45 | V | | $V_{OL}$ | Low-level output | ALE | IoL = 10 mA | | | 1.9 | V | | | voltage | | IoL = 2 mA | | | 0.43 | , v | | Vol | Low-level output | Ē | IoL = 10 mA | | | 1.6 | V | | | voltage | | IoL = 2 mA | | | 0.4 | | | V <sub>T+</sub> —V <sub>T-</sub> | Hysteresis | HOLD, RDY, TA2IN-TA4IN, TB0IN, TB1IN, INT0-INT2, ADTRG, CTS0, CTS1, CLK0, CLK1, DMAREQ0-DMAREQ3, TC | | 0.4 | | 1 | V | | V <sub>T+</sub> –V <sub>T-</sub> | Hysteresis | RESET | | 0.2 | | 0.5 | V | | | Hysteresis | Xin | | 0.1 | | 0.3 | V | | Іін | High-level input current | A <sub>8</sub> /D <sub>8</sub> -A <sub>15</sub> /D <sub>15</sub> , A <sub>16</sub> /D <sub>0</sub> -A <sub>23</sub> /D <sub>7</sub> , P4 <sub>3</sub> -P4 <sub>7</sub> , P5 <sub>0</sub> -P5 <sub>7</sub> , P6 <sub>0</sub> -P6 <sub>7</sub> , P7 <sub>0</sub> -P7 <sub>7</sub> , P8 <sub>0</sub> -P8 <sub>7</sub> , P9 <sub>0</sub> -P9 <sub>7</sub> , P1 <sub>0</sub> 0-P1 <sub>0</sub> 7, RDY, HOLD, BYTE, CNVss, X <sub>IN</sub> , RESET | V1 = 5 V | | | 5 | μΑ | | lil. | Low-level input current | $\begin{array}{c} A_8/D_8-A_{15}/D_{15},\ A_{16}/D_0-A_{23}/D_7,\ P4_3-P4_7,\ P5_0-P5_7,\\ \underline{P6_0-P6_7},\ P7_0-P7_7,\ P8_0-P8_7,\ P9_0-P9_7,\ P10_0-P10_7,\\ \overline{RDY},\ \overline{HOLD},\ BYTE,\ CNVss,\ X_{IN},\ \overline{RESET} \end{array}$ | V1 = 0 V | | | -5 | μΑ | | VRAM | RAM hold volta | age | When clock is stopped. | 2 | | | V | | Icc | Power source | current | f(X <sub>IN</sub> ) = 25 MHz (Square waveform) | | 27 | 54 | mA | | | | | Ta = 25 °C (when clock is stopped) | | | 1 | μΑ | | | | | Ta = 85 °C (when clock is stopped) | | | 20 | μΑ | ### A-D CONVERTER CHARACTERISTICS (Vcc = 5 V, Vss = 0 V, Ta = -20 to 85 °C, f(Xin) = 25 MHz, unless otherwise noted) | 0 | Danasastan | T | | I Imit | | | |---------|----------------------|-----------------|------|--------|-----------|------| | Symbol | Parameter | Test conditions | Min. | Тур. | Max. | Unit | | _ | Resolution | VREF = VCC | | | 8 | Bits | | _ | Absolute accuracy | VREF = VCC | | | ±3 | LSB | | RLADDER | Ladder resistance | Vref = Vcc | 2 | | 10 | kΩ | | tconv | Conversion time | | 9.12 | | | μs | | VREF | Reference voltage | | 2 | | Vcc | V | | VIA | Analog input voltage | | 0 | · | $V_{REF}$ | V | Internal peripheral devices' timing requirements ( $Vcc = 5 V \pm 10 \%$ , Vss = 0 V, Ta = -20 to 85 °C, $f(X_{IN}) = 25 \text{ MHz}$ , unless otherwise noted) **Note:** The limits depend on $f(X_{IN})$ . Table 3 lists calculation formulas for the limits. ### Timer A input (Count input in event counter mode) | Symbol | Parameter | | Limits | | |--------------------|------------------------------------|----|--------|------| | | | | Max. | Unit | | t <sub>c(TA)</sub> | TAjın input cycle time | 80 | | ns | | tw(TAH) | TAjın input high-level pulse width | 40 | | ns | | tw(TAL) | TAjın input low-level pulse width | 40 | | ns | ### Timer A input (Gating input in timer mode) | 0 | Parameter | | Limits | | |---------|-------------------------------------------|-----|--------|------| | Symbol | | | Max. | Unit | | tc(TA) | TAjıN input cycle time (Note) | 320 | | ns | | tw(TAH) | TAjıN input high-level pulse width (Note) | 160 | | ns | | tw(TAL) | TAjın input low-level pulse width (Note) | 160 | | ns | ### **Timer A input** (External trigger input in one-shot pulse mode) | O. mala al | Parameter | | Limits | | | |--------------------|------------------------------------|-----|--------|------|--| | Symbol | | | Max. | Unit | | | t <sub>c(TA)</sub> | TAjın input cycle time (Note) | 160 | | ns | | | tw(TAH) | TAjın input high-level pulse width | 80 | | ns | | | tw(TAL) | TAjın input low-level pulse width | 80 | | ns | | ### **Timer A input** (External trigger input in pulse width modulation mode) | Symbol | Development | | Limits | | |---------------------|------------------------------------|------|--------|------| | | Parameter | Min. | Max. | Unit | | $t_{\text{w(TAH)}}$ | TAjın input high-level pulse width | 80 | | ns | | tw(TAL) | TAjın input low-level pulse width | 80 | | ns | #### Timer A input (Up-down input in event counter mode) | Cumbal | Parameter | | Limits | | | |---------------------|-------------------------------------|------|--------|------|--| | Symbol | | | Max. | Unit | | | tc(UP) | TAjout input cycle time | 2000 | | ns | | | tw(UPH) | TAjout input high-level pulse width | 1000 | | ns | | | $t_{\text{w(UPL)}}$ | TAjout input low-level pulse width | 1000 | | ns | | | tsu(UP-TIN) | TAjout input setup time | 400 | | ns | | | th(TIN-UP) | TAjout input hold time | 400 | | ns | | ### Timer A input (Two-phase pulse input in event counter mode) | Cumbal | Parameter | Limits | | Unit | |-------------------|-------------------------|--------|------|-------| | Symbol | | Min. | Max. | Offic | | tc(TA) | TAjın input cycle time | 800 | | ns | | tsu(TAjIN-TAjOUT) | TAjın input setup time | 200 | | ns | | tsu(TAjout-TAjin) | TAjout input setup time | 200 | | ns | #### Internal peripheral devices - •Count input in event counter mode - •Gating input in timer mode - •External trigger input in one-shot pulse mode - •External trigger input in pulse width modulation mode TAjın input •Up-down input and count input in event counter mode •Two-phase pulse input in event counter mode Test conditions extstyle ext •Input timing voltage : V<sub>I</sub> = 1.0 V, V<sub>I</sub> = 4.0 V Timer B input (Count input in event counter mode) | Symbol | Description | Lin | 1.1.0.14 | | |--------------------|-------------------------------------------------------|------|----------|------| | Symbol | Parameter | Min. | Max. | Unit | | t <sub>c(TB)</sub> | TBjin input cycle time (one edge count) | 80 | | ns | | tw(TBH) | TBjiN input high-level pulse width (one edge count) | 40 | | ns | | tw(TBL) | TBjin input low-level pulse width (one edge count) | 40 | | ns | | tc(TB) | TBjin input cycle time (both edges count) | 160 | | ns | | tw(TBH) | TBjin input high-level pulse width (both edges count) | 80 | | ns | | tw(TBL) | TBjin input low-level pulse width (both edges count) | 80 | | ns | Timer B input (Pulse period measurement mode) | O. and b. o. l. | Davamatan | Lim | nits | Unit | |-------------------------------|-------------------------------------------|------|------|-------| | Symbol | Parameter | Min. | Max. | Offic | | $\mathbf{t}_{\mathtt{c}(TB)}$ | TBjin input cycle time (Note) | 320 | | ns | | tw(TBH) | TBjin input high-level pulse width (Note) | 160 | | ns | | tw(TBL) | TBjin input low-level pulse width (Note) | 160 | | ns | Timer B input (Pulse width measurement mode) | Cumbal | Donomotor | Limits | Unit | | |---------|-------------------------------------------------------|--------|------|-------| | Symbol | Parameter | Min. | Max. | Offic | | tc(TB) | TBjin input cycle time (Note) | 320 | | ns | | tw(TBH) | TBj <sub>IN</sub> input high-level pulse width (Note) | 160 | | ns | | tw(TBL) | TBjin input low-level pulse width (Note) | 160 | | ns | A-D trigger input | Courada a l | Deservator | Limits | | Unit | |-------------|--------------------------------------------------|--------|------|------| | Symbol | Parameter | Min. | Max. | Oill | | tc(AD) | ADTRG input cycle time (trigger enabled minimum) | 1000 | | ns | | tw(ADL) | ADTRG input low-level pulse width | 125 | - | ns | Serial I/O | Cumbal | Devenuelos | Lim | Limits | | |---------------------|-----------------------------------|------|--------|------| | Symbol | Parameter | Min. | Max. | Unit | | tc(CK) | CLKi input cycle time | 200 | | ns | | tw(CKH) | CLKi input high-level pulse width | 100 | | ns | | tw(CKL) | CLKi input low-level pulse width | 100 | | ns | | t <sub>d(C-Q)</sub> | TxDi output delay time | | 80 | ns | | th(C-Q) | TxDi hold time | 0 | | ns | | tsu(D-C) | RxDi input setup time | 20 | | ns | | th(C-D) | RxDi input hold time | 90 | | ns | External interrupt INTi input | 0 | Danamatan | Limits | | Unit | |---------------------|-----------------------------------|--------|------|-------| | Symbol | Parameter | Min. | Max. | Offic | | $t_{\text{w(INH)}}$ | INTi input high-level pulse width | 250 | | ns | | tw(INL) | INTi input low-level pulse width | 250 | | ns | ### Internal peripheral devices Test conditions •Vcc = 5 V ± 10 % •Input timing voltage : VIL = 1.0 V, VIH = 4.0 V •Output timing voltage : Vol = 0.8 V, Voh = 2.0 V ### Ready and Hold Timing requirements (Vcc = 5 V $\pm$ 10 %, Vss = 0 V, Ta = -20 to 85 °C, $f(X_{IN})$ = 25 MHz, unless otherwise noted) | | Б | Lin | nits | | |-------------------------------|-----------------------|------|------|------| | Symbol | Parameter | Min. | Max. | Unit | | $\mathbf{t}_{su(RDY-\phi_1)}$ | RDY input setup time | 55 | | ns | | $t_{su(HOLD-\phi_1)}$ | HOLD input setup time | 55 | | ns | | $\mathbf{t}_{h(\phi1-RDY)}$ | RDY input hold time | 0 | | ns | | $t_{h(\phi_1-HOLD)}$ | HOLD input hold time | 0 | | ns | Switching characteristics (Vcc = 5 V $\pm$ 10 %, Vss = 0 V, Ta = -20 to 85 °C, $f(X_{IN})$ = 25 MHz, unless otherwise noted) | Symbol | Parameter | Lin | Limits | | |------------|----------------------------|------|---------|------| | | i didilietei | Min. | n. Max. | Unit | | td(∮1−STi) | ST0, ST1 output delay time | | 40 | ns | Note: Figure 13 shows the test circuit. # Appendix 11. Electrical characteristics ### Ready function Test conditions $\bullet$ Vcc = 5 V ± 10 % •Input timing voltage : VIL = 1.0 V, VIH = 4.0 V •Output timing voltage: VoL = 0.8 V, VoH = 2.0 V #### •Hold function Test conditions •Vcc = 5 V ± 10 % •Input timing voltage : $V_{IL} = 1.0 \text{ V}$ , $V_{IH} = 4.0 \text{ V}$ •Output timing voltage : $V_{OL} = 0.8 \text{ V}$ , $V_{OH} = 2.0 \text{ V}$ Microprocessor mode: with no Wait **Note:** The limits depend on $f(X_{IN})$ . Table 4 lists calculation formulas for the limits. Timing requirements ( $Vcc = 5 \text{ V} \pm 10 \text{ %}$ , Vss = 0 V, Ta = -20 to 85 °C, $f(X_{IN}) = 25 \text{ MHz}$ , unless otherwise noted) | Symbol | Davamatar | Limits | Linit | | |-------------------|---------------------------------------------|--------|-------|------| | Symbol | Parameter | Min. | Max. | Unit | | tc | External clock input cycle time | 40 | | ns | | t <sub>w(H)</sub> | External clock input high-level pulse width | 15 | | ns | | t <sub>w(L)</sub> | External clock input low-level pulse width | 15 | | ns | | tr | External clock input rising time | | 8 | ns | | tf | External clock input falling time | | 8 | ns | | tsu(PiD-E) | Port Pi input setup time (i = 4-10) | 60 | | ns | | th(E-PiD) | Port Pi input hold time (i = 4-10) | 0 | | ns | Switching characteristics ( $Vcc = 5 V \pm 10 \%$ , Vss = 0 V, Ta = -20 to 85 °C, f(Xin) = 25 MHz, unless otherwise noted) | Symbol | Davamatar | Limits | | Unit | |--------------------------------|-----------------------------------------------------------------|--------|------|------| | Syllibol | Parameter | Min. | Max. | Unit | | td(E-PiQ) | Port Pi data output delay time (i = 4-10) | | 80 | ns | | td(AL-E) | Address low-order output delay time (Note) | 15 | | ns | | td(E-DHQ) | Data high-order output delay time (BYTE = "L") | | 35 | ns | | tpxz(E-DHZ) | Data high-order floating start delay time (BYTE = "L") | | 0 | ns | | td(AM-E) | Address middle-order output delay time (Note) | 15 | | ns | | td(AM-ALE) | Address middle-order output delay time (Note) | 5 | | ns | | td(E-DLQ) | Data low-order output delay time | | 35 | ns | | tpxz(E-DLZ) | Data low-order floating start delay time | | 0 | ns | | $t_{d(AH-E)}$ | Address high-order output delay time (Note) | 15 | | ns | | td(AH-ALE) | Address high-order output delay time (Note) | 5 | | ns | | td(ALE-E) | ALE output delay time | 4 | | ns | | tw(ALE) | ALE pulse width (Note) | 22 | | ns | | td(BHE-E) | BHE output delay time (Note) | 20 | | ns | | td(BLE-E) | BLE output delay time (Note) | 20 | | ns | | $t_{d(R/W-E)}$ | R/W output delay time (Note) | 20 | | ns | | $\mathbf{t}_{d(E-\phi_1)}$ | $\phi_1$ output delay time | 0 | 18 | ns | | th(E-AL) | Address low-order hold time (Note) | 18 | | ns | | $\mathbf{t}$ h(ALE-AM) | Address middle-order hold time (BYTE = "L") | 9 | | ns | | th(E-DHQ) | Data high-order hold time (BYTE = "L") (Note) | 18 | | ns | | $t_{\sf pzx(E-DHZ)}$ | Data high-order floating release delay time (BYTE = "L") (Note) | 20 | | ns | | th(E-AM) | Address middle-order hold time (BYTE = "H") (Note) | 18 | | ns | | th(ALE-AH) | Address high-order hold time | 9 | | ns | | $t_{h(E-DLQ)}$ | Data low-order hold time (Note) | 18 | | ns | | $t_{\text{pzx}(\text{E-DLZ})}$ | Data low-order floating release delay time (Note) | 20 | | ns | | th(E-BHE) | BHE hold time (Note) | 18 | | ns | | th(E-BLE) | BLE hold time (Note) | 18 | | ns | | $t_{h(E-R/W)}$ | R/W hold time (Note) | 18 | | ns | | tw(EL) | E pulse width (Note) | 55 | | ns | | tsu(A-DL) | Data low-order setup time after address stabilization (Note) | _ | 50 | ns | | tsu(ALE-DL) | Data low-order setup time after rising of ALE (Note) | | 55 | ns | | tsu(A-DH) | Data high-order setup time after address stabilization (Note) | | 50 | ns | | tsu(ALE-DH) | Data high-order setup time after rising of ALE (Note) | | 55 | ns | Note: Figure 13 shows the test circuit. #### Microprocessor mode: with no Wait #### <Write> tw(L) tw(H) f(XIN) td(E- 01) ⊬ tw(EL) Ē td(AL-E) th(E-AL) Address output A0-A7 Address th(E-AM) td(AM-E) Address output A8-A15 (BYTE = "H") Address td(AM-E)|◀ td(E-DHQ) th(E-DHQ) Address/Data output Address A8/D8-A15/D15 Data (BYTE = "L") th(ALE-AM) Data input D0-D15 td(AM-ALE) (BYTE = "L") → td(E-DLQ) th(E-DLQ) td(AH-E) Address/Data output Data Address A16/D0-A23/D7 Data input D0-D7 td(AH-ALE) th(ALE-AH) tw(ALE) td(ALE-E) ALE output td(BHE-E) th(E-BHE) BHE output th(E-BLE) ◀ td(BLE-E) ► **BLE** output td(R/W-E) th(E-R/W) R/W output td(E-PiQ) ← Port Pi output (i = 4-10) Test conditions (port Pi) - •Vcc = $5 V \pm 10 \%$ - •Input timing voltage : $V_{IL}$ = 1.0 V, $V_{IH}$ = 4.0 V •Output timing voltage : $V_{OL}$ = 0.8 V, $V_{OH}$ = 2.0 V Test conditions (except port Pi) - •Vcc = $5 V \pm 10 \%$ - •Output timing voltage : VoL = 0.8 V, VoH = 2.0 V •Data input : VIL = 0.8 V, VIH = 2.5 V #### Microprocessor mode: with no Wait #### <Read> Test conditions (port Pi) •Vcc = $5 V \pm 10\%$ •Input timing voltage : V<sub>IL</sub> = 1.0 V, V<sub>IH</sub> = 4.0 V •Output timing voltage : VoL = 0.8 V, VoH = 2.0 V Test conditions (except port Pi) - •Vcc = $5 V \pm 10 \%$ - •Output timing voltage : Vol = 0.8 V, Voh = 2.0 V - •Data input : V<sub>IL</sub> = 0.8 V, V<sub>IH</sub> = 2.5 V ### Appendix 11. Electrical characteristics Microprocessor mode: with Wait **Note:** The limits depend on $f(X_{IN})$ . Table 4 lists calculation formulas for the limits. Timing requirements ( $Vcc = 5 \text{ V} \pm 10 \text{ %}$ , Vss = 0 V, Ta = -20 to 85 °C, $f(X_{IN}) = 25 \text{ MHz}$ , unless otherwise noted) | Symbol | Description | Lim | 1.1:4 | | |-------------------|---------------------------------------------|------|-------|------| | Symbol | Parameter | Min. | Max. | Unit | | tc | External clock input cycle time | 40 | | ns | | t <sub>w(H)</sub> | External clock input high-level pulse width | 15 | | ns | | tw(L) | External clock input low-level pulse width | 15 | | ns | | tr | External clock input rising time | | 8 | ns | | <b>t</b> f | External clock input falling time | | 8 | ns | | tsu(PiD-E) | Port Pi input setup time (i = 4-10) | 60 | | ns | | th(E-PiD) | Port Pi input hold time (i = 4-10) | 0 | | ns | Switching characteristics ( $Vcc = 5 \text{ V} \pm 10 \text{ \%}$ , Vss = 0 V, Ta = -20 to 85 °C, $f(X_{IN}) = 25 \text{ MHz}$ , unless otherwise noted) | Symbol | bol Parameter | | nits | Unit | |----------------------------|-----------------------------------------------------------------|------|------|------| | | | Min. | Max. | Unit | | td(E-PiQ) | Port Pi data output delay time | | 80 | ns | | td(AL-E) | Address low-order output delay time (Note) | 15 | | ns | | td(E-DHQ) | Data high-order output delay time (BYTE = "L") | | 35 | ns | | t <sub>pxz(E-DHZ)</sub> | Data high-order floating start delay time (BYTE = "L") | | 0 | ns | | td(AM-E) | Address middle-order output delay time (Note) | 15 | | ns | | td(AM-ALE) | Address middle-order output delay time (Note) | 5 | | ns | | td(E-DLQ) | Data low-order output delay time | | 35 | ns | | $t_{pxz(E-DLZ)}$ | Data low-order floating start delay time | | 0 | ns | | $t_{\sf d(AH-E)}$ | Address high-order output delay time (Note) | 15 | | ns | | td(AH-ALE) | Address high-order output delay time (Note) | 5 | | ns | | td(ALE-E) | ALE output delay time | 4 | | ns | | tw(ALE) | ALE pulse width (Note) | 22 | | ns | | t <sub>d(BHE-E)</sub> | BHE output delay time (Note) | 20 | | ns | | td(BLE-E) | BLE output delay time (Note) | 20 | | ns | | t <sub>d(R/W-E)</sub> | R/W output delay time (Note) | 20 | | ns | | $\mathbf{t}_{d(E-\phi_1)}$ | $\phi_1$ output delay time | 0 | 18 | ns | | th(E-AL) | Address low-order hold time (Note) | 18 | | ns | | th(ALE-AM) | Address middle-order hold time (BYTE = "L") | 9 | | ns | | th(E-DHQ) | Data high-order hold time (BYTE = "L") (Note) | 18 | | ns | | tpzx(E-DHZ) | Data high-order floating release delay time (BYTE = "L") (Note) | 20 | | ns | | th(E-AM) | Address middle-order hold time (BYTE = "H") (Note) | 18 | | ns | | th(ALE-AH) | Address high-order hold time | 9 | | ns | | th(E-DLQ) | Data low-order hold time (Note) | 18 | | ns | | tpzx(E-DLZ) | Data low-order floating release delay time (Note) | 20 | | ns | | th(E-BHE) | BHE hold time (Note) | 18 | | ns | | th(E-BLE) | BLE hold time (Note) | 18 | | ns | | th(E-R/W) | R/W hold time (Note) | 18 | | ns | | tw(EL) | E pulse width (Note) | 135 | | ns | | tsu(A-DL) | Data low-order setup time after address stabilization (Note) | | 130 | ns | | tsu(ALE-DL) | Data low-order setup time after rising of ALE (Note) | | 135 | ns | | tsu(A-DH) | Data high-order setup time after address stabilization (Note) | | 130 | ns | | tsu(ALE-DH) | Data high-order setup time after rising of ALE (Note) | | 135 | ns | Note: Figure 13 shows the test circuit. #### Microprocessor mode: with Wait #### <Write> Test conditions (port Pi) - •Vcc = $5 V \pm 10 \%$ - •Input timing voltage : V<sub>I</sub>L = 1.0 V, V<sub>I</sub>H = 4.0 V - •Output timing voltage : Vol = 0.8 V, Voh = 2.0 V Test conditions (except port Pi) - •Vcc = $5 V \pm 10 \%$ - •Output timing voltage : Vol = 0.8 V, Voh = 2.0 V - •Data input : V<sub>IL</sub> = 0.8 V, V<sub>IH</sub> = 2.5 V #### Microprocessor mode: with Wait #### <Read> Test conditions (port Pi) •Vcc = 5 V ± 10 % •Input timing voltage : $V_{IL} = 1.0 \text{ V}$ , $V_{IH} = 4.0 \text{ V}$ •Output timing voltage: VoL = 0.8 V, VoH = 2.0 V Test conditions (except port Pi) •Vcc = 5 V ± 10 % $\bullet$ Output timing voltage : VoL = 0.8 V, VoH = 2.0 V •Data input : VIL = 0.8 V, VIH = 2.5 V **DRAM control switching characteristics** ( $Vcc = 5 V \pm 10 \%$ , Vss = 0 V, Ta = -20 to 85 °C, $f(X_{IN}) = 25$ MHz, unless otherwise noted) **Note:** The limits depend on $f(X_{IN})$ . Table 5 lists calculation formulas for the limits. ### Read | Cymahal | Develop | Lin | nits | 1 1 14 | |------------------------|--------------------------------------------------------------------|------|------|--------| | Symbol | Parameter | Min. | Max. | Unit | | tw(RASL) | RAS low-level pulse width (Note) | 120 | | ns | | tw(CASL) | CAS low-level pulse width (Note) | 92.5 | | ns | | tw(RASH) | CAS high-level pulse width (Note) | 60 | | ns | | td(RAS-CAS) | RAS-CAS delay time (Note) | 28 | | ns | | td(RA-RAS) | Row address delay time before RAS (Note) | 5 | | ns | | th(RAS-RA) | Row address hold time after RAS (Note) | 18 | | ns | | td(CA-CAS) | Column address delay time before CAS | 5 | | ns | | $t_{\text{h(CAS-CA)}}$ | Column address hold time after CAS (Note) | 100 | | ns | | td(R/W-RAS) | R/W delay time before RAS (Note) | 18 | | ns | | th(CAS-R/W) | $R/\overline{W}$ hold time after $\overline{CAS}$ (Note) | 18 | | ns | | td(E-CA) | Column address delay time after $\overline{E}$ 's low level (Note) | | 65 | ns | | td(E-RASL) | RAS delay time after E's low level | | 30 | ns | | td(E-CASL) | CAS delay time after E's low level (Note) | | 77.5 | ns | | td(E-RASH) | RAS delay time after E's high level | 0 | 20 | ns | | td(E-CASH) | CAS delay time after E's high level | 0 | 20 | ns | Note: Figure 13 shows the test circuit. ### Write | Symbol | Doromotor | Limits | | Linit | |------------------------|----------------------------------------------------------|--------|------|-------| | Symbol | Parameter | Min. | Max. | Unit | | tw(RASL) | RAS low-level pulse width (Note) | 120 | | ns | | tw(CASL) | CAS low-level pulse width (Note) | 55 | | ns | | tw(RASH) | CAS high-level pulse width (Note) | 60 | | ns | | td(RAS-CAS) | RAS-CAS delay time (Note) | 60 | | ns | | td(RA-RAS) | Row address delay time before RAS (Note) | 5 | | ns | | th(RAS-RA) | Row address hold time after RAS (Note) | 18 | | ns | | td(CA-CAS) | Column address delay time before CAS (Note) | 10 | | ns | | $t_{\text{h(CAS-CA)}}$ | Column address hold time afrer CAS (Note) | 60 | | ns | | td(R/W-RAS) | R/W delay time before RAS (Note) | 18 | | ns | | th(CAS-R/W) | $R/\overline{W}$ hold time after $\overline{CAS}$ (Note) | 18 | | ns | | td(E-RASL) | RAS delay time after E's low level | | 30 | ns | | td(E-CASL) | CAS delay time after E's low level (Note) | 80 | 115 | ns | | td(E-RASH) | RAS delay time after E's high level | 0 | 20 | ns | | td(E-CASH) | CAS delay time after E's high level | 0 | 20 | ns | Note: Figure 13 shows the test circuit. #### Refresh state | Cymbol | Down water | Limits | | 1.1.0.14 | |---------------------|----------------------------------|--------|------|----------| | Symbol | Parameter | Min. | Max. | Unit | | tw(RASL) | RAS low-level pulse width (Note) | 120 | | ns | | tw(CASL) | CAS low-level pulse width (Note) | 55 | | ns | | $t_{ t d(CAS-RAS)}$ | CAS-RAS delay time (Note) | 17.5 | | ns | | th(RAS-CAS) | CAS hold time after RAS (Note) | 17.5 | | ns | Note: Figure 13 shows the test circuit. #### At DRAM control Test conditions •Vcc = 5 V ± 10 % •Output timing voltage : Vol = 0.8 V, Voh = 2.0 V •D0–D15 input : VIL = 0.8 V, VIH = 2.5 V **DMAC switching characteristics** ( $V_{CC} = 5 \text{ V} \pm 10 \text{ %}$ , $V_{SS} = 0 \text{ V}$ , Ta = -20 to 85 °C, $f(X_{IN}) = 25 \text{ MHz}$ , unless otherwise noted) **Note:** The limits depend on $f(X_{IN})$ . Table 6 lists calculation formulas for the limits. | Cymbal | Б., | Lin | nits | I India | |------------------------------|-----------------------------------------------------------------|------|------|---------| | Symbol | Parameter | Min. | Max. | Unit | | tsu(DRQ-φ1) | DMAREQi input setup time | 60 | | ns | | tw(DRQ) | DMAREQi input pulse width | 80 | | ns | | $\mathbf{t}_{d(\phi_1-STi)}$ | ST0, ST1 output delay time | | 40 | ns | | $\mathbf{t}_{d(\phi_1-DAK)}$ | DMAACKi output delay time | | 60 | ns | | td(AL-E) | Address low-order output delay time (Note) | 15 | | ns | | td(E-DHQ) | Data high-order output delay time (BYTE = "L") | | 35 | ns | | tpxz(E-DHZ) | Data high-order floating start delay time (BYTE = "L") | | 0 | ns | | t <sub>d(AM-E)</sub> | Address middle-order output delay time (Note) | | | ns | | t <sub>d(E-DLQ)</sub> | Data low-order output delay time | | 35 | ns | | tpxz(E-DLZ) | Data low-order floating start delay time | | 0 | ns | | td(AH-E) | Address high-order output delay time (Note) | 15 | | ns | | t <sub>d(ALE-E)</sub> | ALE output delay time | 4 | | ns | | tw(ALE) | ALE pulse width (Note) | 22 | | ns | | td(BHE-E) | BHE output delay time (Note) | 20 | | ns | | td(BLE-E) | BLE output delay time (Note) | 20 | | ns | | t <sub>d(R/W-E)</sub> | R/W output delay time (Note) | 20 | | ns | | th(E-AL) | Address low-order hold time (Note) | 18 | | ns | | th(ALE-AM) | Address middle-order hold time (BYTE = "L") | 9 | | ns | | th(E-DHQ) | Data high-order hold time (BYTE = "L") (Note) | 18 | | ns | | t <sub>pzx(E-DHZ)</sub> | Data high-order floating release delay time (BYTE = "L") (Note) | 20 | | ns | | th(E-AM) | Address middle-order hold time (BYTE = "H") (Note) | 18 | | ns | | th(ALE-AH) | Address high-order hold time | 9 | | ns | | th(E-DLQ) | Data low-order hold time (Note) | 18 | | ns | | tpzx(E-DLZ) | Data low-order floating release delay time (Note) | 20 | | ns | | th(E-BHE) | BHE hold time (Note) | 18 | | ns | | th(E-BLE) | BLE hold time (Note) | 18 | | ns | | th(E-R/W) | R/W hold time (Note) | 18 | | ns | | tw(EL) | E pulse width (Note) | 55 | | ns | | t <sub>d(data)</sub> | Copy delay time | 50 | | ns | | <b>t</b> d( <i>ϕ</i> 1−TC) | TC output delay time | | 50 | ns | | tw(TC) | TC output pulse width (Note) | 50 | | ns | | tsu(TCIN) | TC input setup time | 60 | | ns | | tw(TCIN) | TC input pulse width | 80 | | ns | Note: Figures 13 and 14 show the test circuits. #### At DMA transfer ### •Burst transfer timing (External source DMAREQi) #### Test conditions •Vcc = 5 V ± 10 % •Output timing voltage : Vol = 0.8 V, Voh = 2.0 V•D0-D15 input : VIL = 0.8 V, VIH = 2.5 V •DMAREQi input: VIL = 0.8 V, VIH = 2.5 V #### At DMA transfer ### •Cycle-steal transfer timing (External source DMAREQi) ### Test conditions - $extstyle Vcc = 5 V \pm 10 \%$ - $\bullet$ Output timing voltage : VoL = 0.8 V, VoH = 2.0 V - •<u>D0</u>–<u>D15 input</u>: VIL = 0.8 V, VIH = 2.5 V - •DMAREQi input : VIL = 0.8 V, VIH = 2.5 V ### At DMA transfer •1-bus transfer timing Test conditions - •Vcc = 5 V ± 10 % - •Output timing voltage : Vol = 0.8 V, Voh = 2.0 V •D0–D15 input : VIL = 0.8 V, VIH = 2.5 V ### At DMA transfer ### •Transfer complete timing Test conditions - •Vcc = 5 V ± 10 % - •Output timing voltage : Vol = 0.8 V, Voh = 2.0 V - •D0-D15 input : VIL = 0.8 V, VIH = 2.5 V # When DMA transfer is forcedly completed by $\overline{TC}$ input $\overline{TC}$ input timing Test conditions •Vcc = 5 V ± 10 % •Output timing voltage : Vol = 0.8 V, Voh = 2.0 V •<u>D0</u>–D15 input : VIL = 0.8 V, VIH = 2.5 V •TC input : VIL = 0.8 V, VIH = 2.5 V Table 3 Calculation formulas for internal peripheral devices' input/output timing depending on $f(X_{IN})$ (Vcc = 5 V ± 10 %, Vss = 0 V, Ta = -20 to 85 °C) Timer A input (Gating input in timer mode) | Symbol | Calculation formula | Unit | |--------------------|--------------------------------------------|------| | t <sub>c(TA)</sub> | $\frac{8 \times 10^9}{f(X_{IN})}$ | ns | | tw(TAH) | $\frac{4 \times 10^9}{f(X_{IN})}$ | ns | | tw(TAL) | 4 X 10 <sup>9</sup><br>f(X <sub>IN</sub> ) | ns | ### Timer A input (External trigger input in one-shot pulse mode) | Symbol | Calculation formula | Unit | |--------------------|-----------------------------------|------| | t <sub>c(TA)</sub> | $\frac{4 \times 10^9}{f(X_{IN})}$ | ns | ### **Timer B input** (Pulse period measurement mode) | Symbol | Calculation formula | Unit | |--------------------|--------------------------------------------|------| | t <sub>c(TB)</sub> | 8 × 10 <sup>9</sup><br>f(X <sub>IN</sub> ) | ns | | tw(TBH) | 4 X 10 <sup>9</sup><br>f(X <sub>IN</sub> ) | ns | | tw(TBL) | 4 × 10°<br>f(X <sub>IN</sub> ) | ns | Timer B input (Pulse width measurement mode) | Symbol | Calculation formula | Unit | |--------------------|--------------------------------------------|------| | t <sub>c(TB)</sub> | 8 X 10 <sup>9</sup><br>f(X <sub>IN</sub> ) | ns | | <b>t</b> w(ТВН) | 4 × 10 <sup>9</sup><br>f(X <sub>IN</sub> ) | ns | | tw(TBL) | 4 X 10 <sup>9</sup> f(X <sub>IN</sub> ) | ns | ## Appendix 11. Electrical characteristics Table 4 Calculation formulas for bus timing depending on $f(X_N)$ (Vcc = 5 V ± 10 %, Vss = 0 V, Ta = -20 to 85 °C) | | (VCC = 5 V ± 10 % | , vss = 0 v, ra = -20 to | 85 C) | |----------------------------------|-------------------|----------------------------------------|-------| | | Symbol | Calculation formula | Unit | | td(AL-E)<br>td(AM-E)<br>td(AH-E) | | $\frac{1 \times 10^9}{f(X_{IN})} - 25$ | ns | | td(AM-ALE)<br>td(AH-ALE) | | $\frac{1 \times 10^9}{f(X_{IN})} - 35$ | ns | | tw(ALE) | | $\frac{1 \times 10^9}{f(X_{IN})} - 18$ | ns | | td(BLE-E) td(BHE-E) td(R/W-E) | | $\frac{1 \times 10^9}{f(X_{IN})} - 20$ | ns | | th(E-AL)<br>th(E-AM) | | $\frac{1 \times 10^9}{f(X_{IN})} - 22$ | ns | | th(E-DLQ) th(E-DHQ) | | $\frac{1 \times 10^9}{f(X_{IN})} - 22$ | ns | | tpzx(E-DLZ)<br>tpzx(E-DHZ) | | $\frac{1 \times 10^9}{f(X_{IN})} - 20$ | ns | | th(E-BLE) th(E-BHE) th(E-R/W) | | $\frac{1 \times 10^9}{f(X_{IN})} - 22$ | ns | | tw(EL) | Wait bit = "1" | $\frac{2 \times 10^9}{f(X_{IN})} - 25$ | ns | | | Wait bit = "0" | $\frac{4 \times 10^9}{f(X_{IN})} - 25$ | ns | | tsu(A-DL)<br>tsu(A-DH) | Wait bit = "1" | $\frac{3 \times 10^9}{f(X_{IN})} - 70$ | ns | | | Wait bit = "0" | $\frac{5 \times 10^9}{f(X_{IN})} - 70$ | ns | | tsu(ALE-DL)<br>tsu(ALE-DH) | Wait bit = "1" | $\frac{3 \times 10^9}{f(X_{IN})} - 65$ | ns | | | Wait bit = "0" | $\frac{5 \times 10^9}{f(X_{IN})} - 65$ | ns | Table 5 Calculation formulas for DRAM control bus timing depending of $f(X_{IN})$ (Vcc = 5 V ± 10 %, Vss = 0 V, Ta = -20 to 85 °C) #### Read | Symbol | Calculation formula | Unit | Symbol | Calculation formula | Unit | |-------------|------------------------------------------|------|-------------|------------------------------------------|------| | tw(RASL) | $\frac{4 \times 10^9}{f(X_{IN})} - 40$ | ns | th(CAS-CA) | $\frac{4\times10^9}{f(X_{IN})}-60$ | ns | | tw(CASL) | $\frac{3 \times 10^9}{f(X_{IN})} - 27.5$ | ns | td(R/W-RAS) | $\frac{1 \times 10^9}{f(X_{IN})} - 22$ | ns | | tw(RASH) | $\frac{2 \times 10^9}{f(X_{IN})} - 20$ | ns | th(CAS-R/W) | $\frac{1 \times 10^9}{f(X_{IN})} - 22$ | ns | | td(RAS-CAS) | $\frac{1 \times 10^9}{f(X_{IN})} - 12$ | ns | td(E-CA) | $\frac{1 \times 10^9}{f(X_{IN})} + 25$ | ns | | td(RA-RAS) | $\frac{1 \times 10^9}{f(X_{IN})} - 35$ | ns | td(E-CASL) | $\frac{1 \times 10^9}{f(X_{IN})} + 37.5$ | ns | | tn(RAS-RA) | $\frac{1 \times 10^9}{f(X_{IN})} - 22$ | ns | | | | #### Write | Symbol | Calculation formula | Unit | Symbol | Calculation formula | Unit | |-------------|----------------------------------------|------|-------------|---------------------------------------------|------| | tw(RASL) | $\frac{4 \times 10^9}{f(X_{IN})} - 40$ | ns | td(CA-CAS) | $\frac{1 \times 10^9}{f(X_{IN})} - 30$ | ns | | tw(CASL) | $\frac{2 \times 10^9}{f(X_{IN})} - 25$ | ns | th(CAS-CA) | $\frac{3 \times 10^9}{f(X_{IN})} - 60$ | ns | | tw(RASH) | $\frac{2 \times 10^9}{f(X_{IN})} - 20$ | ns | td(R/W-RAS) | $\frac{1 \times 10^9}{f(X_{IN})} - 22$ | ns | | td(RAS-CAS) | $\frac{2 \times 10^9}{f(X_{IN})} - 20$ | ns | th(CAS-R/W) | $\frac{1 \times 10^9}{f(X_{IN})} - 22$ | ns | | td(RA-RAS) | $\frac{1 \times 10^9}{f(X_{IN})} - 35$ | ns | td(E-CASL) | $\frac{2 \times 10^9}{f(X_{IN})} + 35(0)^*$ | ns | | th(RAS-RA) | $\frac{1 \times 10^9}{f(X_{IN})} - 22$ | ns | | | | <sup>\*</sup> The value within ( ) is for the minimum value. #### Refresh | Symbol | Calculation formula | Unit | Symbol | Calculation formula | Unit | |----------|----------------------------------------|------|-------------|------------------------------------------|------| | tw(RASL) | $\frac{4 \times 10^9}{f(X_{IN})} - 40$ | ns | td(CAS-RAS) | $\frac{1 \times 10^9}{f(X_{IN})} - 22.5$ | ns | | tw(CASL) | $\frac{2 \times 10^9}{f(X_{IN})} - 25$ | ns | th(RAS-CAS) | $\frac{1 \times 10^9}{f(X_{IN})} - 22.5$ | ns | ### Appendix 11. Electrical characteristics Table 6 Calculation formulas for DMA transfer bus timing depending on $f(X_{IN})$ (Vcc = 5 V $\pm$ 10 %, Vss = 0 V, Ta = -20 to 85 °C) | | Symbol | Calculation formula | Unit | |----------------------------------|-----------------------------------------------------|----------------------------------------|------| | td(AL-E)<br>td(AM-E)<br>td(AH-E) | | $\frac{1 \times 10^9}{f(X_{IN})} - 25$ | ns | | tw(ALE | ) | $\frac{1 \times 10^9}{f(X_{IN})} - 18$ | ns | | td(BLE-<br>td(BHE<br>td(R/W- | –E) | $\frac{1 \times 10^9}{f(X_{IN})} - 20$ | ns | | th(E-Al | L) | $\frac{1 \times 10^9}{f(X_{IN})} - 22$ | ns | | th(E-D | | $\frac{1 \times 10^9}{f(X_{IN})} - 22$ | ns | | t <sub>pzx(E</sub> - | | $\frac{1 \times 10^9}{f(X_{IN})} - 20$ | ns | | th(E-B) | HE) | $\frac{1 \times 10^9}{f(X_{IN})} - 22$ | ns | | tw(EL) | Transfer source/Transfer destination wait bit = "1" | $\frac{2 \times 10^9}{f(X_{IN})} - 25$ | ns | | | Transfer source/Transfer destination wait bit = "0" | $\frac{4 \times 10^9}{f(X_{IN})} - 25$ | ns | | tw(TC) | | $\frac{2 \times 10^9}{f(X_{IN})} - 30$ | ns | Fig. 13 Test circuit for each pin Fig. 14 Test circuit for TC output delay time and TC output pulse width ### Appendix 12. Standard characteristics Standard characteristics described below are just examples of the M37721S2BFP's characteristics and are not guaranteed. For each parameter's limits, refer to section "Appendix 11. Electrical characteristics." ### 1. Programmable I/O port (CMOS output) standard characteristics #### (1) P-channel Іон-Vон characteristics ### (2) N-channel IoL-VoL characteristics ### Appendix 12. Standard characteristics ### 2. Icc-f(X<sub>IN</sub>) standard characteristics ### (1) Icc-f(X<sub>IN</sub>) characteristics on operating and at reset Measurement condition (Vcc = 5.0 V, Ta = 25 °C, f(XIN): square waveform, microprocessor mode) ### (2) Wait mode Measurement condition (Vcc = 5.0 V, Ta = 25 °C, f(XIN) : square waveform, microprocessor mode) #### 3. A-D converter standard characteristics The lower lines of the graph indicate the absolute precision errors. These are expressed as the deviation from the ideal value when the output code changes. For example, the change in output code from 0 to 1 should occur at 10 mV, but the measured value is +2 mV. Accordingly, the measured point of change is 10 + 2 = 12 mV. The upper lines of the graph indicate the input voltage width for which the output code is constant. For example, the measured input voltage width for which the output code is 15 is 24 mV, so that the differential non-linear error is 24 - 20 = 4 mV (0.2 LSB). ### [Measurement conditions] •Vcc = 5 V, V<sub>REF</sub> = 5.12 V, $f(X_{IN})$ = 25 MHz, Ta = 25 °C, $\phi_{AD}$ = $f_2$ divided by 2 # Appendix 12. Standard characteristics **MEMORANDUM** # **GLOSSARY** This section briefly explains the terms used in this user's manual. The terms defined here apply to this manual only. | Term | Meaning | Relevant term | |----------------------------|-----------------------------------------------------------------------------|---------------| | Access | Means performing read, write, or read and write. | | | | In DRAMC, also means performing DRAM refresh. | | | Access space | An accessible memory space of up to 16 Mbytes. | Access | | Access characteristics | Means whether accessible or not. | Access | | Branch | Means moving the program's execution point (= address) to another location. | | | Bus control signal | A generic name for ALE, E, R/W, BLE, BHE, RDY, HOLD, HLDA, | | | | BYTE, ST0, and ST1 signals. | | | Countdown | Means decreasing by 1 and counting. | Countup | | Count source | A signal that is counted by timers A and B, the UARTi baud rate | | | | register (BRGi) and the watchdog timer. That is f2, f16, f64, f512 | | | | selected by the count source select bits and others. | | | Countup | Means increasing by 1 and counting. | Countdown | | External area | An accessible area for external devices connected. It is up to 16- | Internal area | | | Mbyte external area. | | | External bus | A generic name for the external address bus and the external | | | | data bus. | | | External device | Devices connected externally to the microcomputer. A generic | | | | name for a memory, an I/O device and a peripheral IC. | | | Internal area | An accessible internal area. A generic name for areas of the | External area | | | internal RAM and the SFR. | | | Interrupt routine | A routine that is automatically executed when an interrupt request | | | | is accepted. Set the start address of this routine into the interrupt | | | | vector table. | | | Overflow | A state where the countup resultant is greater than the counter | Underflow | | | resolution. | Countup | | Read-modify-write | An instruction that reads the memory contents, modifies them | | | instruction | and writes back to the same address. Relevant instructions are | | | | the ASL, ASR, CLB, DEC, INC, LSR, ROL, ROR, SEB instructions. | | | Signal required for access | A generic name for bus control, address bus, and data bus signals. | Bus control | | to external device | | signal | | Stop mode | A state where the oscillation circuit halts and the program execution | Wait mode | | | is stopped. By executing the STP instruction, the microcomputer | | | | enters the stop mode. | | | UART | Clock asynchronous serial I/O. When used to designate the name | Clock | | | of a functional block, this term also means the serial I/O which | synchronous | | | can be switched to the cock synchronous serial I/O. | serial I/O | | Underflow | A state where the countdown resultant is greater than the counter | Overflow | | | resolution. | Countdown | | Wait mode | A state where the oscillation circuit is operating, however, the | Stop mode | | | program execution is stopped. By executing the WIT instruction, | | | | the microcomputer enters the wait mode. | | ### MITSUBISHI SEMICONDUCTORS USER'S MANUAL 7721 Group Sep. First Edition 1997 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. ©1997 MITSUBISHI ELECTRIC CORPORATION # User's Manual 7721 Group