### Old Company Name in Catalogs and Other Documents

On April 1<sup>st</sup>, 2010, NEC Electronics Corporation merged with Renesas Technology Corporation, and Renesas Electronics Corporation took over all the business of both companies. Therefore, although the old company name remains in this document, it is a valid Renesas Electronics document. We appreciate your understanding.

Renesas Electronics website: http://www.renesas.com

April 1<sup>st</sup>, 2010 Renesas Electronics Corporation

Issued by: Renesas Electronics Corporation (http://www.renesas.com)

Send any inquiries to http://www.renesas.com/inquiry.

#### Notice

- 1. All information included in this document is current as of the date this document is issued. Such information, however, is subject to change without any prior notice. Before purchasing or using any Renesas Electronics products listed herein, please confirm the latest product information with a Renesas Electronics sales office. Also, please pay regular and careful attention to additional and different information to be disclosed by Renesas Electronics such as that disclosed through our website.
- Renesas Electronics does not assume any liability for infringement of patents, copyrights, or other intellectual property rights of third parties by or arising from the use of Renesas Electronics products or technical information described in this document. No license, express, implied or otherwise, is granted hereby under any patents, copyrights or other intellectual property rights of Renesas Electronics or others.
- 3. You should not alter, modify, copy, or otherwise misappropriate any Renesas Electronics product, whether in whole or in part.
- 4. Descriptions of circuits, software and other related information in this document are provided only to illustrate the operation of semiconductor products and application examples. You are fully responsible for the incorporation of these circuits, software, and information in the design of your equipment. Renesas Electronics assumes no responsibility for any losses incurred by you or third parties arising from the use of these circuits, software, or information.
- 5. When exporting the products or technology described in this document, you should comply with the applicable export control laws and regulations and follow the procedures required by such laws and regulations. You should not use Renesas Electronics products or the technology described in this document for any purpose relating to military applications or use by the military, including but not limited to the development of weapons of mass destruction. Renesas Electronics products and technology may not be used for or incorporated into any products or systems whose manufacture, use, or sale is prohibited under any applicable domestic or foreign laws or regulations.
- 6. Renesas Electronics has used reasonable care in preparing the information included in this document, but Renesas Electronics does not warrant that such information is error free. Renesas Electronics assumes no liability whatsoever for any damages incurred by you resulting from errors in or omissions from the information included herein.
- 7. Renesas Electronics products are classified according to the following three quality grades: "Standard", "High Quality", and "Specific". The recommended applications for each Renesas Electronics product depends on the product's quality grade, as indicated below. You must check the quality grade of each Renesas Electronics product before using it in a particular application. You may not use any Renesas Electronics product for any application categorized as "Specific" without the prior written consent of Renesas Electronics. Further, you may not use any Renesas Electronics. Renesas Electronics shall not be in any way liable for any damages or losses incurred by you or third parties arising from the use of any Renesas Electronics product for an application categorized as "Specific" or for which the product is not intended where you have failed to obtain the prior written consent of Renesas Electronics. The quality grade of each Renesas Electronics product is "Standard" unless otherwise expressly specified in a Renesas Electronics data sheets or data books, etc.
  - "Standard": Computers; office equipment; communications equipment; test and measurement equipment; audio and visual equipment; home electronic appliances; machine tools; personal electronic equipment; and industrial robots.
  - "High Quality": Transportation equipment (automobiles, trains, ships, etc.); traffic control systems; anti-disaster systems; anticrime systems; safety equipment; and medical equipment not specifically designed for life support.
  - "Specific": Aircraft; aerospace equipment; submersible repeaters; nuclear reactor control systems; medical equipment or systems for life support (e.g. artificial life support devices or systems), surgical implantations, or healthcare intervention (e.g. excision, etc.), and any other applications or purposes that pose a direct threat to human life.
- 8. You should use the Renesas Electronics products described in this document within the range specified by Renesas Electronics, especially with respect to the maximum rating, operating supply voltage range, movement power voltage range, heat radiation characteristics, installation and other product characteristics. Renesas Electronics shall have no liability for malfunctions or damages arising out of the use of Renesas Electronics products beyond such specified ranges.
- 9. Although Renesas Electronics endeavors to improve the quality and reliability of its products, semiconductor products have specific characteristics such as the occurrence of failure at a certain rate and malfunctions under certain use conditions. Further, Renesas Electronics products are not subject to radiation resistance design. Please be sure to implement safety measures to guard them against the possibility of physical injury, and injury or damage caused by fire in the event of the failure of a Renesas Electronics product, such as safety design for hardware and software including but not limited to redundancy, fire control and malfunction prevention, appropriate treatment for aging degradation or any other appropriate measures. Because the evaluation of microcomputer software alone is very difficult, please evaluate the safety of the final products or system manufactured by you.
- 10. Please contact a Renesas Electronics sales office for details as to environmental matters such as the environmental compatibility of each Renesas Electronics product. Please use Renesas Electronics products in compliance with all applicable laws and regulations that regulate the inclusion or use of controlled substances, including without limitation, the EU RoHS Directive. Renesas Electronics assumes no liability for damages or losses occurring as a result of your noncompliance with applicable laws and regulations.
- 11. This document may not be reproduced or duplicated, in any form, in whole or in part, without prior written consent of Renesas Electronics.
- 12. Please contact a Renesas Electronics sales office if you have any questions regarding the information contained in this document or Renesas Electronics products, or if you have any other inquiries.
- (Note 1) "Renesas Electronics" as used in this document means Renesas Electronics Corporation and also includes its majorityowned subsidiaries.
- (Note 2) "Renesas Electronics product(s)" means any product developed or manufactured by or for Renesas Electronics.

### RENESAS

**User's Manual** 

# Phase-out/Discontinued

### V821<sup>™</sup>

32-/16-Bit Microprocessor

Hardware

 $\mu$ **PD70741** 

Document No. U10077EJ5V0UM00 (5th edition) Date Published February 1999 J CP(K)

© NEC Corporation 1995 Printed in Japan



[MEMO]



### SUMMARY OF CONTENTS

| CHAPTER 1  | OVERVIEW                                       | 23  |
|------------|------------------------------------------------|-----|
| CHAPTER 2  | PIN FUNCTIONS                                  | 31  |
| CHAPTER 3  | CPU FUNCTIONS                                  | 45  |
| CHAPTER 4  | INTERRUPT/EXCEPTION HANDLING FUNCTIONS         | 55  |
| CHAPTER 5  | BUS CONTROL FUNCTION                           | 75  |
| CHAPTER 6  | WAIT CONTROL FUNCITONS                         | 109 |
| CHAPTER 7  | MEMORY ACCESS CONTROL FUNCTIONS                | 119 |
| CHAPTER 8  | DMA FUNCTIONS (DMA CONTROLLER)                 | 139 |
| CHAPTER 9  | SERIAL INTERFACE FUNCTION                      | 155 |
| CHAPTER 10 | TIMER/COUNTER FUNCTIONS (REAL-TIME PULSE UNIT) | 183 |
| CHAPTER 11 | WATCHDOG TIMER FUNCTIONS                       | 213 |
| CHAPTER 12 | PORT FUNCTIONS                                 | 217 |
| CHAPTER 13 | CLOCK GENERATION FUNCTIONS                     | 221 |
| CHAPTER 14 | STANDBY FUNCTIONS                              | 225 |
| CHAPTER 15 | RESET FUNCTIONS                                | 237 |
| APPENDIX A | REGISTER INDEX                                 | 243 |
| APPENDIX B | GENERAL INDEX                                  | 247 |

### NOTES FOR CMOS DEVICES -

### **①** PRECAUTION AGAINST ESD FOR SEMICONDUCTORS

#### Note:

Strong electric field, when exposed to a MOS device, can cause destruction of the gate oxide and ultimately degrade the device operation. Steps must be taken to stop generation of static electricity as much as possible, and quickly dissipate it once, when it has occurred. Environmental control must be adequate. When it is dry, humidifier should be used. It is recommended to avoid using insulators that easily build static electricity. Semiconductor devices must be stored and transported in an anti-static container, static shielding bag or conductive material. All test and measurement tools including work bench and floor should be grounded. The operator should be grounded using wrist strap. Semiconductor devices must not be touched with bare hands. Similar precautions need to be taken for PW boards with semiconductor devices on it.

### **②** HANDLING OF UNUSED INPUT PINS FOR CMOS

Note:

No connection for CMOS device inputs can be cause of malfunction. If no connection is provided to the input pins, it is possible that an internal input level may be generated due to noise, etc., hence causing malfunction. CMOS devices behave differently than Bipolar or NMOS devices. Input levels of CMOS devices must be fixed high or low by using a pull-up or pull-down circuitry. Each unused pin should be connected to VDD or GND with a resistor, if it is considered to have a possibility of being an output pin. All handling related to the unused pins must be judged device by device and related specifications governing the devices.

#### **③** STATUS BEFORE INITIALIZATION OF MOS DEVICES

Note:

Power-on does not necessarily define initial status of MOS device. Production process of MOS does not define the initial operation status of the device. Immediately after the power source is turned ON, the devices with reset function have not yet been initialized. Hence, power-on does not guarantee out-pin levels, I/O settings or contents of registers. Device is not initialized until the reset signal is received. Reset operation must be executed immediately after power-on for devices having reset function.

V821 Family and V810 Family are trademarks of NEC Corporation.

UNIX is a registered trademark licensed by X/Open Company Limited in the US and other countries. Windows is either a registered trademark or a trademark of Microsoft Corporation in the United States and/or other countries.

The application circuits and their parameters are for reference only and are not intended for use in actual design-ins.

#### The information in this document is subject to change without notice.

No part of this document may be copied or reproduced in any form or by any means without the prior written consent of NEC Corporation. NEC Corporation assumes no responsibility for any errors which may appear in this document.

NEC Corporation does not assume any liability for infringement of patents, copyrights or other intellectual property rights of third parties by or arising from use of a device described herein or any other liability arising from use of such device. No license, either express, implied or otherwise, is granted under any patents, copyrights or other intellectual property rights of NEC Corporation or others.

While NEC Corporation has been making continuous effort to enhance the reliability of its semiconductor devices, the possibility of defects cannot be eliminated entirely. To minimize risks of damage or injury to persons or property arising from a defect in an NEC semiconductor device, customers must incorporate sufficient safety measures in its design, such as redundancy, fire-containment, and anti-failure features.

NEC devices are classified into the following three quality grades:

"Standard", "Special", and "Specific". The Specific quality grade applies only to devices developed based on a customer designated "quality assurance program" for a specific application. The recommended applications of a device depend on its quality grade, as indicated below. Customers must check the quality grade of each device before using it in a particular application.

- Standard: Computers, office equipment, communications equipment, test and measurement equipment, audio and visual equipment, home electronic appliances, machine tools, personal electronic equipment and industrial robots
- Special: Transportation equipment (automobiles, trains, ships, etc.), traffic control systems, anti-disaster systems, anti-crime systems, safety equipment and medical equipment (not specifically designed for life support)
- Specific: Aircrafts, aerospace equipment, submersible repeaters, nuclear reactor control systems, life support systems or medical equipment for life support, etc.

The quality grade of NEC devices is "Standard" unless otherwise specified in NEC's Data Sheets or Data Books. If customers intend to use NEC devices for applications other than those specified for Standard quality grade, they should contact an NEC sales representative in advance.

Anti-radioactive design is not implemented in this product.



### **Regional Information**

Some information contained in this document may vary from country to country. Before using any NEC product in your application, please contact the NEC office in your country to obtain a list of authorized representatives and distributors. They will verify:

- · Device availability
- · Ordering information
- Product release schedule
- · Availability of related technical literature
- Development environment specifications (for example, specifications for third-party tools and components, host computers, power plugs, AC supply voltages, and so forth)
- Network requirements

In addition, trademarks, registered trademarks, export restrictions, and other legal issues may also vary from country to country.

#### **NEC Electronics Inc. (U.S.)**

Santa Clara, California Tel: 408-588-6000 800-366-9782 Fax: 408-588-6130 800-729-9288

#### **NEC Electronics (Germany) GmbH**

Duesseldorf, Germany Tel: 0211-65 03 02 Fax: 0211-65 03 490

#### NEC Electronics (UK) Ltd.

Milton Keynes, UK Tel: 01908-691-133 Fax: 01908-670-290

### NEC Electronics Italiana s.r.l.

Milano, Italy Tel: 02-66 75 41 Fax: 02-66 75 42 99 NEC Electronics (Germany) GmbH Benelux Office Eindhoven, The Netherlands Tel: 040-2445845 Fax: 040-2444580

### NEC Electronics (France) S.A.

Velizy-Villacoublay, France Tel: 01-30-67 58 00 Fax: 01-30-67 58 99

#### NEC Electronics (France) S.A.

Spain Office Madrid, Spain Tel: 01-504-2787 Fax: 01-504-2860

#### NEC Electronics (Germany) GmbH Scandinavia Office

Taeby, Sweden Tel: 08-63 80 820 Fax: 08-63 80 388 NEC Electronics Hong Kong Ltd. Hong Kong Tel: 2886-9318 Fax: 2886-9022/9044

NEC Electronics Hong Kong Ltd. Seoul Branch Seoul, Korea Tel: 02-528-0303 Fax: 02-528-4411

NEC Electronics Singapore Pte. Ltd. United Square, Singapore 1130 Tel: 65-253-8311 Fax: 65-250-3583

NEC Electronics Taiwan Ltd. Taipei, Taiwan Tel: 02-2719-2377 Fax: 02-2719-5951

#### NEC do Brasil S.A.

Electron Devices Division Rodovia Presidente Dutra, Km 214 07210-902-Guarulhos-SP Brasil Tel: 55-11-6465-6810 Fax: 55-11-6465-6829

J98. 11

### **Major Changes**

| Page   | Description                                                                    |
|--------|--------------------------------------------------------------------------------|
| P. 24  | The μPD70741GC-25-7EA has been deleted from Section 1.2.                       |
| P. 25  | The μPD70741GC-25-7EA has been deleted from Section 1.3.                       |
| P. 27  | Section 1.4.1 has been modified.                                               |
| P. 123 | The description has been added to Section 7.1.5.                               |
| P. 151 | Figure 8-9 has been modified.                                                  |
| P. 221 | The clock generation function block diagram in Section 13.2 has been modified. |
| P. 223 | The description has been added to Section 13.3.2 (2).                          |
| P. 231 | The description has been added to Section 14.5.1.                              |

The mark  $\star$  shows major revised points.



[MEMO]

### PREFACE

| Intended readers      | : This manual is aimed at those users who wish to become familiar with the functions of the V821 ( $\mu$ PD70741), and those involved in designing systems based on the V821.                                                                                                                                                                                                                                                                                                                                             |
|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Purpose               | : The purpose of this manual is to assist users in understanding the hardware functions of the V821, as listed in "Configuration" below.                                                                                                                                                                                                                                                                                                                                                                                  |
| Configuration         | : The V821 User's Manual is provided as two volumes, Hardware (this manual)<br>and Architecture (V810 Family <sup>TM</sup> User's Manual, Architecture).                                                                                                                                                                                                                                                                                                                                                                  |
|                       | <ul> <li>Pin functions</li> <li>CPU functions</li> <li>Interrupt functions</li> <li>Bus control functions</li> <li>Built-in peripheral functions</li> <li>Reset functions</li> </ul> |
| How to use this manua | <ol> <li>Readers are assumed to be familiar with electronics, logic circuits, and micro-<br/>computers.</li> </ol>                                                                                                                                                                                                                                                                                                                                                                                                        |
|                       | For an explanation of the CPU functions -> Read <b>Chapter 3</b> .                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                       | <ul> <li>For an explanation of the instructions</li> <li>-&gt; Refer to the V810 Family User's Manual, Architecture (the companion volume to this manual).</li> </ul>                                                                                                                                                                                                                                                                                                                                                     |
|                       | To gain an overall understanding of the functions of the V821<br>-> Read this manual in its entirety.                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                       | To know the electrical characteristics<br>-> Refer to the <b>V821 Data Sheet</b> provided separately.                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                       | In this manual, 2-byte data is referred to as halfword data, while 4-byte data is referred to as word data.                                                                                                                                                                                                                                                                                                                                                                                                               |



| Legend | : Significance of data represent | ation : Left high, right low                                                                       |
|--------|----------------------------------|----------------------------------------------------------------------------------------------------|
|        | Representation of active low     | : xxx [bar above a pin or signal name)                                                             |
|        | Memory map address               | : Top upper, bottom lower                                                                          |
|        | Note                             | : Explanation of Note marked in text                                                               |
|        | Caution                          | : Note to which particular attention must be afforded                                              |
|        | Remark                           | : Supplementary explanation of text                                                                |
|        | Representation of numbers        | : xxxx or xxxxB for a binary number<br>xxxx for a decimal number<br>xxxxH for a hexadecimal number |
|        | Prefixes indicating powers of t  | two (address space, memory capacity):                                                              |
|        | K (kilo)                         | : 2 <sup>10</sup> = 1,024                                                                          |
|        | M (mega)                         | $2^{20} = 1,024^2$                                                                                 |
|        | G (giga)                         | $2^{30} = 1,024^3$                                                                                 |
|        |                                  |                                                                                                    |

**Related document** : Some related documents may be preliminary editions; Note, however, that whether a related document is preliminary is not indicated in this manual.

### ○ Documents related to devices

| Document name                           | Document number |
|-----------------------------------------|-----------------|
| V821 User's Manual, Hardware            | This manual     |
| V810 Family User's Manual, Architecture | U10082E         |
| μPD70741 Data Sheet                     | U11678E         |

### • Documents related to development tools (user's manual)

| Docur                | Document number                          |         |
|----------------------|------------------------------------------|---------|
| CA732 (C compiler)   | Operation (UNIX <sup>TM</sup> -based)    | U11013E |
|                      | Operation (Windows <sup>TM</sup> -based) | U11068E |
|                      | Assembly language                        | U11016E |
|                      | С                                        | U11010E |
|                      | Project manager                          | U11991E |
| RX732 (Real-time OS) | Basic                                    | U10346E |
|                      | Technical                                | U10490E |
|                      | Nucleus installation                     | U10347E |

### CONTENTS

| CHAPTER 1 | OVERVIEW |                                                   |    |
|-----------|----------|---------------------------------------------------|----|
|           | 1.1      | FEATURES                                          | 23 |
|           | 1.2      | ORDERING INFORMATION                              | 24 |
|           | 1.3      | PIN CONFIGURATION (TOP VIEW)                      | 25 |
|           | 1.4      | FUNCTIONAL BLOCK CONFIGURATION                    | 27 |
|           |          | 1.4.1 Internal Block Diagram                      | 27 |
|           |          | 1.4.2 Internal Units                              | 28 |
| CHAPTER 2 | PIN      | UNCTIONS                                          | 31 |
|           | 2.1      | PIN FUNCTIONS                                     | 31 |
|           |          | 2.1.1 Port Pins                                   | 31 |
|           |          | 2.1.2 Non-Port Pins                               | 32 |
|           | 2.2      | PIN STATES                                        | 34 |
|           | 2.3      | PIN FUNCTIONS                                     | 35 |
|           |          | 2.3.1 Address Bus                                 | 35 |
|           |          | 2.3.2 Data Bus                                    | 35 |
|           |          | 2.3.3 Bus Control Signals                         | 35 |
|           |          | 2.3.4 System Control Signals                      | 37 |
|           |          | 2.3.5 Interrupt Control Signals                   | 38 |
|           |          | 2.3.6 DRAM Control Signals                        | 38 |
|           |          | 2.3.7 DMA Control Signals                         | 39 |
|           |          | 2.3.8 Real-Time Pulse Control Signals             | 40 |
|           |          | 2.3.9 Serial Control Signals                      | 40 |
|           |          | 2.3.10 Watchdog Timer Control Signal              | 41 |
|           |          | 2.3.11 Port Control Signal                        | 41 |
|           | 2.4      | PIN I/O CIRCUITS AND PROCESSING OF UNUSED PINS    | 42 |
|           | 2.5      | PIN I/O CIRCUITS                                  | 43 |
| CHAPTER 3 | CPU      | FUNCTIONS                                         | 45 |
|           | 3.1      | FEATURES                                          | 45 |
|           | 3.2      | ADDRESS SPACE                                     | 45 |
|           |          | 3.2.1 Memory Map                                  | 46 |
|           |          | 3.2.2 I/O Map                                     | 47 |
|           |          | 3.2.3 Images                                      | 47 |
|           |          | 3.2.4 Differences between the Memory and I/O Maps | 48 |
|           | 3.3      | CPU REGISTER SET                                  | 49 |
|           |          | 3.3.1 Program Register Set                        | 50 |

|           |      | 3.3.2 System Register Set                                         | 51 |  |  |
|-----------|------|-------------------------------------------------------------------|----|--|--|
|           | 3.4  | BUILT-IN PERIPHERAL I/O REGISTERS                                 | 52 |  |  |
| CHAPTER 4 | INTE | ERRUPT/EXCEPTION HANDLING FUNCTIONS                               | 55 |  |  |
|           | 4.1  | FEATURES                                                          | 55 |  |  |
|           | 4.2  | NONMASKABLE INTERRUPTS                                            | 58 |  |  |
|           |      | 4.2.1 Operation                                                   | 58 |  |  |
|           | 4.3  | MASKABLE INTERRUPTS                                               | 60 |  |  |
|           |      | 4.3.1 Block Diagram                                               | 60 |  |  |
|           |      | 4.3.2 Operation                                                   | 61 |  |  |
|           |      | 4.3.3 Maskable Interrupt Priority                                 | 63 |  |  |
|           | 4.4  | CONTROL REGISTERS                                                 | 64 |  |  |
|           |      | 4.4.1 Interrupt Group Priority Register (IGP)                     | 64 |  |  |
|           |      | 4.4.2 Interrupt Clear Register (ICR)                              | 66 |  |  |
|           |      | 4.4.3 Interrupt Request Register (IRR)                            | 66 |  |  |
|           |      | 4.4.4 Interrupt Request Mask Register (IMR)                       | 67 |  |  |
|           |      | 4.4.5 ICU Mode Register (IMOD)                                    | 68 |  |  |
|           | 4.5  | EXCEPTION HANDLING (SOFTWARE EXCEPTION AND EXCEPTION              |    |  |  |
|           |      | TRAP)                                                             | 69 |  |  |
|           |      | 4.5.1 Operation                                                   | 70 |  |  |
|           |      | 4.5.2 Return from an Exception or Interrupt                       | 72 |  |  |
|           | 4.6  | PRIORITY CONTROL                                                  | 73 |  |  |
|           |      | 4.6.1 Priorities of Interrupts and Exceptions                     | 73 |  |  |
|           |      | 4.6.2 Priorities of Floating-Point Exceptions                     | 74 |  |  |
| CHAPTER 5 | BUS  | CONTROL FUNCTION                                                  | 75 |  |  |
|           | 5.1  | CPU BUS STATES                                                    | 75 |  |  |
|           | 5.2  | DMAC BUS STATE                                                    | 77 |  |  |
|           | 5.3  | BUS PRIORITY                                                      | 80 |  |  |
|           | 5.4  | DATA FLOW WHEN USING AN ADDITIONAL BUS CYCLE                      |    |  |  |
|           | 5.5  | RELATIONSHIP BETWEEN EXTERNAL ACCESSES AND THE DATA BUS           | 82 |  |  |
|           |      | 5.5.1 Relationship between External Access and Byte Enable Signal | 82 |  |  |
|           |      | 5.5.2 Operand Read                                                | 83 |  |  |
|           |      | 5.5.3 Operand Write                                               | 84 |  |  |
|           |      | 5.5.4 Notes on Bit Strings                                        | 85 |  |  |
|           | 5.6  | EXTERNAL I/O ACCESS                                               | 86 |  |  |
|           |      | 5.6.1 External I/O Read Cycle                                     | 86 |  |  |
|           |      | 5.6.2 External I/O Write Cycle                                    | 87 |  |  |
|           | 5.7  | INTERNAL I/O ACCESS                                               | 88 |  |  |
|           |      | 5.7.1 Internal I/O Read Cycle                                     | 88 |  |  |

|           |                   | 5.7.2                                    | Internal I/O Write Cycle                                                                                 | 89                                            |
|-----------|-------------------|------------------------------------------|----------------------------------------------------------------------------------------------------------|-----------------------------------------------|
|           | 5.8               | SRAM                                     | (ROM) ACCESS                                                                                             | 90                                            |
|           |                   | 5.8.1                                    | SRAM (ROM) Read Cycle                                                                                    | 90                                            |
|           |                   | 5.8.2                                    | SRAM Write Cycle                                                                                         | 91                                            |
|           | 5.9               | PAGE-                                    | ROM ACCESS                                                                                               | 92                                            |
|           |                   | 5.9.1                                    | Page-ROM Read Cycle                                                                                      | 92                                            |
|           | 5.10              | DRAM                                     | ACCESS                                                                                                   | 93                                            |
|           |                   | 5.10.1                                   | DRAM Read Cycle                                                                                          | 93                                            |
|           |                   | 5.10.2                                   | DRAM Write Cycle                                                                                         | 95                                            |
|           |                   | 5.10.3                                   | CBR Refresh Cycle                                                                                        | 98                                            |
|           |                   | 5.10.4                                   | Self-Refresh Cycle                                                                                       | 99                                            |
|           |                   | 5.10.5                                   | Bus Cycle during Fly-by Transfer                                                                         | 100                                           |
|           | 5.11              | EXCEF                                    | PTION HANDLING CYCLES                                                                                    | 104                                           |
|           |                   | 5.11.1                                   | Machine Fault Cycle                                                                                      | 104                                           |
|           |                   | 5.11.2                                   | Halt Acknowledge Cycle                                                                                   | 105                                           |
|           | 5.12              | CONTR                                    | ROL SIGNAL TIMING                                                                                        | 106                                           |
|           |                   | 5.12.1                                   | Bus Hold                                                                                                 | 106                                           |
|           |                   | 5.12.2                                   | Bus Lock                                                                                                 | 108                                           |
| CHAPTER 6 | WAI               |                                          | ROL FUNCTIONS                                                                                            | 109                                           |
|           | 6.1               | FEATU                                    | IRES                                                                                                     | 109                                           |
|           | 6.2               | ADDRE                                    | ESS SPACES AND BLOCKS                                                                                    | 109                                           |
|           | 6.3               | CHIP S                                   | SELECT CREATION AND BUS CYCLE SELECTION FUNCTIONS                                                        | 110                                           |
|           | 6.4               | PROG                                     | RAMMABLE WAIT FUNCTION                                                                                   | 110                                           |
|           |                   | 6.4.1                                    | Wait Control Using the READY Pin                                                                         | 110                                           |
|           |                   | 6.4.2                                    | Wait Control during DMA Transfer                                                                         | 111                                           |
|           |                   | 6.4.3                                    | Bus Cycles during Which the Wait Function Is Effective                                                   | 111                                           |
|           | 6.5               | CONT                                     | ROL REGISTERS                                                                                            | 114                                           |
|           |                   | 6.5.1                                    | Bus Cycle Type Control Register (BCTC)                                                                   | 114                                           |
|           |                   | 6.5.2                                    | Programmable Wait Control Register 0 (PWC0)                                                              | 115                                           |
|           |                   |                                          |                                                                                                          |                                               |
|           |                   | 6.5.3                                    | Programmable Wait Control Register 1 (PWC1)                                                              | 116                                           |
|           |                   | 6.5.3<br>6.5.4                           | Programmable Wait Control Register 1 (PWC1)<br>Programmable Wait Control Register 2 (PWC2)               |                                               |
| CHAPTER 7 | MEM               | 6.5.4                                    |                                                                                                          | 117                                           |
| CHAPTER 7 | <b>MEM</b><br>7.1 | 6.5.4<br>ORY A                           | Programmable Wait Control Register 2 (PWC2)                                                              | 117<br><b>119</b>                             |
| CHAPTER 7 |                   | 6.5.4<br>ORY A                           | Programmable Wait Control Register 2 (PWC2)                                                              | 117<br><b>119</b><br>119                      |
| CHAPTER 7 |                   | 6.5.4<br><b>ORY A</b><br>DRAM            | Programmable Wait Control Register 2 (PWC2)                                                              | 117<br><b>119</b><br>119<br>119               |
| CHAPTER 7 |                   | 6.5.4<br><b>ORY A</b><br>DRAM<br>7.1.1   | Programmable Wait Control Register 2 (PWC2)<br>CCESS CONTROL FUNCTIONS<br>CONTROLLER (DRAMC)<br>Features | 117<br><b>119</b><br>119<br>119<br>119        |
| CHAPTER 7 |                   | 6.5.4<br>ORY A<br>DRAM<br>7.1.1<br>7.1.2 | Programmable Wait Control Register 2 (PWC2)                                                              | 117<br><b>119</b><br>119<br>119<br>119<br>121 |

|           |      | 7.1.6   | Wait Control for DRAM Cycle                               | 127 |
|-----------|------|---------|-----------------------------------------------------------|-----|
|           |      | 7.1.7   | Refresh Function                                          | 129 |
|           |      | 7.1.8   | Self-Refresh Function                                     | 132 |
|           | 7.2  | ROM C   | CONTROLLER (ROMC)                                         | 134 |
|           |      | 7.2.1   | on-page/off-page Decision                                 | 134 |
|           |      | 7.2.2   | Page-ROM Access                                           | 135 |
|           |      | 7.2.3   | Page-ROM Configuration Register (PRC)                     | 137 |
| CHAPTER 8 | DMA  | FUNCT   | TIONS (DMA CONTROLLER)                                    | 139 |
|           | 8.1  | FEATU   | IRES                                                      | 139 |
|           | 8.2  | CONFI   | GURATION                                                  | 140 |
|           | 8.3  | DMA C   | ONTROL REGISTERS                                          | 140 |
|           |      | 8.3.1   | DMA Source Address Registers 0 and 1 (DSA0 and DSA1)      | 140 |
|           |      | 8.3.2   | DMA Destination Address Registers 0 and 1 (DDA0 and DDA1) | 141 |
|           |      | 8.3.3   | DMA Byte Count Registers 0 and 1 (DBC0 and DBC1)          | 143 |
|           |      | 8.3.4   | DMA Channel Control Registers 0 and 1 (DCHC0 and DCHC1)   | 144 |
|           | 8.4  | TRANS   | SFER MODES                                                | 146 |
|           |      | 8.4.1   | Single Transfer Mode                                      | 146 |
|           |      | 8.4.2   | Single-Step Transfer Mode                                 | 146 |
|           |      | 8.4.3   | Block Transfer Mode                                       | 147 |
|           | 8.5  | DMA T   | RANSFER TYPES AND TRANSFER OBJECTS                        | 148 |
|           |      | 8.5.1   | Two-Cycle Transfer                                        | 148 |
|           |      | 8.5.2   | Fly-by Transfer                                           | 149 |
|           |      | 8.5.3   | Transfer Objects                                          | 149 |
|           | 8.6  | DMA C   | HANNEL PRIORITIES                                         | 150 |
|           | 8.7  | DMA T   | RANSFER REQUESTS                                          | 150 |
|           | 8.8  | DMA T   | RANSFER END INTERRUPTS                                    | 150 |
|           | 8.9  | DMA T   | RANSFER END OUTPUT                                        | 151 |
|           | 8.10 | FORCI   | BLE INTERRUPTION                                          | 152 |
|           | 8.11 | DATA    | FLOW DURING DMA TRANSFER                                  | 152 |
| CHAPTER 9 | SER  | IAL INT | ERFACE FUNCTION                                           | 155 |
|           | 9.1  | FEATU   | IRES                                                      | 155 |
|           | 9.2  | ASYNC   | CHRONOUS SERIAL INTERFACE (UART)                          | 155 |
|           |      | 9.2.1   | Features                                                  | 155 |
|           |      | 9.2.2   | Configuration                                             | 156 |
|           |      | 9.2.3   | UART Control Registers                                    | 158 |
|           |      | 9.2.4   | Interrupt Requests                                        | 164 |
|           |      | 9.2.5   | Operation                                                 | 165 |
|           | 9.3  | SYNCH   | HRONOUS SERIAL INTERFACE (CSI)                            | 169 |

|            |      | 9.3.1 Features                                                 | 169 |
|------------|------|----------------------------------------------------------------|-----|
|            |      | 9.3.2 Configuration                                            | 170 |
|            |      | 9.3.3 CSI Control Registers                                    | 171 |
|            |      | 9.3.4 Basic Operation                                          | 172 |
|            |      | 9.3.5 Transmission in Three-Wire Serial I/O Mode               | 174 |
|            |      | 9.3.6 Reception in Three-Wire Serial I/O Mode                  | 175 |
|            |      | 9.3.7 Transmission and Reception in Three-Wire Serial I/O Mode | 176 |
|            |      | 9.3.8 Example System Configuration                             | 177 |
|            | 9.4  | BAUD RATE GENERATOR (BRG)                                      | 178 |
|            |      | 9.4.1 Configuration and Function                               | 178 |
|            |      | 9.4.2 Baud Rate Generator Register (BRG)                       | 181 |
|            |      | 9.4.3 Baud Rate Generator Prescaler Mode Register (BPRM)       | 181 |
| CHAPTER 10 | ТІМЕ | ER/COUNTER FUNCTIONS (REAL-TIME PULSE UNIT)                    | 183 |
|            | 10.1 | FEATURES                                                       | 183 |
|            | 10.2 | BASIC CONFIGURATION                                            | 184 |
|            |      | 10.2.1 Timer 0                                                 | 186 |
|            |      | 10.2.2 Timer 1                                                 | 188 |
|            | 10.3 | CONTROL REGISTERS                                              | 189 |
|            | 10.4 | OPERATION OF TIMER 0                                           | 195 |
|            |      | 10.4.1 Counting                                                | 195 |
|            |      | 10.4.2 Count Clock Selection                                   | 195 |
|            |      | 10.4.3 Overflow                                                | 196 |
|            |      | 10.4.4 Clearing/Starting the Timer by the TCLR Input           |     |
|            |      | 10.4.5 Capturing                                               | 198 |
|            |      | 10.4.6 Comparison                                              | 199 |
|            | 10.5 | OPERATION OF TIMER 1                                           | 201 |
|            |      | 10.5.1 Counting                                                |     |
|            |      | 10.5.2 Input Clock Selection                                   |     |
|            |      | 10.5.3 Overflow                                                | 201 |
|            |      | 10.5.4 Comparison                                              | 202 |
|            | 10.6 | EXAMPLES OF APPLICATIONS                                       | 204 |
|            | 10.7 | CAUTIONS                                                       | 211 |
| CHAPTER 11 | WAT  | CHDOG TIMER FUNCTIONS                                          | 213 |
|            | 11.1 | FEATURES                                                       | 213 |
|            | 11.2 | CONFIGURATION                                                  | 213 |
|            | 11.3 | OPERATION                                                      | 214 |
|            | 11.4 | WDT MODE REGISTER (WDTM)                                       | 215 |

| CHAPTER 12 | PORT FUNCTIONS 2                                               |     |  |  |  |
|------------|----------------------------------------------------------------|-----|--|--|--|
|            | 12.1 FEATURES                                                  | 217 |  |  |  |
|            | 12.2 CONFIGURATION                                             | 217 |  |  |  |
|            | 12.3 PIN FUNCTIONS OF PORT 0                                   | 218 |  |  |  |
|            | 12.4 CONTROL REGISTER                                          | 219 |  |  |  |
|            | 12.4.1 Port Mode Control Register 0 (PMC0)                     | 219 |  |  |  |
|            | 12.4.2 Port Mode Register 0 (PM0)                              | 219 |  |  |  |
| CHAPTER 13 | CLOCK GENERATION FUNCTIONS                                     | 221 |  |  |  |
|            | 13.1 FEATURES                                                  | 221 |  |  |  |
|            | 13.2 CONFIGURATION                                             | 221 |  |  |  |
|            | 13.3 INPUT CLOCK SELECTION                                     | 222 |  |  |  |
|            | 13.3.1 Direct Mode                                             | 222 |  |  |  |
|            | 13.3.2 PLL Mode                                                | 222 |  |  |  |
|            | 13.4 CLOCK OUTPUT CONTROL                                      | 223 |  |  |  |
|            | 13.5 CLOCK CONTROL REGISTER (CGC)                              | 224 |  |  |  |
| CHAPTER 14 | STANDBY FUNCTIONS                                              | 225 |  |  |  |
|            | 14.1 FEATURES                                                  | 225 |  |  |  |
|            | 14.2 STANDBY MODE                                              | 225 |  |  |  |
|            | 14.3 STANDBY CONTROL REGISTER (STBC)                           | 228 |  |  |  |
|            | 14.4 HALT MODE                                                 | 229 |  |  |  |
|            | 14.4.1 Placing the System in the HALT Mode and Operation State | 229 |  |  |  |
|            | 14.4.2 Releasing the System from the HALT Mode                 | 230 |  |  |  |
|            | 14.5 IDLE MODE                                                 | 231 |  |  |  |
|            | 14.5.1 Placing the System in the IDLE Mode and Operation State | 231 |  |  |  |
|            | 14.5.2 Releasing the System from the IDLE Mode                 | 233 |  |  |  |
|            | 14.6 STOP MODE                                                 | 234 |  |  |  |
|            | 14.6.1 Placing the System in the STOP Mode and Operation State | 234 |  |  |  |
|            | 14.6.2 Releasing the System from the STOP Mode                 | 235 |  |  |  |
|            | 14.7 SECURING OSCILLATION SETTLING TIME                        | 235 |  |  |  |
| CHAPTER 15 | RESET FUNCTIONS                                                | 237 |  |  |  |
|            | 15.1 FEATURES                                                  | 237 |  |  |  |
|            | 15.2 PIN FUNCTIONS                                             | 237 |  |  |  |
|            | 15.3 INITIALIZATION                                            | 239 |  |  |  |
| APPENDIX A | REGISTER INDEX                                                 | 243 |  |  |  |
|            | A.1 REGISTER NAMES                                             | 243 |  |  |  |
|            | A.2 REGISTER SYMBOLS                                           | 245 |  |  |  |
| APPENDIX B | GENERAL INDEX                                                  | 247 |  |  |  |



### LIST OF FIGURES

| Figure No. | Title                                                                            | Page |
|------------|----------------------------------------------------------------------------------|------|
| 3-1.       | Memory Map                                                                       | 46   |
| 3-2.       | I/O Мар                                                                          | 47   |
| 3-3.       | Images in an Address Space                                                       | 48   |
| 4-1.       | Noise Elimination of the $\overline{\text{NMI}}$ Pin Introducing an Analog Delay | 58   |
| 4-2.       | Nonmaskable Interrupt Handling Procedure                                         | 59   |
| 4-3.       | Accepting a Nonmaskable Interrupt Request                                        | 59   |
| 4-4.       | Maskable Interrupts                                                              | 60   |
| 4-5.       | Maskable Interrupt Handling Procedure                                            | 62   |
| 5-1.       | CPU Bus Cycle State Transition                                                   | 76   |
| 5-2.       | DMAC Bus Cycle State Transition                                                  | 78   |
| 5-3.       | Data Flow When an Additional Bus Cycle Is Used                                   | 81   |
| 5-4.       | Read Cycle                                                                       | 83   |
| 5-5.       | Write Cycle                                                                      | 84   |
| 5-6.       | Write Cycles for Bit Strings                                                     | 85   |
| 5-7.       | External I/O Read Cycle                                                          | 86   |
| 5-8.       | External I/O Write Cycle                                                         | 87   |
| 5-9.       | Internal I/O Read Cycle                                                          | 88   |
| 5-10.      | Internal I/O Write Cycle                                                         | 89   |
| 5-11.      | SRAM (ROM) Read Cycle                                                            | 90   |
| 5-12.      | SRAM Write Cycle                                                                 | 91   |
| 5-13.      | Page-ROM Read Cycle                                                              | 92   |
| 5-14.      | DRAM Read Cycle                                                                  | 94   |
| 5-15.      | DRAM Write Cycle                                                                 | 96   |
| 5-16.      | CBR Refresh Cycle                                                                | 98   |
| 5-17.      | CBR Self-Refresh Cycle                                                           | 99   |
| 5-18.      | Fly-by Read Cycle during DMA Block Transfer (DRAM to External I/O Device)        | 100  |
| 5-19.      | Fly-by Read Cycle during DMA Single Transfer and Single-Step Transfer            | 101  |
|            | (DRAM to External I/O Device)                                                    | 101  |
| 5-20.      | Fly-by Write Cycle during DMA Block Transfer (External I/O Device to DRAM)       | 102  |
| 5-21.      | Fly-by Write Cycle during DMA Single Transfer and Single-Step Transfer           | 103  |
|            | (External I/O Device to DRAM)                                                    | 103  |
| 5-22.      | Machine Fault Cycle                                                              | 105  |
| 5-23.      | Halt Acknowledge Cycle                                                           | 105  |
| 5-24.      | Bus Hold Cycle                                                                   | 107  |

| Figure No. | Title                                                                          |     |  |  |  |
|------------|--------------------------------------------------------------------------------|-----|--|--|--|
| 5-25.      | Bus Lock Cycle When the CAXI Instruction Is Executed                           | 108 |  |  |  |
| 6-1.       | Memory and I/O Maps                                                            | 109 |  |  |  |
| 7-1.       | Connection of 16-Mbyte (1-Mbyte x 16) DRAM                                     | 120 |  |  |  |
| 7-2.       | Connection of 4-Mbyte (1-Mbyte x 4) DRAM                                       | 120 |  |  |  |
| 7-3.       | Output of Row and Column Addresses                                             | 121 |  |  |  |
| 7-4.       | DRAM Read Cycle                                                                | 124 |  |  |  |
| 7-5.       | DRAM Write Cycle                                                               | 125 |  |  |  |
| 7-6.       | Insertion of Wait State (1 Wait) during DRAM Read for                          | 127 |  |  |  |
|            | Fly-by DMA Transfer (DRAM to External I/O)                                     | 127 |  |  |  |
| 7-7.       | Insertion of Wait State (1 Wait) during DRAM Write for                         | 128 |  |  |  |
|            | Fly-by DMA Transfer (External I/O to DRAM)                                     | 128 |  |  |  |
| 7-8.       | CBR Refresh Cycle                                                              |     |  |  |  |
| 7-9.       | Cancellation of CBR Self Refresh with MMI Input                                | 132 |  |  |  |
| 7-10.      | Cancellation of CBR Self-Refresh with HLDRQ Input (in IDLE mode)               |     |  |  |  |
| 7-11.      | on-page/off-page Decision When ROM Having a Page Access Function Is            |     |  |  |  |
|            | Connected                                                                      | 134 |  |  |  |
| 7-12.      | Timing of the Page-ROM Cycle (16-Mbit (1-Mbit x 16) Page-ROM)                  |     |  |  |  |
| 7-13.      | Connection of 16-Mbit (1-Mbit x 16) Page-ROM                                   |     |  |  |  |
| 7-14.      | Connection of 16-Mbit (2-Mbit x 8) Page-ROM                                    |     |  |  |  |
| 8-1.       | Block Diagram of DMAC                                                          | 140 |  |  |  |
| 8-2.       | Single Transfer Example 1                                                      | 146 |  |  |  |
| 8-3.       | Single Transfer Example 2                                                      | 146 |  |  |  |
| 8-4.       | Single-Step Transfer Example 1                                                 | 146 |  |  |  |
| 8-5.       | Single-Step Transfer Example 2                                                 | 147 |  |  |  |
| 8-6.       | Block Transfer Example                                                         | 147 |  |  |  |
| 8-7.       | Timing of Two-Cycle, Single-Step DMA Transfer (External I/O to DRAM (on-page)) | 148 |  |  |  |
| 8-8.       | Timing of Fly-by DMA Transfer (DRAM (on-page) to External I/O)                 | 149 |  |  |  |
| 8-9.       | Timing of DMA Transfer End Output                                              | 151 |  |  |  |
| 8-10.      | Data Flow during DMA Transfer (Two-Cycle Byte Transfer)                        | 152 |  |  |  |
| 8-11.      | Data Flow during DMA Transfer (Two-Cycle, 16-Bit Transfer)                     |     |  |  |  |
| 8-12.      | Data Flow during DMA Transfer (Fly-by Transfer)                                |     |  |  |  |
| 9-1.       | Asynchronous Serial Interface                                                  | 157 |  |  |  |
| 9-2.       | Format of Transmission and Reception Data Transferred                          | 165 |  |  |  |
|            | via Asynchronous Serial Interface                                              | 165 |  |  |  |

| Figure No. | Title                                                                         | Page  |  |  |  |
|------------|-------------------------------------------------------------------------------|-------|--|--|--|
| 9-3.       | Timing of Transmission Completion Interrupt via Asynchronous Serial Interface | . 166 |  |  |  |
| 9-4.       | Timing of Reception Completion Interrupt via Asynchronous Serial Interface    | . 167 |  |  |  |
| 9-5.       | Timing of Reception Error                                                     |       |  |  |  |
| 9-6.       | Timing of Three-Wire Serial I/O Mode (Transmission)                           | . 174 |  |  |  |
| 9-7.       | Timing of Three-Wire Serial I/O Mode (Reception)                              | . 175 |  |  |  |
| 9-8.       | Timing of Three-Wire Serial I/O Mode (Transmission and Reception)             | . 177 |  |  |  |
| 9-9.       | Example System Configuration Using CSI                                        | . 177 |  |  |  |
| 9-10.      | Block Diagram                                                                 | . 178 |  |  |  |
| 10-1.      | Basic Operation of Timer 0                                                    | . 195 |  |  |  |
| 10-2.      | Operation after an Overflow (When ECLR0 = 0 and OST = 1)                      | . 196 |  |  |  |
| 10-3.      | Clearing/Starting TM0 by a TCLR Input (When ECLR0 = 1 and OST = 0)            | . 197 |  |  |  |
| 10-4.      | Clearing/Starting TM0 by a TCLR Input and the Related Overflow                |       |  |  |  |
|            | (When ECLR0 = 0 and OST = 1)                                                  | . 197 |  |  |  |
| 10-5.      | Example of TM0 Capturing (When Both Rising and Falling Edges Are Specified)   | . 198 |  |  |  |
| 10-6.      | Example of TM0 Capturing                                                      | . 199 |  |  |  |
| 10-7.      | Example of Comparison                                                         | . 200 |  |  |  |
| 10-8.      | Example of TM0 Comparison (Set/Reset Output Mode)                             | . 200 |  |  |  |
| 10-9.      | Basic Operation of Timer 1                                                    | . 201 |  |  |  |
| 10-10.     | Operation from When CM1 Is 1 until It Is FFFFH                                | . 202 |  |  |  |
| 10-11.     | Operation with CM1 Cleared to 0                                               | . 203 |  |  |  |
| 10-12.     | Interval Timer Operation Timing (Timer 1)                                     | . 204 |  |  |  |
| 10-13.     | Interval Timer Operation Setting Procedure (Timer 1)                          | . 204 |  |  |  |
| 10-14.     | Pulse Width Measurement Timing (Timer 0)                                      | . 205 |  |  |  |
| 10-15.     | Pulse Width Measurement Setting Procedure (Timer 0)                           | . 206 |  |  |  |
| 10-16.     | Pulse Width Calculation Interrupt Request Handling Routine (Timer 0)          | . 206 |  |  |  |
| 10-17.     | PWM Output Timing (TM0)                                                       | . 207 |  |  |  |
| 10-18.     | PWM Output Setting Procedure (Timer 0)                                        | . 208 |  |  |  |
| 10-19.     | Compare Value Rewrite Interrupt Request Handling Routine (Timer 0)            | . 209 |  |  |  |
| 10-20.     | Pulse Width Measurement Timing (TM0)                                          | . 210 |  |  |  |
| 10-21.     | Period Measurement Setting Procedure (Timer 0)                                | . 210 |  |  |  |
| 10-22.     | Period Calculation Interrupt Request Handling Routine (Timer 0)               | . 211 |  |  |  |
| 11-1.      | Watchdog Timer Block Diagram                                                  | . 213 |  |  |  |
| 14-1.      | Bus Hold in IDLE Mode and Restart of Self-Refresh                             | . 233 |  |  |  |

### LIST OF TABLES

| Table No. | Title                                                                                                                                | Page |
|-----------|--------------------------------------------------------------------------------------------------------------------------------------|------|
| 3-1.      | Program Registers                                                                                                                    | 50   |
| 3-2.      | System Register Numbers                                                                                                              | 51   |
| 3-3.      | Built-in Peripheral I/O Registers                                                                                                    | 52   |
| 4-1.      | Interrupts                                                                                                                           | 56   |
| 4-2.      | Correspondence between Priorities, Exception Codes, Handler Addresses,<br>and Interrupt Levels (When the IGP Register Is Set to 4EH) | 65   |
| 4-3.      | Correspondence between Interrupt Control Register Bits and                                                                           |      |
|           | Interrupt Request Signals                                                                                                            | 67   |
| 4-4.      | Priorities of Interrupts and Exceptions                                                                                              | 73   |
| 4-5.      | Priorities of Floating-Point Exceptions                                                                                              | 74   |
| 5-1.      | Bus Priority                                                                                                                         | 80   |
| 5-2.      | Relationship between Addresses, Data Length, UBE, and Address Pins                                                                   | 82   |
| 5-3.      | Correspondence between the Address Bus and Data Bus in the Machine Fault Cycle                                                       | 104  |
| 6-1.      | Bus Cycles during Which the Wait Function Is Effective                                                                               | 112  |
| 6-2.      | Cycles during Which Programmable Waits Can Be Set, and                                                                               |      |
|           | Corresponding Control Registers                                                                                                      |      |
| 6-3.      | Number of Waits to Be Inserted during Fly-by DMA Transfer                                                                            |      |
|           | (at off-page Time during DRAM Cycle)                                                                                                 | 118  |
| 7-1.      | DRAM Control Pins                                                                                                                    | 119  |
| 7-2.      | Examples of DRAM and Address Multiplexing Width                                                                                      | 121  |
| 7-3.      | Differences between on-page and off-page Cycles                                                                                      | 123  |
| 7-4.      | DRAM Refresh Intervals                                                                                                               | 130  |
| 7-5.      | Examples of Setting the Interval Factor                                                                                              | 130  |
| 8-1.      | Transfer Types vs. Transfer Objects                                                                                                  | 149  |
| 9-1.      | Generated Interrupts and Default Priorities                                                                                          | 164  |
| 9-2.      | BRG Setting Data                                                                                                                     | 180  |
| 10-1.     | Configuration of the RPU                                                                                                             | 184  |
| 10-2.     | Capture Trigger Signal for the 16-Bit Capture Register (TM0)                                                                         | 198  |

| Table No. | Title                                                           | Page |
|-----------|-----------------------------------------------------------------|------|
| 10-3.     | Interrupt Request Signal from the 16-Bit Compare Register (TM0) | 199  |
| 12-1.     | Port Operation                                                  | 220  |
| 14-1.     | Clock Generator Operation under Standby Control                 | 226  |
| 14-2.     | Operations during the HALT Mode                                 | 229  |
| 14-3.     | Operations during the IDLE Mode                                 | 232  |
| 14-4.     | Operations during the STOP Mode                                 | 234  |
| 14-5.     | Count Time Examples                                             | 236  |
| 15-1.     | Output State of Each Pin during a Reset                         | 238  |
| 15-2.     | Initial Value in Each Register after a Reset                    | 240  |



[MEMO]



### **CHAPTER 1 OVERVIEW**

The V821 is a 32-/16-bit RISC microprocessor that uses, as its processor core, the high-performance 32-bit V810<sup>TM</sup> ( $\mu$ PD70732) microprocessor designed for built-in control applications. It incorporates peripheral functions such as a DRAM/ROM controller, 2-channel DMA controller, real-time pulse unit, serial interface, and interrupt controller.

The V821, which offers quick real-time response, high-speed integer instructions, bit string instructions, and floating-point instructions, is ideally suited to use in OA equipment such as printers and facsimiles, image processing devices such as those used in navigation units, portable devices, and other devices demanding excellent cost performance.

### **1.1 FEATURES**

| • 32-bit CPU core                                  | Compatible with V810 instructions<br>Built-in 1-Kbyte instruction cache memory<br>1-clock-pulse pitch pipeline<br>16-bit data bus<br>Internal 4-Gbyte linear addresses<br>General-purpose registers: 32 bits x 32          |
|----------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                    | Instruction group that can be applied to a wide range of fields (floating-<br>point instructions, bit string manipulation instructions)                                                                                    |
| <ul> <li>Interrupts/exceptions</li> </ul>          | Nonmaskable : 1 external input<br>Maskable : 8 external inputs<br>11 types of internal sources<br>Priorities can be specified in units of four groups.                                                                     |
| • Wait control unit                                | Capable of CS control over four blocks in both memory and I/O spaces.<br>Linear address space of each block: 16 Mbytes<br>Automatic insertion of 0-7 waits per block<br>Bus cycle (page-ROM, DRAM) selection function      |
| <ul> <li>Memory access control function</li> </ul> | S                                                                                                                                                                                                                          |
|                                                    | Supports DRAM high-speed page mode.                                                                                                                                                                                        |
|                                                    | Supports page-ROM page mode.                                                                                                                                                                                               |
| DMA controller                                     | 2 channels                                                                                                                                                                                                                 |
|                                                    | Maximum transfer count: 65,536<br>Two transfer types (fly-by (1-cycle) transfer and 2-cycle transfer)<br>Three transfer modes (single transfer, single-step transfer, and block<br>transfer)<br>Programmable wait function |

- Serial interfaces
   Asynchronous serial interface (UART): 1 channel
   Synchronous serial interface (CSI): 1 channel
   Built-in dedicated baud rate generator
- Real-time pulse unit
   16-bit timer/event counter: 1 channel Timer output: 2
   16-bit capture/compare register: 4
   16-bit interval timer: 1 channel
- Watchdog timer functions
- Clock generator Multiplication-by-5 function with a PLL clock synthesizer
   Standby functions HALT, IDLE, and STOP modes Clock output control

### ★ 1.2 ORDERING INFORMATION

| Part number       | Package                           | Maximum operating frequency (MHz) |  |
|-------------------|-----------------------------------|-----------------------------------|--|
| μPD70741GC-25-8EU | 100-pin plastic LQFP (fine pitch) | 25                                |  |
|                   | (14 x 14 x 1.40 mm)               |                                   |  |

Not all devices/types available in every country. Please check with local NEC representative for availability and additional information.

### ★ 1.3 PIN CONFIGURATION (TOP VIEW)

100-pin plastic LQFP (fine pitch) (14 x 14 mm)  $\mu$ PD70741GC-25-8EU



Caution Connect pin IC to GND via a resistor.

### Pin names

| A0-A23                       | : Address Bus                    |
|------------------------------|----------------------------------|
| BLOCK                        | : Bus Lock                       |
| CLKOUT                       | : System Clock Out               |
| CS0-CS3                      | : Chip Select                    |
| D0-D15                       | : Data Bus                       |
| DACKO, DACK1                 | : DMA Acknowledge                |
| DREQ0, DREQ1                 | : DMA Request                    |
| HLDAK                        | : Hold Acknowledge               |
| HLDRQ                        | : Hold Request                   |
| INTP00-INTP03, INTP10-INTP13 | : Interrupt Request              |
| IORD                         | : I/O Read                       |
| IOWR                         | : I/O Write                      |
| LCAS                         | : Lower Column Address Strobe    |
| LMWR                         | : Lower Memory Write             |
| MRD                          | : Memory Read                    |
| NMI                          | : Non-maskable Interrupt Request |
| P00-P09                      | : Port                           |
| RAS                          | : Row Address Strobe             |
| READY                        | : Ready                          |
| REFRQ                        | : Refresh Request                |
| RESET                        | : Reset                          |
| RXD                          | : Receive Data                   |
| SCLK                         | : Serial Clock                   |
| SI                           | : Serial Input                   |
| SO                           | : Serial Output                  |
| TC                           | : Terminal Count                 |
| TCLR                         | : Timer Clear                    |
| ТІ                           | : Timer Input                    |
| TO00, TO01                   | : Timer Output                   |
| TXD                          | : Transmit Data                  |
| UBE                          | : Upper Byte Enable              |
| UCAS                         | : Upper Column Address Strobe    |
| UMWR                         | : Upper Memory Write             |
| WDTOUT                       | : Watchdog Timer Output          |
| WE                           | : Write Enable                   |
| X1, X2                       | : Crystal Oscillator             |

### **1.4 FUNCTIONAL BLOCK CONFIGURATION**

### ★ 1.4.1 Internal Block Diagram



### 1.4.2 Internal Units

### (1) Bus interface unit (BIU)

Controls the pins of the address bus, data bus, and control bus. A bus cycle activated by the CPU or DMAC is controlled via the WCU, DRAMC, and ROMC.

### (2) Wait control unit (WCU)

Manages the four blocks corresponding to four chip select signals ( $\overline{CS0}$ - $\overline{CS3}$ ). This block generates chip select signals, performs wait control, and selects a bus cycle type.

### (3) DRAM controller (DRAMC)

Generates the RAS, UCAS, and LCAS signals (2CAS control) and controls access to DRAM. This block supports DRAM high-speed page mode. Access to DRAM can be of either of two types, each having a different cycle, normal access (off-page) or high-speed page access (on-page).

### (4) ROM controller (ROMC)

Supports access to ROM supporting a page access function.

Performs address comparison relative to the previous bus cycle and performs wait control for normal access (off-page)/page access (on-page). It supports page widths of 8-64 bytes.

### (5) Interrupt controller

Handles maskable interrupt requests (INTP00-INTP03, INTP10-INTP13) from both the built-in and external peripheral hardware. Priorities can be specified for these interrupt requests, in units of four groups. It can apply multiple handling control to the interrupt sources.

### (6) DMA controller (DMAC)

Transfers data between memory and I/O, as instructed by the CPU.

There are two address modes, fly-by (1-cycle) transfer and 2-cycle transfer. There are three bus modes, single transfer, single-step transfer, and block transfer.

### (7) Serial interfaces (UART/CSI)

As serial interfaces, the V821 features an asychronous serial interface (UART) and a synchronous serial interface (CSI), one channel being assigned to each.

The UART transfers data via pins TXD and RXD.

The CSI transfers data via pins SO, SI, and  $\overline{SCLK}$ .

Either the baud rate generator or the system clock can be selected as the serial clock source.

### (8) Real-time pulse unit (RPU)

This block incorporates a 16-bit timer/event counter and a 16-bit interval timer. It can calculate pulse intervals and frequencies and output programmable pulses.

### (9) Watchdog timer (WDT)

This block incorporates an 8-bit watchdog timer to detect a program hanging up or system errors. If the watchdog timer overflows, the WDTOUT pin becomes active.

### (10) Clock generator (CG)

Supplies clock pulses at a frequency five times greater than that of the oscillator connected to pins X1 and X2 (when the built-in PLL is being used) or at half the frequency (when the built-in PLL is not being used) of the operating clock pulses for the CPU. Also, instead of connecting an oscillator, external clock pulses can be input.

### (11) Bus arbitration unit (BAU)

Arbitrates any contention over bus mastership between the bus masters (CPU, DRAMC, DMAC, external bus master). Bus mastership can be switched in each bus cycle and also in the idle state.

### (12) Port

Port 0 provides a total of ten input/output port pins. The pins can be used as either port or control pins.



[MEMO]



### **CHAPTER 2 PIN FUNCTIONS**

The pins of the V821 are classed either as port pins or non-port pins, according to their function.

### 2.1 PIN FUNCTIONS

#### 2.1.1 Port Pins

| Pin name | Input/output | Function                                                     | Dual-function pin |
|----------|--------------|--------------------------------------------------------------|-------------------|
| P00      | Input/output | Port 0                                                       | TCLR              |
| P01      |              | 10-bit input/output port<br>Can be set for input/output bit. | DREQ0             |
| P02      |              | Can be set for input/output bit.                             | DACK0             |
| P03      |              |                                                              | DREQ1             |
| P04      |              |                                                              | DACK1             |
| P05      |              |                                                              | SI                |
| P06      |              |                                                              | SO                |
| P07      |              |                                                              | SCLK              |
| P08      |              |                                                              | TXD/UBE           |
| P09      |              |                                                              | RXD/TC            |

### 2.1.2 Non-Port Pins

|          |                       |                                             | (1/2)             |
|----------|-----------------------|---------------------------------------------|-------------------|
| Pin name | Input/output          | Function                                    | Dual-function pin |
| A0-A23   | Tristate output       | Address bus signal                          | _                 |
| D0-D15   | Tristate input/output | Bidirectional data bus signal               | _                 |
| READY    | Input                 | Bus cycle termination permit signal         | _                 |
| HLDRQ    | Input                 | Bus mastership request signal               | _                 |
| HLDAK    | Output                | Bus mastership permit signal                | _                 |
| BLOCK    | Output                | Bus mastership prohibit signal              | WDTOUT            |
| MRD      | Tristate output       | Read strobe signal to memory                | _                 |
| LMWR     | Tristate output       | Write strobe signal to lower data in memory | WE                |
| UMWR     | Tristate output       | Write strobe signal to upper data in memory | _                 |
| IORD     | Tristate output       | Read strobe signal to I/O data              | -                 |
| IOWR     | Tristate output       | Write strobe signal to I/O data             | _                 |
| UBE      | Tristate output       | Data bus upper data enable signal           | TXD/P08           |
| RESET    | Input                 | System reset input                          | _                 |
| X1, X2   | Input                 | Crystal connection/external clock input     | _                 |
| CLKOUT   | Output                | System clock output                         | _                 |
| CS0      | Tristate output       | Chip select signal                          | REFRQ             |
| CS1      |                       |                                             | _                 |
| CS2      |                       |                                             | _                 |
| CS3      |                       |                                             | _                 |
| INTP00   | Input                 | Interrupt request input                     | TO00              |
| INTP01   |                       |                                             | _                 |
| INTP02   | _                     |                                             | TO01              |
| INTP03   | ]                     |                                             | _                 |
| INTP10   |                       |                                             | _                 |
| INTP11   |                       |                                             | _                 |
| INTP12   |                       |                                             | _                 |
| INTP13   |                       |                                             | ТІ                |

(2/2)

| Pin name | Input/output    | Function                                                      | Dual-function pin |
|----------|-----------------|---------------------------------------------------------------|-------------------|
| NMI      | Input           | Nonmaskable interrupt request input                           | _                 |
| REFRQ    | Tristate output | Refresh request signal to DRAM                                | CS0               |
| RAS      | Tristate output | Row address strobe signal to DRAM                             | _                 |
| LCAS     | Tristate output | Column address strobe signal to lower data in DRAM            | _                 |
| UCAS     | Tristate output | Column address strobe signal to upper data in DRAM            | _                 |
| WE       | Tristate output | Write strobe signal to DRAM                                   | LMWR              |
| DREQ0    | Input           | DMA request signal (channel 0)                                | P01               |
| DREQ1    | Input           | DMA request signal (channel 1)                                | P03               |
| DACK0    | Output          | DMA permit signal (channel 0)                                 | P02               |
| DACK1    | Output          | DMA permit signal (channel 1)                                 | P04               |
| TC       | Output          | DMA end signal                                                | RXD/P09           |
| ТО00     | Output          | RPU pulse output                                              | INTP00            |
| TO01     |                 |                                                               | INTP02            |
| TCLR     | Input           | External clear or start signal input to timer 0               | P00               |
| TI       | Input           | External count clock input to timer 0                         | INTP13            |
| TXD      | Output          | UART serial data output                                       | UBE/P08           |
| RXD      | Input           | UART serial data input                                        | TC/P09            |
| SCLK     | Input/output    | CSI serial clock input/output                                 | P07               |
| SO       | Output          | CSI serial data output                                        | P06               |
| SI       | Input           | CSI serial data input                                         | P05               |
| WDTOUT   | Output          | WDT overflow signal                                           | BLOCK             |
| IC       | _               | Internal connection (must be connected to GND via a resistor) | _                 |
| Vdd      | _               | Supplies positive power.                                      | _                 |
| GND      | _               | Ground potential                                              | _                 |

### 2.2 PIN STATES

The table below indicates the state of each pin in each operating state.

| Operating state<br>Pin | Reset  | Bus hold | HALT mode | IDLE mode | STOP mode |
|------------------------|--------|----------|-----------|-----------|-----------|
| CLKOUT                 | Note 1 | Note 1   | Note 1    | Note 1    | 1         |
| CS0/REFRQ              | 1      | Hi-Z     | 1         | 1         | 1         |
| CS1                    | 1      | Hi-Z     | 1         | 1         | 1         |
| CS2                    | 1      | Hi-Z     | 1         | 1         | 1         |
| CS3                    | 1      | Hi-Z     | 1         | 1         | 1         |
| A0-A23                 | x      | Hi-Z     | Note 2    | Note 2    | Note 2    |
| D0-D15                 | Hi-Z   | Hi-Z     | Hi-Z      | Hi-Z      | Hi-Z      |
| MRD                    | 1      | Hi-Z     | 1         | 1         | 1         |
| LMWR/WE                | 1      | Hi-Z     | 1         | 1         | 1         |
| UMWR                   | 1      | Hi-Z     | 1         | 1         | 1         |
| IORD                   | 1      | Hi-Z     | 1         | 1         | 1         |
| IOWR                   | 1      | Hi-Z     | 1         | 1         | 1         |
| HLDAK                  | 1      | 0        | x         | х         | 1         |
| RAS                    | 1      | Hi-Z     | 1         | 0         | 0         |
| LCAS                   | 1      | Hi-Z     | 1         | 0         | 0         |
| UCAS                   | 1      | Hi-Z     | 1         | 0         | 0         |
| BLOCK/WDTOUT           | 0      | 0        | х         | х         | 0         |

Notes 1. Clock output

2. PC of the HALT instruction

Remark Hi-Z : High impedance

- 0 : Low-level output
- 1 : High-level output
- x : Not defined

#### 2.3 PIN FUNCTIONS

This section describes the pins according to their functions.

#### 2.3.1 Address Bus

#### (1) A0-A23 (Address Bus): tristate output

Output an address signal when the V821 is accessing main external storage or an input/output device. An address space of up to 2<sup>24</sup> bytes can be accessed. The states of the pins change in sync with the rising edge of a clock pulse of the T1 state in a bus cycle.

#### 2.3.2 Data Bus

#### (1) D0-D15 (Data Bus): tristate input/output

Pins for inputting and outputting write and read data when the V821 is accessing main external storage or an input/output device. During a write bus cycle, the user can specify that write data driving start at the falling edge of a clock pulse in the T1 state or at the rising edge of a clock pulse in the T2 state. The data is held until the bus hold state and the rising edge of a clock pulse in the next bus cycle. In a read bus cycle, data is sampled at the rise of the clock pulse following the last T2 state in the cycle.

#### 2.3.3 Bus Control Signals

#### (1) **READY** (Ready): input

Receives the signal used to prolong a bus cycle to align it with memory or I/O access time. For DRAM off-page access and during a CBR refresh cycle, this signal is sampled at the rising edge of the second clock pulse in the T2 state. In another cycle in which the READY pin is valid, the signal is sampled at the falling edge of a clock pulse in the T2 state.

The setup/hold time for READY input must always be observed. Otherwise, normal operation cannot be guaranteed.

#### (2) HLDRQ (Hold Request): input

Input pin used to issue a request to the CPU to relinquish bus mastership.

The signal is sampled at the falling edge of a clock pulse in the T2, TI, and TH states. If this pin and the  $\overline{\text{READY}}$  pin are both active at the falling edge of a clock pulse in the T2 state, the CPU changes to the TI state. Then, if this signal is active at the falling edge of a clock pulse in the TI state, the CPU changes to the TH state, sets the address, data, and control buses to high impedance, makes the HLDAK signal active, and relinquishes bus mastership.

During a bus clock cycle, the CPU does not change to the TH state.

#### (3) **HLDAK** (Hold Acknowledge): output

Outputs the acknowledge signal for HLDRQ input.

The state of this pin changes at the falling edge of a clock pulse. After relinquishing up bus mastership, the CPU sets this signal to the active state. If  $\overline{\text{HLDRQ}}$  input subsequently becomes inactive, the CPU sets this signal to the inactive state and regains bus mastership.

**Phase-out/Discontinued** 

If, however, a request is issued for a higher priority cycle during bus hold, the HLDAK signal becomes inactive.

#### (4) BLOCK (Bus Lock): output

Outputs the signal prohibiting use of a bus to a bus user other than the V821 itself. The signal becomes active at the start of the first bus cycle (rising edge of a clock pulse in the T1 state) and inactive at the rising edge of the clock pulse following the end (last T2 state) of the last bus cycle.

#### (5) MRD (Memory Read): tristate output

Outputs a strobe signal indicating that the current bus cycle is an external memory read cycle. The signal always becomes inactive at the rising edge of a clock pulse in the T1 state during a bus cycle. If the bus cycle is for memory read, it becomes active at the falling edge of a clock pulse in the T1 state. For the duration of a page-ROM cycle, however, the signal remains active. Also, it remains active for the duration of a refresh cycle.

#### (6) LMWR (Lower Memory Write): tristate output

Outputs the strobe signal for writing data to external memory.

The lower bytes on the data bus are valid. If the bus cycle is for lower memory write, the signal becomes active at the falling edge of a clock pulse in the T1 state, and inactive at the falling edge of a clock pulse in the last T2 state of the bus cycle.

#### (7) UMWR (Upper Memory Write): tristate output

Outputs the strobe signal for writing data to external memory.

The upper bytes on the data bus are valid. If the bus cycle is for upper memory write, the signal becomes active at the falling edge of a clock pulse in the T1 state, and inactive at the falling edge of a clock pulse in the last T2 state of the bus cycle.

#### (8) IORD (I/O Read): tristate output

Outputs the strobe signal indicating that the current bus cycle is a read cycle for external I/O. This pin always becomes inactive at the rising edge of a clock pulse in the T1 state of a bus cycle. If the bus cycle is for I/O read, it becomes active at the falling edge of a clock pulse in the T1 state.

#### (9) IOWR (I/O Write): tristate output

Outputs the strobe signal for writing data to external I/O.

If the bus cycle is for I/O write, the signal becomes active at the falling edge of a clock pulse in the T1 state, and inactive at the falling edge of a clock pulse in the last T2 state of the bus cycle.

#### (10) UBE (Upper Byte Enable): tristate output

Outputs signal indicating access to the upper bytes on the data bus. The state of the pin changes in sync with the rising edge of a clock pulse in the T1 state.

Phase-out/Discontinued

Control over the lower bytes on the data bus is performed using the A0 signal.

| Access    | UBE | A0 |
|-----------|-----|----|
| Word      | 0   | 0  |
| Halfword  |     |    |
| Even byte | 1   | 0  |
| Odd byte  | 0   | 1  |

#### 2.3.4 System Control Signals

#### (1) RESET (Reset): input

This pin is used to initialize the V821.

To initialize the V821, the signal must remain active for at least 30 clock pulses. When the RESET signal is accepted, the V821 initializes each signal and internal register and executes instructions starting from address FFFFFF0H.

#### (2) X1, X2 (Crystal Oscillator): input

Used to connect a crystal oscillator when the internal clock generator is to be used. When using external clock, input its pulses to pin X1.

#### (3) CLKOUT (System Clock Out): output

Outputs internally generated system clock pulses.

#### (4) CS0-CS3 (Chip Select): tristate output

Output chip select signals to the address spaces. The address blocks to which the chip select signals are output are predetermined. When the bus cycle for accessing an address block is activated, the corresponding signal becomes active at the rising edge of a clock pulse in the T1 state during the bus cycle.

However,  $\overline{CS3}$  remains active for the duration of a page-ROM cycle.

#### 2.3.5 Interrupt Control Signals

#### (1) INTP00-INTP03 (Interrupt Request): input

Receive an asynchronous interrupt request signal that has been issued to the interrupt control unit (ICU). Either an edge trigger or level trigger (low level) can be selected.

If the capture/compare register (CC0) of timer 0 (TM0) in the real-time pulse unit (RPU) is specified as a capture register, the value of TM0 is latched using the valid edge (either edge) of this signal as a capture trigger.

#### (2) INTP10-INTP13 (Interrupt Request): input

Receive an asynchronous interrupt request signal that has been issued to the interrupt control unit (ICU). Either an edge trigger or level trigger (low level) can be selected.

#### (3) NMI (Non-maskable Interrupt Request): input

Receives a nonmaskable interrupt signal that has been issued to the CRU.

This signal indicates an interrupt level to the CPU. It is sampled at the falling edge of a clock pulse. This signal must be held at the active level until the CPU starts interrupt handling and posts notification, by software, that the interrupt has been accepted.

#### 2.3.6 DRAM Control Signals

#### (1) REFRQ (Refresh Request): tristate output

Outputs a refresh request signal to DRAM.

This pin is used for  $\overline{RAS}$  control during a refresh cycle when DRAM is to be expanded by decoding the addresses in an external circuit.

The signal becomes active at the rising edge of a clock pulse in the second T2 state of a refresh cycle. Then, if the cycle is a self-refresh cycle, the signal is held active at the falling edge of a clock pulse. In the case of a normal refresh cycle, the signal becomes inactive at the falling edge of a clock pulse in the fourth T2 state.

#### (2) RAS (Row Address Strobe): tristate output

Outputs a row address strobe signal to DRAM.

For DRAM off-Page access, the signal becomes inactive at the falling edge of a clock pulse in the T1 state of a bus cycle, and active at the rising edge of a clock pulse in the second T2 state.

The timing differs for a refresh cycle. (See Section 7.1.7.)

#### (3) LCAS (Lower Column Address Strobe): tristate output

Outputs a column address strobe signal to DRAM.

The lower bytes on the data bus are valid.

For read, if the cycle is an off-page cycle, the signal becomes active at the rising edge of a clock pulse in the third T2 state, and inactive at the rising edge of a clock pulse in the T1 state of the next bus cycle. If the cycle is an on-page cycle, the signal becomes active at the falling edge of a clock pulse in the T1 state and inactive at the rising edge of a clock pulse in the T1 state of the next bus cycle.

For write, the signal becomes active at the rising edge of a clock pulse in the last T2 state of a bus cycle, and inactive at the rising edge of a clock pulse in the T1 state of the next bus cycle.

The timing differs for a refresh cycle. (See Section 7.1.7.)

#### (4) UCAS (Upper Column Address Strobe): tristate output

Outputs a column address strobe signal to DRAM.

The upper bytes on the data bus are valid.

For read, if the cycle is an off-page cycle, the signal becomes active at the rising edge of a clock pulse in the third T2 state, and inactive at the rising edge of a clock pulse in the T1 state of the next bus cycle. If the cycle is an on-page cycle, the signal becomes active at the falling edge of a clock pulse in the T1 state, and inactive at the rising edge of a clock pulse in the T1 state of the next bus cycle. For write, the signal becomes active at the rising edge of a clock pulse in the last T2 state of a bus cycle, and inactive at the rising edge of a clock pulse in the T1 state of the next bus cycle.

The timing differs for a refresh cycle. (See Section 7.1.7.)

#### (5) WE (Write Enable): tristate output

Outputs the signal indicating that the current bus cycle is a DRAM write cycle.

If the bus cycle is for DRAM write, the signal becomes active at the falling edge of a clock pulse in the T1 state, and inactive at the falling edge of a clock pulse in the last T2 state of the bus cycle.

#### 2.3.7 DMA Control Signals

#### (1) DREQ0, DREQ1 (DMA Request): input

Receive a DMA service request signal. The pins correspond to DMA channels 0 and 1, respectively, and are independent of each other. Priorities are fixed: DREQ1< DREQ0.

This signal is sampled at the falling edge of the CLKOUT signal. It must be held at the active level until the DMA request is accepted.

#### (2) DACK0, DACK1 (DMA Acknowledge): output

Output a signal indicating that a DMA service request can be accepted. The pins correspond to DMA channels 0 and 1, respectively, and are independent of each other.

This signal becomes active at the rising edge of a clock pulse in the T1R or T1F state of a DMA cycle and is held at the active level during DMA transfer.

#### (3) TC (Terminal Count): output

Outputs a signal indicating that DMA transfer using the DMA controller has ended. This signal becomes active at the rising edge of a clock pulse.

The OR of  $\overline{TC}$  for channel 0 and  $\overline{TC}$  for channel 1 is output. The  $\overline{TC}$  for channel 0 and for channel 1 must, therefore, be generated by ANDing it with each of the DACK0 and DACK1 signals in an external circuit. (See **Chapter 8**.)

#### 2.3.8 Real-Time Pulse Control Signals

#### (1) TO00, TO01 (Timer Output): output

Output the compare match signal of the capture/compare register (CC0) of timer 0 (TM0) in the real-time pulse unit (RPU). This signal is set upon the detection of a match between the CC00 and CC02 registers. It is reset upon the detection of a match between the CC01 and CC03 registers. The output can be reversed by RPU mode setting.

#### (2) TCLR (Timer Clear): input

Receives a clear signal for TM0 of RPU.

#### (3) TI (Timer Input): input

Receives the external clock signal used by TM0 of RPU. Whether TM0 of RPU is to use this external clock signal or the clock pulses obtained by dividing the internal system clock pulses must be specified at initialization.

#### 2.3.9 Serial Control Signals

#### (1) TXD (Transmit Data): output

Output pin for UART serial transmission data. This signal changes in sync with an internal serial clock pulse. It is held at the high level while transmission is not being performed.

#### (2) RXD (Receive Data): input

Input pin for UART serial receive data.

#### (3) SCLK (Serial Clock): input/output

Input/output pin for CSI serial clock. Can be set to input/output through register setting.

#### (4) SO (Serial output): output

Output pin for CSI serial transmission data. The state of the pin changes in sync with the fall of the  $\overline{SCLK}$  signal. It is set to high impedance while transmission is not being performed.

#### (5) SI (Serial Input): input

Input pin for CSI serial receive data. This signal is sampled at the rising edge of the  $\overline{SCLK}$  signal.

#### 2.3.10 Watchdog Timer Control Signal

#### (1) WDTOUT (Watchdog Timer Output): output

Outputs a signal indicating that the watchdog timer (WDT) has overflowed. This signal becomes active if WDT overflows, again becoming inactive once 32 clock pulses have been issued.

#### 2.3.11 Port Control Signal

#### (1) P00-P09 (Port): tristate input/output

Port signal pins. Can be set to input/output through register setting.

#### 2.4 PIN I/O CIRCUITS AND PROCESSING OF UNUSED PINS

| Pin             | I/O circuit type | Recommended connection                                              |
|-----------------|------------------|---------------------------------------------------------------------|
| P00/TCLR        | 5                | Input status: Individually connect these pins to the VDD pin or GND |
| P01/DREQ0       | -                | via a resistor.                                                     |
| P02/DACK0       |                  | Output status: Leave these pins open.                               |
| P03/DREQ1       |                  |                                                                     |
| P04/DACK1       | -                |                                                                     |
| P05/SI          | -                |                                                                     |
| P06/SO          | -                |                                                                     |
| P07/SCLK        |                  |                                                                     |
| P08/TXD/UBE     | -                |                                                                     |
| P09/RXD/TC      |                  |                                                                     |
| D0-D15          | 5                | Leave these pins open.                                              |
| A0-A7, A16-A18  | -                |                                                                     |
| A8-A15, A19-A23 | 4                | Leave these pins open.                                              |
| READY           | 1                | Connect this pin to GND via a resistor.                             |
| HLDRQ           |                  | Connect this pin to the VDD pin via a resistor.                     |
| HLDAK           | 4                | Leave these pins open.                                              |
| BLOCK/WDTOUT    | -                |                                                                     |
| MRD             | -                |                                                                     |
| LMWR/WE         | -                |                                                                     |
| UMWR            | -                |                                                                     |
| IORD            | -                |                                                                     |
| IOWR            |                  |                                                                     |
| CLKOUT          | -                |                                                                     |
| CS0/REFRQ       | -                |                                                                     |
| CS1-CS3         | -                |                                                                     |
| INTP00/TO00     | 8                | Connect this pin to the Vod pin via a resistor.                     |
| INTP01          | 2                | Connect this pin to the Vod pin via a resistor.                     |
| INTP02/TO01     | 8                | Connect this pin to the Vod pin via a resistor.                     |
| INTP03          | 2                | Connect these pins to the VDD pin via a resistor.                   |
| INTP10-INTP12   | 1                |                                                                     |
| INTP13/TI       |                  |                                                                     |
| NMI             | -                |                                                                     |
| RESET           |                  |                                                                     |
| RAS             | 4                | Leave these pins open.                                              |
| LCAS            |                  |                                                                     |
| UCAS            | -                |                                                                     |
| X2              | -                |                                                                     |
| IC              | -                | Connect this pin to GND via a resistor.                             |

# **Phase-out/Discontinued**

#### 2.5 PIN I/O CIRCUITS





[MEMO]



#### **CHAPTER 3 CPU FUNCTIONS**

The CPU has functions equivalent to those of the V810 microprocessor, designed for built-in control. It offers bit string instructions, floating-point instructions, and quick real-time response.

#### 3.1 FEATURES

The features of the CPU are:

- High-performance 32-bit RISC microprocessor
  - Built-in 1-Kbyte cache memory
  - 1-clock-pulse pitch pipeline structure
  - 16-bit data bus
  - 32-bit general-purpose register x 32
  - 4-Gbyte linear address space
- Instruction groups suitable for a wide range of applications
  - Floating-point instructions (conforming to the IEEE754 data format)
  - Bit string instructions
- High-speed interrupt response
- Debug support functions

#### 3.2 ADDRESS SPACE

The V821 supports internal memory and I/O spaces of 4 Gbytes each. The V821 outputs 24-bit addresses to memory and I/O, such that the addresses range from 0 to 2<sup>24</sup>-1.

In byte data, bit 0 is defined as the LSB (Least Significant Bit) and bit 7 as the MSB (Most Significant Bit). In multiple-byte data, bit 0 of the byte data in the lower address is defined as the LSB and bit 7 of the byte data in the upper address as the MSB, unless noted otherwise.

In the case of the V821, 2-byte data is referred to as halfword data, and 4-byte data as word data. In this manual, in representations of multiple-byte memory and I/O data, the right address corresponds to the lower address and the left address to the upper address, as shown below.



#### 3.2.1 Memory Map

Figure 3-1 shows the memory map of the V821.

The internal 4-Gbyte memory space is divided into blocks of 1 Gbyte each.

Each block has a linear address space of 16 Mbytes. (The lower 24 bits of a 32-bit address are output.)



Figure 3-1. Memory Map

Note See Table 4-1 for details.

#### 3.2.2 I/O Map

Figure 3-2 shows the I/O map of the V821.

The internal 4-Gbyte memory space is divided into blocks of 1 Gbyte each.

Each block has a linear address space of 16 Mbytes. (The lower 24 bits of a 32-bit address are output.)

The V821 reserves I/O addresses C0000000H-FFFFFFFH (I/O block 3) as an internal I/O space. Each unit is mapped to this internal I/O space.

See Section 3.4 for details of the configuration of the internal I/O space.



#### Figure 3-2. I/O Map

#### 3.2.3 Images

The 4-Gbyte memory and I/O spaces are each divided into four blocks of 1 Gbyte each. Each block is selected with the  $\overline{CS}$  signal. (See **Chapter 6**.)

Each block has a linear address space of 16 Mbytes. In one block, a 16-Mbyte physical address space is regarded as being 64 images. Thus, irrespective of the values of bits 29-24 of an address, the same 16-Mbyte physical address space is accessed. Figure 3-3 illustrates images in an address space.

The 32-bit memory address in memory block 0 is used as a 24-bit physical address, the upper 8 bits being ignored. Thus, physical address xx000000H can be regarded not only as memory address 00000000H but also as 01000000H, 02000000H, ..., 3E000000H, and 3F000000H.





Phase-out/Discontinued

#### 3.2.4 Differences between the Memory and I/O Maps

The memory and I/O maps differ in the control procedure that is applied when access is performed. If an interrupt occurs during read access (LD instruction) to the memory map, the interrupt takes precedence and the data read by executing the LD instruction may be nullified. The LD instruction may, therefore, need to be reexecuted upon the completion of interrupt handling.

If an interrupt occurs during read access (IN instruction) to the I/O map, the read access takes precedence. The IN instruction will not, therefore, be executed after the completion of interrupt handling.

For the above reason, any devices that are cleared by read operations (such as the read buffer in the serial controller) and those that are updated depending on the read count must be placed in the I/O map, not the memory map.

#### 3.3 CPU REGISTER SET

The registers of the V821 belong to one of two sets, the general-purpose program register set and the dedicated system register set. All registers are 32 bits in wide.

| Program register set |                                 |    |  |  |
|----------------------|---------------------------------|----|--|--|
| 31                   |                                 | 0  |  |  |
| r0                   | Zero Register                   |    |  |  |
| r1                   | Reserved for Address Generation | on |  |  |
| r2                   | Handler Stack Pointer (hp)      |    |  |  |
| r3                   | Stack Pointer (sp)              |    |  |  |
| r4                   | Global Pointer (gp)             |    |  |  |
| r5                   | Text Pointer (tp)               |    |  |  |
| r6                   |                                 |    |  |  |
| r7                   |                                 |    |  |  |
| r8                   |                                 |    |  |  |
| r9                   |                                 |    |  |  |
| r10                  |                                 |    |  |  |
| r11                  |                                 |    |  |  |
| r12                  |                                 |    |  |  |
| r13                  |                                 |    |  |  |
| r14                  |                                 |    |  |  |
| r15                  |                                 |    |  |  |
| r16                  |                                 |    |  |  |
| r17                  |                                 |    |  |  |
| r18                  |                                 |    |  |  |
| r19                  |                                 |    |  |  |
| r20                  |                                 |    |  |  |
| r21                  |                                 |    |  |  |
| r22                  |                                 |    |  |  |
| r23                  |                                 |    |  |  |
| r24                  |                                 |    |  |  |
| r25                  |                                 |    |  |  |
| r26                  | String Destination Bit Offset   |    |  |  |
| r27                  | String Source Bit Offset        |    |  |  |
| r28                  | String Length                   |    |  |  |
| r29                  | String Destination              |    |  |  |
| r30                  | String Source                   |    |  |  |
| r31                  | Link Pointer (lp)               |    |  |  |
| 31                   |                                 | 0  |  |  |

#### System register set

| 31    |                          | 0 |
|-------|--------------------------|---|
| EIPC  | Exception/Interrupt PC   |   |
| EIPSW | Exception/Interrupt PSW  |   |
| 31    |                          | 0 |
| FEPC  | Fatal Error PC           |   |
| FEPSW | Fatal Error PSW          |   |
| 31    |                          | 0 |
| ECR   | Exception Cause Register |   |
| 31    |                          | 0 |
| PSW   | Program Status Word      |   |
| 31    |                          | 0 |
| PIR   | Processor ID Register    |   |
| 31    |                          | 0 |
| TKCW  | Task Control Word        |   |
| 31    |                          | 0 |
| CHCW  | Cache Control Word       |   |
| 31    |                          | 0 |
| ADTRE | Address Trap Register    |   |

31 ( PC Program Counter

#### 3.3.1 Program Register Set

The program register set includes general-purpose registers and a program counter.

#### (1) General-purpose registers

The V821 has 32 general-purpose registers, r0-r31. These registers can be used for data or address variables.

Registers r0 and r26-r30 are used implicitly with instructions. Caution is therefore necessary when using these registers. Registers r1-r5 and r31 are used implicitly by the assembler and the C compiler. Before using these registers, therefore, the contents of the registers must be saved to prevent their being destroyed. After using the registers, their contents must be restored.

| Name   | Use                                       | Explanation                                                                    |
|--------|-------------------------------------------|--------------------------------------------------------------------------------|
| r0     | Zero register                             | Always stores zeros.                                                           |
| r1     | Assembler-reserved register               | Used as a working register to create 32-bit immediate.                         |
| r2     | Handler stack pointer                     | Used as a stack pointer for the handler.                                       |
| r3     | Stack pointer                             | Used to create a stack frame at a function call.                               |
| r4     | Global pointer                            | Used to access a global variable in a data area.                               |
| r5     | Text pointer                              | Points to the top of a text area                                               |
| r6-r25 | -                                         | Register for an address/data variable                                          |
| r26    | String destination start bit offset       | Used to execute a bit string instruction.                                      |
| r27    | String source start bit offset            |                                                                                |
| r28    | String length register                    |                                                                                |
| r29    | String destination start address register |                                                                                |
| r30    | String start address register             |                                                                                |
| r31    | Link pointer                              | Stores a return point address according to the execution of a JAL instruction. |

#### Table 3-1. Program Registers

#### (2) Program counter

Stores the address of an instruction while a program is running. Bit 0 of the program counter (PC) is fixed to 0, thus preventing a branch to an odd address. It is initialized to FFFFFF0H at reset.



#### 3.3.2 System Register Set

System registers are used to control the state of the CPU and store interrupt information.

| No.   | Register name | Use                                                                                            | Explanation                                                                                                                                                                                                                                                                               |
|-------|---------------|------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | EIPC          | Registers for saving the current<br>status upon the occurrence of an<br>exception or interrupt | Retain the contents of PC and PSW if an exception or interrupt occurs. Note, however, that there is only one pair of these registers.                                                                                                                                                     |
| 1     | EIPSW         |                                                                                                | When multiple interrupts are allowed,<br>therefore, the contents of the registers must<br>be saved by the program.                                                                                                                                                                        |
| 2     | FEPC          | Registers for saving the current                                                               | Retain the contents of PC and PSW if an                                                                                                                                                                                                                                                   |
| 3     | FEPSW         | status upon the occurrence of an NMI or double exception                                       | NMI or double exception occurs.                                                                                                                                                                                                                                                           |
| 4     | ECR           | Exception source register                                                                      | Stores the source of an exception, maskable<br>interrupt, or NMI. The upper 16 bits of this<br>register are called "FECC" and set to the<br>exception code of an NMI/double exception.<br>The lower 16 bits are called "EICC" and set to<br>the exception code of an exception/interrupt. |
| 5     | PSW           | Program status word                                                                            | The program status word is a set of flags<br>indicating the state of the program (result of<br>executing an instruction) and the state of the<br>CPU.                                                                                                                                     |
| 6     | PIR           | Processor ID register                                                                          | Used to identify a CPU type number.                                                                                                                                                                                                                                                       |
| 7     | TKCW          | Task control word                                                                              | Used to control a floating-point operation.                                                                                                                                                                                                                                               |
| 8-23  | Reserved      |                                                                                                |                                                                                                                                                                                                                                                                                           |
| 24    | СНСМ          | Cache control word                                                                             | Used to control the built-in instruction cache.                                                                                                                                                                                                                                           |
| 25    | ADTRE         | Address trap register                                                                          | Stores the address used to detect an address match with PC, and to generate an address trap.                                                                                                                                                                                              |
| 26-31 | Reserved      |                                                                                                |                                                                                                                                                                                                                                                                                           |

#### Table 3-2. System Register Numbers

Read and write operations made to these system registers can be performed using the system register load/ store instructions (LDSR and STSR) with the system register numbers specified.

#### 3.4 BUILT-IN PERIPHERAL I/O REGISTERS

The built-in peripheral I/O registers are allocated to the 256-byte area between C0000000H and C00000FFH in the 1-Gbyte space between C0000000H and FFFFFFFH. Starting from address C0000100H, 256-byte images are created every 256 bytes.

The least significant bit of an address is not decoded. Thus, when byte access is attempted to a register at an odd address (2n+1), a register at an even address (2n) is actually performed.

When 16-bit access is attempted to an 8-bit I/O register, the upper eight bits are ignored for write, and become undefined for read.

Table 3-3 lists the built-in peripheral I/O registers.

| Address  | Function register name               | Abbreviation | Manipulatable bits |        | Initial value |  |
|----------|--------------------------------------|--------------|--------------------|--------|---------------|--|
|          |                                      |              | 8-bit              | 16-bit |               |  |
| C0000010 | Port mode control register 0         | PMC0         |                    | 0      | 0000H         |  |
| C0000012 | Port mode register 0                 | PM0          |                    | 0      | 03FFH         |  |
| C0000014 | Port register 0                      | P0           |                    | 0      | Not defined   |  |
| C0000020 | Bus cycle type control register      | BCTC         | 0                  |        | 01H           |  |
| C0000022 | Programmable wait control register 0 | PWC0         | 0                  |        | 77H           |  |
| C0000024 | Programmable wait control register 1 | PWC1         | 0                  |        | 77H           |  |
| C0000026 | Programmable wait control register 2 | PWC2         | 0                  |        | 77H           |  |
| C0000028 | DRAM configuration register          | DRC          | 0                  |        | 81H           |  |
| C000002A | Refresh control register             | RFC          | 0                  |        | 80H           |  |
| C000002C | Page-ROM configuration register      | PRC          | 0                  |        | 80H           |  |
| C0000040 | DMA source address register 0H       | DSA0H        |                    | 0      | Not defined   |  |
| C0000042 | DMA source address register 0L       | DSA0L        |                    | 0      | Not defined   |  |
| C0000044 | DMA destination address register 0H  | DDA0H        |                    | 0      | Not defined   |  |
| C0000046 | DMA destination address register 0L  | DDA0L        |                    | 0      | Not defined   |  |
| C0000048 | DMA source address register 1H       | DSA1H        |                    | 0      | Not defined   |  |
| C000004A | DMA source address register 1L       | DSA1L        |                    | 0      | Not defined   |  |
| C000004C | DMA destination address register 1H  | DDA1H        |                    | 0      | Not defined   |  |
| C000004E | DMA destination address register 1L  | DDA1L        |                    | 0      | Not defined   |  |
| C0000050 | DMA byte count register 0            | DBC0         |                    | 0      | Not defined   |  |
| C0000052 | DMA byte count register 1            | DBC1         |                    | 0      | Not defined   |  |
| C0000054 | DMA channel control register 0       | DCHC0        |                    | 0      | 0000H         |  |
| C0000056 | DMA channel control register 1       | DCHC1        |                    | 0      | 0000H         |  |

#### Table 3-3. Built-in Peripheral I/O Registers (1/2)



| Address  | Function register name                        | Abbreviation | Manipulatable bits |        | Initial value |
|----------|-----------------------------------------------|--------------|--------------------|--------|---------------|
|          |                                               |              | 8-bit              | 16-bit |               |
| C0000060 | Timer unit mode register 0                    | TUM0         |                    | 0      | 0A00H         |
| C0000062 | Timer control register 0                      | TMC0         | 0                  |        | 00H           |
| C0000064 | Timer control register 1                      | TMC1         | 0                  |        | 00H           |
| C0000066 | Timer output control register 0               | ТОС0         | 0                  |        | 03H           |
| C0000068 | Timer overflow status register                | TOVS         | 0                  |        | 00H           |
| C0000070 | Timer register 0                              | ТМО          |                    | 0      | 0000H         |
| C0000072 | Capture/compare register 00                   | CC00         |                    | 0      | Not defined   |
| C0000074 | Capture/compare register 01                   | CC01         |                    | 0      | Not defined   |
| C0000076 | Capture/compare register 02                   | CC02         |                    | о      | Not defined   |
| C0000078 | Capture/compare register 03                   | CC03         |                    | о      | Not defined   |
| C000007C | Timer register 1                              | TM1          |                    | о      | 0000H         |
| C000007E | Compare register 1                            | CM1          |                    | о      | Not defined   |
| C0000080 | Asynchronous serial interface mode register   | ASIM         | 0                  |        | 00H           |
| C0000082 | Asynchronous serial interface status register | ASIS         | 0                  |        | 00H           |
| C0000084 | Reception buffer                              | RXB          |                    | ο      | Not defined   |
| C000086  | Reception buffer L                            | RXBL         | о                  |        | Not defined   |
| C0000088 | Transmission shift register                   | TXS          |                    | о      | Not defined   |
| C00008A  | Transmission shift register L                 | TXSL         | о                  |        | Not defined   |
| C0000090 | Synchronous serial interface mode register    | CSIM         | о                  |        | 00H           |
| C0000092 | Serial I/O shift register                     | SIO          | о                  |        | Not defined   |
| C00000A0 | Baud rate generator register                  | BRG          | о                  |        | Not defined   |
| C00000A2 | Baud rate generator prescale mode register    | BPRM         | 0                  |        | 00H           |
| C00000B0 | Interrupt group priority register             | IGP          | о                  |        | E4H           |
| C00000B2 | Interrupt clear register                      | ICR          |                    | о      | 0000H         |
| C00000B4 | Interrupt request register                    | IRR          |                    | 0      | 0000H         |
| C00000B6 | Interrupt request mask register               | IMR          |                    | 0      | FFFFH         |
| C00000B8 | ICU mode register                             | IMOD         |                    | 0      | ААААН         |
| C00000C0 | WDT mode register                             | WDTM         | 0                  |        | 00H           |
| C00000D0 | Standby control register                      | STBC         | 0                  |        | 00H           |
| C00000E0 | Clock control register                        | CGC          | о                  |        | 03H           |

#### Table 3-3. Built-in Peripheral I/O Registers (2/2)



[MEMO]



#### **CHAPTER 4 INTERRUPT/EXCEPTION HANDLING FUNCTIONS**

The V821 features an interrupt controller (ICU) that is dedicated to interrupt handling. The V821 thus supports a powerful interrupt handling function capable of handling interrupt requests issued by up to 16 sources.

As referred to in this manual, an interrupt is an event which occurs independently of program execution while an exception is an event that depends on program execution. In general, an exception assumes a higher priority than an interrupt.

The V821 can handle interrupt requests issued by both built-in peripheral hardware and external devices. Exception handling can be triggered by executing an instruction (TRAP instruction) as well as by the occurrence of an exception (such as an address trap or invalid instruction code).

#### 4.1 FEATURES

- Interrupts
  - Nonmaskable interrupt : 1 source
  - Maskable interrupt : 15 sources
  - Programmable priority control with four groups
  - Multiple interrupt handling control according to priority
  - · Mask specification for each maskable interrupt request
  - Valid edge specification for external interrupt requests
  - The noise eliminator introducing an analog delay (60 to 300 ns) is incorporated into the nonmaskable interrupt (MMI) pin.
- Exceptions
  - Software exception : 32 sources
  - Exception trap : 10 sources

Table 4-1 lists the interrupt and exception sources.

| Туре             | Category  | Group | Priority | Interrupt/exception source |                                                       |                          | Exception | Handler                              | Return                          |       |          |          |  |
|------------------|-----------|-------|----------|----------------------------|-------------------------------------------------------|--------------------------|-----------|--------------------------------------|---------------------------------|-------|----------|----------|--|
|                  |           |       | in group | Name                       | Source                                                | Unit                     | code      | address                              | PCNote 1                        |       |          |          |  |
| Reset            | Interrupt | -     | -        | RESET                      | Reset input                                           | -                        | FFF0H     | FFFFFFF0H                            | Undefined                       |       |          |          |  |
| Non-<br>maskable | Interrupt | -     | -        | NMI                        | NMI input                                             | -                        | FFD0H     | FFFFFFD0H                            | Next<br>PCNote 2                |       |          |          |  |
| Software         | Exception | -     | -        | TRAP1nH                    | trap instruction                                      | -                        | FFBnH     | FFFFFFB0H                            | Next PC                         |       |          |          |  |
| exception        |           | -     | -        | TRAP0nH                    | trap exception                                        | -                        | FFAnH     | FFFFFFA0H                            | Next PC                         |       |          |          |  |
| Exception        | Exception | -     | -        | DP-EX                      | Double exception                                      | -                        | Note 3    | FFFFFFD0H                            | PC                              |       |          |          |  |
| trap             |           | -     | -        | AD-TR                      | Address trap                                          | -                        | FFC0H     | FFFFFFC0H                            |                                 |       |          |          |  |
|                  |           |       | -        | -                          | I-OPC                                                 | Invalid instruction code | -         | FF90H                                | FFFFF90H                        |       |          |          |  |
|                  |           |       | -        | -                          | DIV0                                                  | Division by zero         | -         | FF80H                                | FFFFFF80H                       |       |          |          |  |
|                  |           |       |          |                            | -                                                     | -                        | FIZ       | Invalid floating-<br>point operation | -                               | FF70H | FFFFF60H |          |  |
|                  |           |       |          |                            |                                                       | -                        | -         | FZD                                  | Floating-point division by zero | -     | FF68H    | FFFFF60H |  |
|                  |           |       |          |                            | -                                                     | -                        | FOV       | Floating-point overflow              | -                               | FF64H | FFFFF60H |          |  |
|                  |           | -     | -        | FUD                        | Floating-point<br>underflow <b>Note 4</b>             | -                        | FF62H     | FFFFF60H                             |                                 |       |          |          |  |
|                  |           | -     | -        | FPR                        | Floating-point<br>degraded<br>precision <b>Note 4</b> | -                        | FF61H     | FFFFF60H                             |                                 |       |          |          |  |
|                  |           | -     | -        | FRO                        | Floating-point reserved operand                       | -                        | FF60H     | FFFFF60H                             |                                 |       |          |          |  |

| Table 4-1. | Interrupts | (1/2) |
|------------|------------|-------|
|------------|------------|-------|

#### Remark n = 0H to FH

- Notes 1. PC value saved in EIPC or FEPC at the beginning of interrupt/exception handling
  - 2. Return PC = current PC if an interrupt occurred during the execution of an instruction which was stopped by an interrupt (DIV/DIVU, floating-point, and bit string instructions).
  - **3.** The exception code for the exception which occurred first is written into in the 16 low-order bits of ECR, while and that for the second exception is written into the 16 high-order bits.
  - 4. The V821 is not subject to floating-point underflow or degraded precision exceptions.

# CHAPTER 4 INTERRU Phase-out/Discontinued

| Table 4-1. | Interrupts | (2/2) |
|------------|------------|-------|
|------------|------------|-------|

| Туре     | Category  | Group | -        | Interrupt/exception source |                                        |                  | Exception           | Handler   | Return   |           |
|----------|-----------|-------|----------|----------------------------|----------------------------------------|------------------|---------------------|-----------|----------|-----------|
|          |           |       | in group | Name                       | Source                                 | Unit             | code                | address   | PCNote 1 |           |
| Maskable | Interrupt | GR3   | 3        | RESERVED                   | Reserved                               | -                | FEF0H               | FFFFFEF0H |          |           |
|          |           |       | 2        | INTOV0                     | Timer 0<br>overflow                    | RPU              | FEE0H               | FFFFFEE0H | PCNote 2 |           |
|          |           |       | 1        | INTSER                     | UART recep-<br>tion error              | UART             | FED0H               | FFFFFED0H |          |           |
|          |           |       | 0        | INTP13                     | INTP13 pin<br>input                    | External         | FEC0H               | FFFFFEC0H |          |           |
|          |           | GR2   | 3        | INTSR                      | UART recep-<br>tion end                | UART             | FEB0H               | FFFFEB0H  |          |           |
|          |           |       | 2        | INTST                      | UART trans-<br>mission end             | UART             | FEA0H               | FFFFFEA0H |          |           |
|          |           |       | 1        | INTCSI                     | CSI transmis-<br>sion/reception<br>end | CSI              | FE90H               | FFFFFE90H |          |           |
|          |           |       | 0        | INTP12                     | INTP12 pin<br>input                    | External         | FE80H               | FFFFFE80H |          |           |
|          |           | GR1   | 3        | INTDMA                     | DMA transfer<br>end                    | DMAC             | FE70H               | FFFFFE70H |          |           |
|          |           |       | 2        | INTP00/<br>INTCC00         | INTP00 pin<br>input/CC00<br>match      | External/<br>RPU | FE60H               | FFFFE60H  |          |           |
|          |           |       | 1        | INTP01/<br>INTCC01         | INTP01 pin<br>input/CC01<br>match      | External/<br>RPU | FE50H               | FFFFFE50H |          |           |
|          |           |       |          |                            | 0                                      | INTP11           | INTP11 pin<br>input | External  | FE40H    | FFFFFE40H |
|          |           | GR0   | 3        | INTCM1                     | CM1 match                              | RPU              | FE30H               | FFFFFE30H |          |           |
|          |           |       | 2        | INTP02/<br>INTCC02         | INTP02 pin<br>input/CC02<br>match      | External/<br>RPU | FE20H               | FFFFFE20H |          |           |
|          |           |       | 1        | INTP03/<br>INTCC03         | INTP03 pin<br>input/CC03<br>match      | External/<br>RPU | FE10H               | FFFFFE10H |          |           |
|          |           |       | 0        | INTP10                     | INTP10 pin<br>input                    | External         | FE00H               | FFFFFE00H |          |           |

Notes 1. PC value saved in EIPC or FEPC at the beginning of interrupt/exception handling

2. Return PC = current PC if an interrupt occurred during the execution of an instruction which was stopped by an interrupt (DIV/DIVU, floating-point, and bit string instructions).

Caution The exception code and handler address for a maskable interrupt assume the values existing when the default priority is specified. Table 4-2 lists the values in the order of their priorities.

#### 4.2 NONMASKABLE INTERRUPTS

A nonmaskable interrupt request is accepted unconditionally, even in the interrupt disabled (DI) state (PSW.ID = 1). Interrupt priority control is not applied to nonmaskable interrupt requests, which always take the highest priority.

Nonmaskable interrupt requests are input to the  $\overline{NMI}$  pin. Because  $\overline{NMI}$  is a level-input pin, the input must be maintained until it can be confirmed that control has branched to the handler and that the request has been accepted.

During the execution of the service program for a nonmaskable interrupt (PSW.NP = 1), nonmaskable interrupt requests are not accepted and instead enter pending status. Pending nonmaskable interrupt requests are accepted only once the execution of the current service program has been completed (after the execution of the RETI instruction) or by setting PSW.NP to 0 by using the LDSR instruction.

The noise eliminator introducing an analog delay (60 to 300 ns) is used for input of a nonmaskable interrupt request. Using this noise eliminator prevents the nonmaskable interrupt request from being received mistakenly when noise having a fine pulse width as shown in Figure 4-1 enters.





deactivate the NMI pin after confirming the reception of the nonmaskable interrupt request.

Phase-out/Discontinued

#### 4.2.1 Operation

Once a nonmaskable interrupt request has been input to the  $\overline{NMI}$  pin, the CPU performs the following processing, then passes control to the handler routine.

- (1) Saves the return PC into FEPC.
- (2) Saves the current PSW into FEPSW.
- (3) Writes exception code FFD0H into the 16 high-order bits of ECR (FECC).
- (4) Sets the NP and ID bits of PSW and clears the AE bit.
- (5) Sets the nonmaskable interrupt handler address (FFFFFD0H) in the PC, thus passing control to the handler routine.

Figure 4-2 illustrates the nonmaskable interrupt handling procedure.



Figure 4-2. Nonmaskable Interrupt Handling Procedure

#### Figure 4-3. Accepting a Nonmaskable Interrupt Request

When a new NMI request is input during the execution of the NMI service program



#### 4.3 MASKABLE INTERRUPTS

An interrupt request for which acceptance can be masked (disabled), by setting the corresponding bit of the interrupt request mask register, is called a maskable interrupt request. The V821 supports 15 maskable interrupt sources.

When two or more maskable interrupt requests are issued at the same time, they are handled in the order of their default priorities. In addition to the default priority, a group interrupt priority can be specified for each of the four groups, by using the interrupt group priority register (IGP) (the priority of each interrupt within a group is fixed).

A maskable interrupt is masked according to the logical sum of the NP, EP, and ID bits of PSW. Interrupt level n for a maskable interrupt is specified by the  $\overline{INTV0}$  to  $\overline{INTV3}$  signals and sent to the CPU. The maskable interrupt is not accepted if n is lower than the interrupt enable level specified in PSW (I0 to I3). An interrupt of the highest interrupt level (n = 15), cannot, therefore, be disabled by specifying the interrupt enable level.

Once an interrupt request has been accepted, the system enters the interrupt disabled state (PSW.ID = 1), thus disabling the acceptance of subsequent maskable interrupt requests. Then, the accepted interrupt level (n) plus one (n + 1) is set in the I0 to I3 bits of PSW.

When enabling multiple interrupts, save the contents of EIPC and EIPSW into memory or registers, then specify the interrupt enabled state (PSW.ID = 0, EP = 0). After the completion of interrupt handling, specify the interrupt disabled state (PWS.ID = 1) before executing the RETI instruction, which restores EIPC and EIPSW.

#### 4.3.1 Block Diagram



#### Figure 4-4. Maskable Interrupts

## CHAPTER 4 INTERRU Phase-out/Discontinued

#### 4.3.2 Operation

Once a maskable interrupt has been issued by using an INT input, the CPU performs the following processing, then passes control to the handler routine.

- (1) Saves the return PC into EIPC.
- (2) Saves the current PSW into EIPSW.
- (3) Writes the exception code into the 16 low-order bits of ECR (EICC).
- (4) Sets the EP and ID bits of PSW and clears the AE bit.
- (5) Sets the accepted interrupt level (n) plus one (n + 1) in the I field (I0 to I3 bits) of PSW. When the accepted interrupt level is of the highest level (n = 15), however, sets 15.
- (6) Sets the handler address for the interrupt in the PC, thus passing control to the handler routine.

Figure 4-5 shows the maskable interrupt handling procedure.





Figure 4-5. Maskable Interrupt Handling Procedure

### CHAPTER 4 INTERRU Phase-out/Discontinued

#### 4.3.3 Maskable Interrupt Priority

While handling one interrupt, the V821 can accept a second interrupt (multiple interrupt handling). Multiple interrupt handling is controlled based on the interrupt priorities.

Priority control is classified into either that based on the default priorities (default priority control) or that based on the settings of the interrupt group priority register (programmable priority control). When default priority control is applied, the V821 handles two or more simultaneously requested interrupts according to the default priority of each interrupt request group (a group consists of four interrupt requests) (see **Table 4-1**). Programmable priority control is applied by specifying a priority (0, 1, 2, or 3) for each interrupt request group, using the interrupt group priority control register. The priority of each interrupt within a group is, however, fixed.

Once an interrupt request has been accepted, the ID and EP flags of PSW are automatically set to 1. Therefore, when performing multiple interrupt handling, enable interrupts (by specifying PSW.ID = 0 and PSW.EP = 0) in the interrupt handling program.

Maskable interrupt or exception service program

| <br><br>• Save EIPC into memory or a register.            |                                                                     |
|-----------------------------------------------------------|---------------------------------------------------------------------|
| <ul> <li>Save EIPSW into memory or a register.</li> </ul> |                                                                     |
| • Enable interrupt acceptance (PSW.ID = 0, PSW.EP = 0).   |                                                                     |
|                                                           |                                                                     |
|                                                           | <ul> <li>Accept an interrupt, such as an<br/>INTP input.</li> </ul> |
|                                                           | INTE Input.                                                         |
|                                                           |                                                                     |
| • Disable interrupt acceptance (PSW.ID = 1, PSW.EP = 1).  |                                                                     |
| Restore EIPSW.                                            |                                                                     |
| Restore EIPC.                                             |                                                                     |
| • Execute the RETI instruction.                           |                                                                     |
|                                                           |                                                                     |

#### 4.4 CONTROL REGISTERS

#### 4.4.1 Interrupt Group Priority Register (IGP)

This register is used to specify the priority of each interrupt request group. **Table 4-2** lists the correspondence between each priority and the exception code and handler address of each interrupt in the group (when the IGP register is set to 4EH).

This register can be read/written in 8-bit units.



| Bit position | Bit name | Description                                                                                                       |          |   |   |   |  |  |
|--------------|----------|-------------------------------------------------------------------------------------------------------------------|----------|---|---|---|--|--|
| 7-0          | PR3-PR0  | Group Priority<br>Specifies the priority for interrupt group n (GRn). 0 is the lowest priori<br>3 is the highest. |          |   |   |   |  |  |
|              |          |                                                                                                                   | Priority |   |   |   |  |  |
|              |          | 0 0                                                                                                               |          |   | 0 | 7 |  |  |
|              |          | 0         1         1           1         0         2                                                             |          | 1 | 1 |   |  |  |
|              |          |                                                                                                                   |          | 2 |   |   |  |  |
|              |          | 1 1 3                                                                                                             |          |   |   |   |  |  |
|              |          | n = 0-3                                                                                                           | 3        |   |   |   |  |  |

Caution Do not specify the same priority for multiple groups. Otherwise, interrupt handling will be unpredictable.

### Table 4-2. Correspondence between Priorities, Exception Codes, Handler Addresses, and Interrupt Levels (When the IGP Register Is Set to 4EH)

| IGP re<br>setting<br>Bit | egister<br>g<br>Value | Group   | Priority of the group | Priority within<br>the group<br>(fixed) | Name of the<br>interrupt/exception<br>source | Exception code | Handler<br>address | Interrupt level |       |           |
|--------------------------|-----------------------|---------|-----------------------|-----------------------------------------|----------------------------------------------|----------------|--------------------|-----------------|-------|-----------|
| PR1                      | 11                    | GR1     | 3                     | 3                                       | INTDMA                                       | FEFOH          | FFFFFEF0H          | 15 (Highest)    |       |           |
|                          |                       | ORT     | 5                     | 2                                       |                                              | FEE0H          | FFFFFEE0H          | 14              |       |           |
|                          |                       |         |                       | 1                                       | INTP01/INTCC01                               | FED0H          | FFFFFED0H          | 13              |       |           |
|                          |                       |         |                       | 0                                       | INTP11                                       | FEC0H          | FFFFFEC0H          | 12              |       |           |
| PR0                      | 10                    | GR0     | 2                     | 3                                       | INTCM1                                       | FEB0H          | FFFFFEB0H          | 11              |       |           |
|                          |                       |         | 2                     | INTP02/INTCC02                          | FEA0H                                        | FFFFFEA0H      | 10                 |                 |       |           |
|                          |                       |         | 1                     | INTP03/INTCC03                          | FE90H                                        | FFFFFE90H      | 9                  |                 |       |           |
|                          |                       |         | 0                     | INTP10                                  | FE80H                                        | FFFFFE80H      | 8                  |                 |       |           |
| PR3                      | 01                    | I GR3 1 | 1                     | 3                                       | RESERVED                                     | FE70H          | FFFFFE70H          | 7               |       |           |
|                          |                       |         |                       |                                         |                                              |                | 2                  | INTOV0          | FE60H | FFFFFE60H |
|                          |                       |         |                       |                                         | 1                                            | INTSER         | FE50H              | FFFFFE50H       | 5     |           |
|                          |                       |         |                       | 0                                       | INTP13                                       | FE40H          | FFFFFE40H          | 4               |       |           |
| PR2                      | PR2 00 GR2            | GR2 0   | 3                     | INTSR                                   | FE30H                                        | FFFFFE30H      | 3                  |                 |       |           |
|                          |                       |         | 2                     | INTST                                   | FE20H                                        | FFFFFE20H      | 2                  |                 |       |           |
|                          |                       |         | 1                     | INTCSI                                  | FE10H                                        | FFFFFE10H      | 1                  |                 |       |           |
|                          |                       |         |                       | 0                                       | INTP12                                       | FE00H          | FFFFFE00H          | 0 (Lowest)      |       |           |

#### 4.4.2 Interrupt Clear Register (ICR)

This register is used to clear interrupt requests. **Table 4-3** lists the correspondence between each bit and interrupt request. This register can be written in 16-bit units.



| Bit position | Bit name   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|--------------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 14-0         | CLR14-CLR0 | Clear interrupt request<br>Setting a bit of this register to 1 clears the corresponding interrupt request<br>(the REQn bit of the IRR register). This register, however, cannot be used to<br>clear interrupt requests in level trigger mode.<br>This is a write-only register. Attempting to read this register always results in<br>0 being read, regardless of its actual value.<br>0: No operation<br>1: Clears the REQn bit of the IRR register. |

#### 4.4.3 Interrupt Request Register (IRR)

This register holds interrupt requests. **Table 4-3** indicates the correspondence between each bit and the interrupt requests. This register can be read in 16-bit units.



| Bit position | Bit name   | Description                                                                                                                                                                                                                                                                                                                                                                   |
|--------------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 14-0         | REQ14-REQ0 | Interrupt Request<br>Once an interrupt request has been issued, the corresponding bit of this<br>register is set, regardless of the mask register setting. For edge-detected<br>interrupts, manipulating the ICR register resets the relevant bits.<br>0: The corresponding interrupt request has not been issued.<br>1: The corresponding interrupt request has been issued. |

# CHAPTER 4 INTERRU Phase-out/Discontinued

#### 4.4.4 Interrupt Request Mask Register (IMR)

This register is used to mask interrupt requests. **Table 4-3** indicates the correspondence between each bit and the interrupt requests. This register can be read/written in 16-bit units.



| Bit position | Bit name   | Description                                                                                                                                                                                                                                                                                                                    |
|--------------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 14-0         | MSK14-MSK0 | <ul> <li>Mask interrupt request</li> <li>Setting a bit of this register to 1 masks the corresponding interrupt request.</li> <li>An interrupt request can be masked only before it is issued.</li> <li>0: Does not mask the corresponding interrupt request.</li> <li>1: Masks the corresponding interrupt request.</li> </ul> |

#### Table 4-3. Correspondence between Interrupt Control Register Bits and Interrupt Request Signals

| ICR register bit | IRR register bit | IMR register bit | Interrupt request<br>signal |
|------------------|------------------|------------------|-----------------------------|
| CLR14            | REQ14            | MSK14            | INTOV0                      |
| CLR13            | REQ13            | MSK13            | INTSER                      |
| CLR12            | REQ12            | MSK12            | INTP13                      |
| CLR11            | REQ11            | MSK11            | INTSR                       |
| CLR10            | REQ10            | MSK10            | INTST                       |
| CLR9             | REQ9             | MSK9             | INTCSI                      |
| CLR8             | REQ8             | MSK8             | INTP12                      |
| CLR7             | REQ7             | MSK7             | INTDMA                      |
| CLR6             | REQ6             | MSK6             | INTP00/INTCC00              |
| CLR5             | REQ5             | MSK5             | INTP01/INTCC01              |
| CLR4             | REQ4             | MSK4             | INTP11                      |
| CLR3             | REQ3             | MSK3             | INTCM1                      |
| CLR2             | REQ2             | MSK2             | INTP02/INTCC02              |
| CLR1             | REQ1             | MSK1             | INTP03/INTCC03              |
| CLR0             | REQ0             | MSK0             | INTP10                      |

#### 4.4.5 ICU Mode Register (IMOD)

This register is used to specify the trigger mode for external interrupt requests INTP00 to INTP03 and INTP10 to INTP13, each of which is input to the pin having the same name. There are two trigger modes: level trigger and edge trigger.

#### (1) Level trigger

Interrupts are sampled at each clock. An interrupt request signal must remain at the active level until the request is recognized by the interrupt handler of the CPU. If an interrupt request is canceled before it can be recognized, an error may occur, such as an undefined branch destination vector.

#### (2) Edge trigger

Interrupts are sampled at the rising edge of each clock. When an interrupt request signal changes at a clock rising edge, as specified with the IMOD register, the request is accepted. If identical interrupt requests are input consecutively, only one is recognized.

Internal interrupts are also edge-detected. To use external interrupt requests, clear the corresponding bits of the interrupt request register (IRR) in the interrupt handling routine.

This register can be read/written in 16-bit units.

|      | 15 14 | 13 12 | 11 10 | 98    | 76    | 54    | 3 2   | 1 0   |                      |                      |
|------|-------|-------|-------|-------|-------|-------|-------|-------|----------------------|----------------------|
| IMOD | ITM13 | ITM12 | ITM11 | ITM10 | ITM03 | ITM02 | ITM01 | ITM00 | Address<br>C00000B8H | When reset,<br>AAAAH |

| Bit position                  | Bit name                   |                                                                                                                                                                 | Description       |                                                    |                      |  |  |  |
|-------------------------------|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|----------------------------------------------------|----------------------|--|--|--|
| 15-0                          | ITM13-ITM10<br>ITM03-ITM00 | Interrupt Trigger Mode<br>Specifies the trigger mode for the INTPn pin. The trigger mode can be<br>changed only before input of the relevant interrupt request. |                   |                                                    |                      |  |  |  |
|                               |                            | ITMn                                                                                                                                                            |                   |                                                    | Trigger mode         |  |  |  |
|                               |                            |                                                                                                                                                                 | 0 0               |                                                    | Level trigger        |  |  |  |
|                               |                            |                                                                                                                                                                 | 0 1               |                                                    | Falling edge trigger |  |  |  |
|                               |                            |                                                                                                                                                                 | 1 0               |                                                    | Rising edge trigger  |  |  |  |
|                               |                            |                                                                                                                                                                 | Both edge trigger |                                                    |                      |  |  |  |
| Do not change the settings of |                            |                                                                                                                                                                 |                   | ttings of ITM03 to ITM00 during timer 0 operation. |                      |  |  |  |

#### 4.5 EXCEPTION HANDLING (SOFTWARE EXCEPTION AND EXCEPTION TRAP)

A software exception occurs when the CPU executes the TRAP instruction. The format of the TRAP instruction is as follows ("vector" is 0 to 1FH):

#### TRAP vector

In addition, the following exception traps may occur:

| <ul> <li>Double exception</li> </ul>                  | : Occurs upon the occurrence of an exception during the handling of another exception (PSW.EP = 1).                |
|-------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------|
| <ul> <li>Address trap</li> </ul>                      | : Occurs once the PC has assumed the address specified with the address trap register.                             |
| <ul> <li>Invalid instruction code</li> </ul>          | : Occurs when the instruction to be executed next is found to be invalid.                                          |
| <ul> <li>Division by zero</li> </ul>                  | : Occurs upon the occurrence of a division by zero error.                                                          |
| <ul> <li>Invalid floating-point operation</li> </ul>  | : Occurs if an invalid floating-point operation is performed.                                                      |
| <ul> <li>Floating-point division by zero</li> </ul>   | : Occurs upon the occurrence of a division by zero error during a floating-point operation.                        |
| <ul> <li>Floating-point overflow</li> </ul>           | : Occurs upon the occurrence of an overflow during a floating-<br>point operation.                                 |
| <ul> <li>Floating-point underflow</li> </ul>          | : Occurs upon the occurrence of an underflow during a floating-<br>point operation.                                |
| <ul> <li>Floating-point degraded precision</li> </ul> | : Occurs upon the occurrence of degraded precision during a floating-point operation.                              |
| <ul> <li>Floating-point reserved operand</li> </ul>   | : Occurs upon the detection of a reserved operand (infinity or non-<br>numeric) during a floating-point operation. |

The V821 is not subject to floating-point underflow and degraded precision exceptions.

#### 4.5.1 Operation

Upon the occurrence of an exception, the CPU performs the following processing, then passes control to the handler routine.

**Phase-out/Discontinued** 

- (1) If NP of PSW has been set, proceeds to step (8).
- (2) If EP of PSW has been set, proceeds to step (9).
- (3) Saves the return PC into EIPC.
- (4) Saves the current PSW into EIPSW.
- (5) Writes the exception code into the 16 low-order bits of ECR (EICC).
- (6) Sets the EP and ID bits of PSW and clears the AE bit.
- (7) Sets the handler address for the exception in the PC, thus passing control to the handler routine.
- (8) For a fatal exception
  - (a) Starts a machine fault cycle, then sequentially outputs the following data to the data bus: cause code for the fatal exception (logical sum of FFFF0000H and the exception code) to address 0000000H, the current PSW to address 00000004H, and the current PC to address 00000008H.
  - (b) Suspends operation until the system is reset.
- (9) For a double exception
  - (a) Saves the return PC into FEPC.
  - (b) Saves the current PSW into FEPSW.
  - (c) Writes the exception code for the exception which caused the double exception, into the 16 high-order bits of ECR (FECC).
  - (d) Sets the NP and ID bits of PSW and clears the AE bit.
  - (e) Sets the double exception handler address (FFFFFD0H) in the PC, thus passing control to the handler routine.

# CHAPTER 4 INTERRU Phase-out/Discontinued



# 4.5.2 Return from an Exception or Interrupt

The RETI instruction is used to perform return from an exception or interrupt, except in the case of a fatal exception.

- (1) Fetches the return PC and PSW from FEPC and FEPSW (when NP of PSW is set to 1) or EIPC and EIPSW (when NP is set to 0).
- (2) Writes the fetched values into the PC and PSW, thus passing control to the address indicated by the PC.



# 4.6 PRIORITY CONTROL

# 4.6.1 Priorities of Interrupts and Exceptions

The following table lists the priorities of interrupts and exceptions. If two or more interrupts and/or exceptions occur at the same time, they are handled according to their priorities.

|       | RESET | NMI        | INT          | AD-TR        | TRAP         | I-OPC        | DIV0         | FLOAT         |
|-------|-------|------------|--------------|--------------|--------------|--------------|--------------|---------------|
| RESET |       | *          | *            | *            | *            | *            | *            | *             |
| NMI   | х     |            | $\leftarrow$ | $\leftarrow$ | $\leftarrow$ | $\leftarrow$ | $\leftarrow$ | $\rightarrow$ |
| INT   | х     | $\uparrow$ |              | $\leftarrow$ | $\leftarrow$ | $\leftarrow$ | $\leftarrow$ | $\downarrow$  |
| AD-TR | х     | $\uparrow$ | $\uparrow$   |              | $\leftarrow$ | $\leftarrow$ | $\leftarrow$ | $\leftarrow$  |
| TRAP  | х     | $\uparrow$ | $\uparrow$   | Ŷ            |              | _            | _            | -             |
| I-OPC | х     | $\uparrow$ | $\uparrow$   | ↑            | _            |              | _            | -             |
| DIV0  | х     | $\uparrow$ | $\uparrow$   | ↑            | _            | _            |              | -             |
| FLOAT | х     | $\uparrow$ | $\uparrow$   | ↑            | _            | _            | _            |               |

- NMI : Nonmaskable interrupt
- INT : Maskable interrupt
- AD-TR : Address trap
- TRAP : Trap instruction
- I-OPC : Invalid instruction code
- DIV0 : Division by zero
- FLOAT : Floating-point exception (invalid operation, division by zero, overflow, and reserved operand)
- \* : The item on the left causes the item at the top to be ignored.
- x : The item at the top causes the item on the left to be ignored.
- : The item on the left and that at the top cannot occur at the same time.
- $\leftarrow$  : The item on the left has a higher priority than the item at the top.
- $\uparrow$  : The item at the top has a higher priority than the item on the left.

# 4.6.2 Priorities of Floating-Point Exceptions

The following table lists the priorities of floating-point exceptions:

|     | FRO | FIV | FZD | FOV | FUD | FPR |
|-----|-----|-----|-----|-----|-----|-----|
| FRO |     | *   | *   | *   | _   | _   |
| FIV | х   |     | *   | *   | -   | _   |
| FZD | х   | х   |     | *   | Ι   | _   |
| FOV | х   | х   | х   |     | Ι   | _   |
| FUD | _   | _   | _   | _   |     | _   |
| FPR | _   | _   | _   | _   | _   |     |

# Table 4-5. Priorities of Floating-Point Exceptions

- FRO : Floating-point reserved operand
- FIV : Invalid floating-point operation
- FZD : Floating-point division by zero
- FOV : Floating-point overflow
- FUD : Floating-point underflow
- FPR : Floating-point degraded precision
- \* : The item on the left causes the item at the top to be ignored.
- x : The item at the top causes the item on the left to be ignored.
- : The item on the left and that at the top cannot occur at the same time.

**Remark** The V821 is not subject to FUD and FPR.



# **CHAPTER 5 BUS CONTROL FUNCTION**

The V821 interfaces with external memory and external I/O devices via the external bus.

#### 5.1 CPU BUS STATES

The V821 bus cycles can assume the following eight states:

#### (1) TI and TIS states

When no access request has been issued, or when the TH or THS state (hold state) is released, the bus enters the TI or TIS state. At the falling edge of the clock signal in the TI and TIS states, the HLDRQ signal is sampled.

#### (2) T1 and T1S states

The bus enters the T1 or T1S state at the start of a bus cycle. In these states, an address is output to the bus at the rising edge of the clock pulse, and valid data is output to the data bus at the falling edge of the clock pulse. After entering the T1 or T1S state, the bus invariably enters the T2 or T2S state.

#### (3) T2 and T2S states

The T2 and T2S states correspond to the final state of a bus cycle or a wait state. At the falling edge of the clock signal in the T2 and T2S states, the HLDRQ signal is sampled. At the rising edge of the clock pulse that occurs immediately after the last T2 and T2S states, read data is sampled.

#### (4) TH and THS states

The bus enters the TH or THS state when the hold state is caused by an  $\overline{\text{HLDRQ}}$  input. In these states, the  $\overline{\text{HLDRQ}}$  signal is sampled at the falling edge of the clock signal. If sampling indicates that the  $\overline{\text{HLDRQ}}$  signal has become inactive, the bus then enters the TI or TIS state.

**Remark** The TIS, T1S, T2S, and THS states are assumed by additional bus cycles which occur only when word accesses are performed. The TIS, T1S, T2S, and THS states correspond to the TI, T1, T2, and TH states of normal bus cycles, respectively.





**Remark** When the RESET input becomes active, the bus enters the TI or TH state according to the HLDRQ signal status.

#### Conditions for bus cycle state transition

- <1> (HLDRQ = 1 or hold disable state) and access source present
- <2> READY = 0 and (non-word access) and access source present and (HLDRQ = 1 or hold disable state)
- <3> READY = 1
- <4> READY = 0 and (non-word access) and (access source not present or (HLDRQ = 0 and hold enable state))
- <5> (HLDRQ = 1 or hold disable state) and access source not present
- <6> HLDRQ = 0 and hold enable state
- **<7>**  $\overrightarrow{READY} = 0$  and (access source not present or ( $\overrightarrow{HLDRQ} = 0$  and hold enable state))
- <8> HLDRQ = 0
- <9> HLDRQ = 1
- <10> READY = 1
- <11>  $\overline{\text{READY}} = 0$  and access source present and ( $\overline{\text{HLDRQ}} = 1$  or hold disable state)
- <12>  $\overline{\text{READY}} = 0$  and word access and ( $\overline{\text{HLDRQ}} = 1$  or hold disable state)
- <13>  $\overline{\text{READY}} = 0$  and word access and  $\overline{\text{HLDRQ}} = 0$  and hold enable state
- <14> HLDRQ = 1
- <15> HLDRQ = 0
- <16> HLDRQ = 1
- <17> HLDRQ = 0
- **Remark** After the BLOCK signal becomes active, the hold disable state continues until the bus enters the last bus cycle of the BLOCK cycle (the last T2 state or, when an additional bus cycle exists, the last T2S state). (During the last bus cycle, the hold enable state exists.)

# 5.2 DMAC BUS STATE

The DMAC bus cycles can assume the following 10 states:

#### (1) TI state

The TI state is the idle state, during which no access request is issued. The DREQ signal is sampled at the falling edge of the clock pulse.

#### (2) T0 state

DMA transfer ready state. (A DMA transfer request has been issued, causing the bus to be acquired for the first DMA transfer.)

# (3) T1R state

The bus enters the T1R state at the beginning of a read operation in two-cycle transfer mode. After entering the T1R state, the bus invariably enters the T2R state. Address driving starts.

#### (4) T2R state

The T2R state corresponds to the last state of a read operation in two-cycle transfer mode, or to a wait state.

In the last T2R state, read data is sampled. After entering the last T2R state, the bus invariably enters the T1W state.

# (5) T1W state

The bus enters the T1W state at the beginning of a write operation in two-cycle transfer mode. After entering the T1W state, the bus invariably enters the T2W state. Address driving starts.

#### (6) T2W state

The T2W state corresponds to the last state of a write operation in two-cycle transfer mode, or to a wait state.

In the last T2W state, the write strobe signal is made inactive.

# (7) T1F state

The bus enters the T1F state at the beginning of a fly-by transfer. After entering the T1F state, the bus invariably enters the T2F state. Address driving starts.

#### (8) T2F state

The T2F state corresponds to the last state of a fly-by transfer or a wait state. In the last T2F state, the write strobe signal is made inactive.

#### (9) T3 state

The bus enters the T3 state when a DMA transfer has been completed, and the bus has been released. After entering the T3 state, the bus invariably enters the TI state.

# (10) TH state

From the TH state, the bus enters the DMA hold state (when a bus request is made by a bus master having a higher priority during DMA block transfer).

Each time the processing for a DMA service is completed, the bus is released (the bus enters bus release mode).





# Conditions governing bus cycle state transition

```
<1> NMI = 0
```

- (External terminal DREQ = 1 or software DREQ = 1 or internal I/O DREQ = 1), transfer not terminated, DMA enable and NMI = 1
- <3> DHLDAK = 1
- **A**  $\overline{\text{DHLDAK}} = 0$  and two-cycle transfer  $\overline{\text{NMI}} = 1$
- **<5>**  $\overline{\text{DHLDAK}}$  = 1 and fly-by transfer  $\overline{\text{NMI}}$  = 1
- **<6>**  $\overline{\text{NMI}}$  = 1 and  $\overline{\text{DHLDAK}}$  = 0, transfer not terminated and block transfer
- <7> DHLDAK = 1
- **<8>**  $\overline{\text{NMI}}$  = 1 and  $\overline{\text{DREADY}}$  = 0 and  $\overline{\text{DHLDAK}}$  = 0, transfer not terminated, and block transfer
- **<9>**  $\overline{\text{NMI}}$  = 1 and  $\overline{\text{DREADY}}$  = 0 and  $\overline{\text{DHLDAK}}$  = 1, transfer not terminated and block transfer
- <10> NMI = 0
- <11> DREADY = 1
- <12> DREADY = 0
- <13> DREADY = 1
- **<14>**  $\overline{\text{DREADY}} = 0$  and  $(\overline{\text{NMI}} = 0$  or transfer terminated or non-block transfer)
- <15>  $\overline{\text{NMI}}$  = 1 and  $\overline{\text{DREADY}}$  = 0 and  $\overline{\text{DHLDAK}}$  = 0, transfer not terminated and block transfer
- <16> DREADY = 1
- **<17>**  $\overline{\text{NMI}}$  = 1 and  $\overline{\text{DHLDAK}}$  = 0, transfer not terminated and block transfer
- **<18>**  $\overrightarrow{\text{DREADY}} = 0$  and  $(\overrightarrow{\text{NMI}} = 0$  or transfer terminated or non-block transfer)
- **<19>**  $\overline{\text{NMI}}$  = 1 and  $\overline{\text{DREADY}}$  = 0,  $\overline{\text{DHLDAK}}$  = 1, transfer not terminated and block transfer
- <20> DHLDAK = 1
- <**21>** DHLDAK = 0
- <22> DHLDAK = 1
- **<23>** NMI = 0
- **Remark** DHLDAK : Internal signal from BAU that grants bus mastership to DMAC

DREADY : Internal signal from WCU to indicate the DMAC ready state, and external READY signal

#### 5.3 BUS PRIORITY

The bus arbitration unit (BAU) arbitrates bus mastership among the bus masters (those that can acquire the bus). If a bus master having a certain priority requests the use of the bus while another bus master having a lower priority is using the bus, the BAU immediately transfers bus mastership from the low-priority bus master to the high-priority bus master.

Table 5-1 lists the types of the bus masters and their priorities.

| Bus master          | Bus cycle                             | Priority    |
|---------------------|---------------------------------------|-------------|
| CPU                 | Bus lock                              | 1 (highest) |
|                     | Fetch                                 | 5 (lowest)  |
|                     | Read/write                            |             |
| DRAMC               | Refresh                               | 2           |
| External bus master | Bus cycles driven by external devices | 3           |
| DMAC                | DMA                                   | 4           |

#### Table 5-1. Bus Priority

Although the DRAMC takes priority over external bus masters, it cannot acquire the bus forcibly while it is being used by an external bus master. In response to a refresh request received from the DRAMC, the BAU makes the  $\overline{\text{HLDAK}}$  pin inactive to indicate the presence of the refresh request. When the  $\overline{\text{HLDRQ}}$  pin is made inactive while the  $\overline{\text{HLDAK}}$  is inactive, a refresh cycle is initiated.

Bus mastership is switched during each bus cycle or idle state. In the halt and IDLE modes upon reset, the  $\overline{\text{HLDRQ}}$  signal is accepted. During a halt acknowledge cycle in which halt or IDLE mode is entered, or during the first six clock cycles of a self-refresh cycle in which IDLE mode is entered, however, the  $\overline{\text{HLDRQ}}$  signal is not accepted.

At power-on reset, the HLDRQ signal must be made inactive.

# 5.4 DATA FLOW WHEN USING AN ADDITIONAL BUS CYCLE

A bus cycle is added only when word access is performed.

During read cycles, the low-order 16 bits of word data are sampled during the first bus cycle. The highorder 16 bits are sampled during the second bus cycle.

During write cycles, the low-order 16 bits of word data are output at the falling edge of the clock signal in the T1 state of the first bus cycle. The remaining high-order 16 bits are output at the falling edge of the clock signal in the T1S state of the second bus cycle. Then, the output data is held until the clock signal in the T1 state of the next bus cycle goes low.

Figure 5-3 illustrates read and write operations. In the figure, A is assumed to be the low-order 16 bits of the word data, while B is assumed to be the high-order 16 bits of the word data.

#### Figure 5-3. Data Flow When an Additional Bus Cycle Is Used



(a) Read cycle





# 5.5 RELATIONSHIP BETWEEN EXTERNAL ACCESSES AND THE DATA BUS

This section explains data I/O and the byte enable signal when external access is performed.

#### 5.5.1 Relationship between External Access and Byte Enable Signal

Table 5-2 shows the relationship between external accesses and the byte enable signal (UBE).

# Table 5-2. Relationship between Addresses, Data Length, UBE, and Address Pins

| Data length | Operand address |       | UBE | Addre | ss pin | Bus cycle sequence |
|-------------|-----------------|-------|-----|-------|--------|--------------------|
|             | Bit 1           | Bit 0 |     | A1    | A0     |                    |
| Byte        | 0               | 0     | 1   | 0     | 0      | 1                  |
|             | 0               | 1     | 0   | 0     | 1      | 1                  |
|             | 1               | 0     | 1   | 1     | 0      | 1                  |
|             | 1               | 1     | 0   | 1     | 1      | 1                  |
| Halfword    | 0               | 0     | 0   | 0     | 0      | 1                  |
|             | 1               | 0     | 0   | 1     | 0      | 1                  |
| Word        | 0               | 0     | 0   | 0     | 0      | 1                  |
|             |                 |       | 0   | 1     | 0      | 2                  |

#### 5.5.2 Operand Read

Figure 5-4 shows the relationship between external access and data input during an operand read operation.

Phase-out/Discontinued

In the figure, read buffer "n;Bm" indicates that the mth byte on the external data bus is read during the nth bus cycle. Bm in the external data bus is illustrated below:



#### Figure 5-4. Read Cycle

#### (a) Data length: Byte

| Operand | address |    |    |    | Internal | registe | er |        |   |
|---------|---------|----|----|----|----------|---------|----|--------|---|
| Bit 1   | Bit 0   | 31 | 24 | 23 | 16       | 15      | 8  | 7      | 0 |
| 0       | 0       |    |    |    |          |         |    | 1 ; B1 |   |
| 0       | 1       |    |    |    |          |         |    | 1 ; B2 |   |
| 1       | 0       |    |    |    |          |         |    | 1 ; B1 |   |
| 1       | 1       |    |    |    |          |         |    | 1 ; B2 |   |

#### (b) Data length: Halfword

| Operand | address |    |    |    | Internal | register |   |        |   |
|---------|---------|----|----|----|----------|----------|---|--------|---|
| Bit 1   | Bit 0   | 31 | 24 | 23 | 16       | 15       | 8 | 7      | 0 |
| 0       | 0       |    |    |    |          | 1 ; B2   |   | 1 ; B1 |   |
| 1       | 0       |    |    |    |          | 1 ; B2   |   | 1 ; B1 |   |

#### (c) Data length: Word

| Operand | address | Internal register |      |       |    |        |   |        |   |
|---------|---------|-------------------|------|-------|----|--------|---|--------|---|
| Bit 1   | Bit 0   | 31                | 24   | 23    | 16 | 15     | 8 | 7      | 0 |
| 0       | 0       | 2                 | ; B2 | 2 ; B | 1  | 1 ; B2 |   | 1 ; B1 |   |

#### 5.5.3 Operand Write

Figure 5-5 shows the relationship between external access and data output during an operand write operation.

In the figure, OPm (m = 1 to 4) indicates the byte position in the internal register.

The position of OPm in the internal register is shown below.



#### Figure 5-5. Write Cycle

#### (a) Data length: Byte

| Bit 1 Bit 0 15 8 7 0 Bus cycle se |         |
|-----------------------------------|---------|
| Bit i Bit 0 13 67 0 Bus cycle se  | equence |
| 0 0 <b>Note 1</b> OP1 1           |         |
| 0 1 OP1 <b>Note 2</b> 1           |         |
| 1 0 <b>Note 1</b> OP1 1           |         |
| 1 1 OP1 <b>Note 2</b> 1           |         |

Notes 1. The undefined data is output from bits D8 to D15.

2. The undefined data is output from bits D0 to D7.

Phase-out/Discontinued

#### (b) Data length: Halfword

| Operand | address |    | External | data bus |   |                    |
|---------|---------|----|----------|----------|---|--------------------|
| Bit 1   | Bit 0   | 15 | 8        | 7        | 0 | Bus cycle sequence |
| 0       | 0       |    | OP2      | OP1      |   | 1                  |
| 1       | 0       |    | OP2      | OP1      |   | 1                  |

#### (c) Data length: Word

| Operand | address |    | External | data bus |   |                    |
|---------|---------|----|----------|----------|---|--------------------|
| Bit 1   | Bit 0   | 15 | 8        | 7        | 0 | Bus cycle sequence |
| 0       | 0       |    | OP2      | OP1      |   | 1                  |
| 0       | 0       |    | OP4      | OP3      |   | 2                  |

# 5.5.4 Notes on Bit Strings

Bit strings are processed word by word (in blocks of 4 bytes) to speed up operation. If the end of the data does not correspond to a word boundary when a write operation is performed, that is, if bits 1 and 0 of the last byte address of the locations that hold the bit string in the destination are other than "11," a maximum of three extra bytes are written as shown in Figure 5-6. In this case, as the extra data, the original value is written as is. In this way, the data is not destroyed.

During read operations, up to three extra words subsequent to the last word of the data may be read during read cycles at both the source and destination. This extra data is discarded.

| Operand address |       | Exter               | External data bus   |   |                    |
|-----------------|-------|---------------------|---------------------|---|--------------------|
| Bit 1           | Bit 0 | 15                  | 8 7                 | 0 | Bus cycle sequence |
| 0               | 0     | OP2 <sup>Note</sup> | OP1                 |   | 1                  |
| 0               | 0     | OP4 <sup>Note</sup> | OP3 <sup>Note</sup> |   | 2                  |
| 0               | 1     | OP2                 | OP1                 |   | 1                  |
| 0               | 1     | OP4 <sup>Note</sup> | OP3 <sup>Note</sup> |   | 2                  |
| 1               | 0     | OP2                 | OP1                 |   | 1                  |
| 1               | 0     | OP4 <sup>Note</sup> | OP3                 |   | 2                  |

# Figure 5-6. Write Cycles for Bit Strings

Note Extra bytes written unnecessarily

# 5.6 EXTERNAL I/O ACCESS

#### 5.6.1 External I/O Read Cycle

The timing for each state is explained below:

- T1 state : The output of an address and  $\overline{CSn}$  signal starts. At the falling edge of the clock signal, the IORD signal becomes active.
- T2 state : If the READY signal is active at the falling edge of the clock signal, the bus cycle terminates. The IORD signal is made inactive, and at the same time, data is sampled.

The wait count set by the WSn bit of the PWCn register is ORed with the wait count controlled by  $\overline{READY}$ . Therefore, as many wait states as the larger of these wait counts are inserted. (See **Chapter 6**.)



Figure 5-7. External I/O Read Cycle

Remarks 1. An arrow indicates a sampling timing when the programmable wait is set to 0.2. A broken line indicates a high impedance.

#### 5.6.2 External I/O Write Cycle

The timing for each state is explained below:

- T1 state : The output of an address and the  $\overline{CSn}$  signal starts. At the falling edge of the clock signal, the  $\overline{IOWR}$  signal becomes active.
- T2 state : If the READY signal is active at the falling edge of the clock signal, the bus cycle terminates, and the IOWR signal is made inactive. The write data is maintained until the clock signal goes high in the T1 or TI state of the next bus cycle.

The wait count set by the WSn bit of the PWCn register is ORed with the wait count controlled by  $\overline{READY}$ . Therefore, as many wait states as the larger of these wait counts are inserted. (See **Chapter 6**.)



Figure 5-8. External I/O Write Cycle

- **Remarks 1.** An arrow indicates a sampling timing when the programmable wait is set to 0.
  - **2.** A broken line indicates a high impedance.

# 5.7 INTERNAL I/O ACCESS

Internal I/O read cycles and internal I/O write cycles are similar to external I/O read cycles and external I/O write cycles, except in the following points:

- Neither the  $\overline{\text{IORD}}$ ,  $\overline{\text{IOWR}}$ , nor  $\overline{\text{CSn}}$  signals become active.
- The number of wait states that can be inserted is always 1 or 2. (Wait control using the READY pin and PWCn register is impossible.)

# 5.7.1 Internal I/O Read Cycle



Figure 5-9. Internal I/O Read Cycle

**Remark** A broken line indicates a high impedance.

# 5.7.2 Internal I/O Write Cycle





**Remark** A broken line indicates a high impedance.

# 5.8 SRAM (ROM) ACCESS

#### 5.8.1 SRAM (ROM) Read Cycle

The timing in each state is explained below:

- T1 state : The output of an address and the  $\overline{CSn}$  signal starts. At the falling edge of the clock signal, the  $\overline{MRD}$  signal becomes active.
- T2 state : If the READY signal is active at the falling edge of the clock signal, the bus cycle terminates. The MRD signal is made inactive and, at the same time, data is sampled.

The wait count set with the WSn bit of the PWCn register is ORed with the wait count controlled by  $\overline{READY}$ . Therefore, as many wait states as the larger of these wait counts are inserted. (See **Chapter 6**.)



Figure 5-11. SRAM (ROM) Read Cycle

Remarks 1. An arrow indicates a sampling timing when the programmable wait is set to 0.2. A broken line indicates a high impedance.

#### 5.8.2 SRAM Write Cycle

The timing in each state is explained below:

- T1 state : The output of an address and the  $\overline{CSn}$  signal starts. At the falling edge of the clock signal, the  $\overline{LMWR}$  and  $\overline{UMWR}$  signals become active.
- T2 state : If the READY signal is active at the falling edge of the clock signal, the bus cycle terminates, and the LMWR and UMWR signals are made inactive. The write data is maintained until the clock signal goes high in the T1 or TI state of the next bus cycle.

The wait count set by the WSn bit of the PWCn register is ORed with the wait count controlled by  $\overline{READY}$ . Therefore, as many wait states as the larger of these wait counts are inserted. (See **Chapter 6**.)



Figure 5-12. SRAM Write Cycle

Remarks 1. An arrow indicates a sampling timing when the programmable wait is set to 0.2. A broken line indicates a high impedance.

# 5.9 PAGE-ROM ACCESS

Page-ROM cycles are selected by setting 1 in the CT3 bit of the BCTC register, a WCU control register.

# 5.9.1 Page-ROM Read Cycle

The page-ROM read cycle is similar to the SRAM read cycle, except in the following points:

- The wait count for each on-page cycle is specified with the WA bit of the PRC register (0 or 1). The wait count for the off-page cycles is specified with the WS3 bit of the PWC1 register (0 to 7).
- Wait control using the READY pin is impossible.
- The MRD signal does not become inactive for the on-page cycles.



Figure 5-13. Page-ROM Read Cycle

Note When MA5 to MA3 of the PRC register are 000 (See Section 7.2.3.)

**Remark** A broken line indicates a high impedance.

# 5.10 DRAM ACCESS

DRAM cycles are selected by setting 01 or 11 in the CT0 bits of the BCTC register, a WCU control register.

**<1>** When CT0 bits = 01 : The  $\overline{CS0}$  pin functions as the  $\overline{REFRQ}$  output.

**2>** When CT0 bits = 11 : The  $\overline{CS0}$  pin functions as the  $\overline{CS0}$  output. ( $\overline{CS0}$  becomes active when I/O block 0 is accessed.)

During the DRAM cycle, the  $\overline{CS0}$  signal becomes active in the case of <2> above.

To generate a cycle for the DRAM high-speed page mode, set the PAE bit of the DRAM configuration register to 1. (See **Section 7.1.4**.)

# 5.10.1 DRAM Read Cycle

# (1) Off-page

The output of a column address starts in the T1 state. At the falling edge of the clock signal, the  $\overline{RAS}$  signal becomes inactive (RAS precharge), and the  $\overline{MRD}$  signal becomes active.

During the first clock period of the T2 state that follows T1, RAS precharge is performed. At the falling edge of the clock cycle, a row address is output.

In a second T2 state, the  $\overrightarrow{RAS}$  signal is made active and, at the falling edge of the clock signal, a column address is output.

In a third T2 state, the  $\overline{\text{LCAS}}$  and  $\overline{\text{UCAS}}$  signals are made active. If the CWS bit of the DRC register is 1, a wait state is inserted into the next cycle.

At the rising edge of the clock signal in the T1 state of the next cycle, the  $\overline{\text{LCAS}}$ ,  $\overline{\text{UCAS}}$ , and  $\overline{\text{MRD}}$  signals are made inactive, data is sampled, and the cycle is completed.

Wait states can be inserted by inputting the external READY signal.

# (2) On-page

In the T1 state, output of a column address starts. At the falling edge of the clock signal, the  $\overline{\text{MRD}}$ ,  $\overline{\text{LCAS}}$ , and  $\overline{\text{UCAS}}$  signals are made active. The  $\overline{\text{RAS}}$  signal is held active.

At the rising edge of the clock signal in the T1 state of the next cycle, the  $\overline{\text{LCAS}}$ ,  $\overline{\text{UCAS}}$ , and  $\overline{\text{MRD}}$  signals are made inactive, data is sampled, and the cycle is completed.



#### Figure 5-14. DRAM Read Cycle

Phase-out/Discontinued

# Remarks 1. ROW : Row address

- COL : Column address
- 2. A broken line indicates a high impedance.
- **3.** An arrow indicates a sampling timing.

# 5.10.2 DRAM Write Cycle

# (1) Off-page

In the T1 state, output of a column address starts. At the falling edge of the clock signal, the  $\overline{RAS}$  signal becomes inactive (RAS precharge), and the  $\overline{WE}$  signal becomes active.

During the first clock period in the T2 state following T1, RAS precharge is performed. At the falling edge of the clock cycle, a row address is output.

During the second T2 state, the  $\overline{RAS}$  signal is made active, and a column address is output at the falling edge of the clock signal. If the CWS bit of the DRC register is 1, a wait state is inserted into the next cycle. In a third T2 state, the  $\overline{LCAS}$  and  $\overline{UCAS}$  signals are made active. At the falling edge of the clock signal, the  $\overline{WE}$  signal is made inactive.

At the rising edge of the clock signal in the T1 state of the next cycle, the  $\overline{\text{LCAS}}$  and  $\overline{\text{UCAS}}$  signals are made inactive, and the cycle is completed.

Wait states can be inserted by inputting the external READY signal.

# (2) On-page

In the T1 state, output of a column address starts. At the falling edge of the clock signal, the  $\overline{WE}$  signal is made active. The  $\overline{RAS}$  signal is held active.

In the T2 state, the  $\overline{\text{LCAS}}$  and  $\overline{\text{UCAS}}$  signals are made active. If the ADC bit of the DRAM configuration register is set to 1, one wait state is inserted unless the previous cycle was a write cycle. In this case, during the next T2 state, the  $\overline{\text{LCAS}}$  and  $\overline{\text{UCAS}}$  signals are made active and, at the falling edge of the clock signal, the  $\overline{\text{WE}}$  signal is made inactive.

At the rising edge of the clock signal in the T1 state of the next cycle, the  $\overline{\text{LCAS}}$  and  $\overline{\text{UCAS}}$  signals are made inactive, and the cycle is completed.

# Figure 5-15. DRAM Write Cycle

# (1) When ADC = 0



Remarks 1. ROW : Row address

- COL : Column address
- **2.** A broken line indicates a high impedance.
- **3.** An arrow indicates a sampling timing.



# (2) When ADC = 1



Remarks 1. ROW : Row address

- COL : Column address
- **2.** A broken line indicates a high impedance.
- **3.** An arrow indicates a sampling timing.

# 5.10.3 CBR Refresh Cycle

A bus cycle for a refresh cycle requires at least seven clock periods. Including the idle cycles entered before and after the refresh cycle, at least nine clock periods are required. During the CBR refresh cycle, the external READY signal can be used for control. At the rising edge of the sixth clock cycle of the CBR refresh cycle, the external READY pin is sampled. If it is found to be inactive, the CBR refresh cycle is not terminated until the external READY pin becomes active at the rising clock edge.



Figure 5-16. CBR Refresh Cycle

**Remarks 1.** A broken line indicates a high impedance.

2. An arrow indicates a sampling timing.

#### 5.10.4 Self-Refresh Cycle

The self-refresh cycle is initiated by setting the SMD bit of the standby control register (STBC) to specify idle or STOP mode, and executing the HALT instruction. Before DRAM can perform a self-refresh operation, the specified  $\overline{RAS}$  pulse width of DRAM (CBR self-refresh) (100  $\mu$ s or more) must be satisfied. When the  $\overline{NMI}$  signal is generated during the CBR self-refresh cycle, the  $\overline{REFRQ}$ ,  $\overline{RAS}$ ,  $\overline{LCAS}$ , and  $\overline{UCAS}$  signals are made inactive, and CBR self-refresh is canceled.

During the halt acknowledge cycle and the first six clock cycles of the IDLE mode self-refresh cycle, all external hold requests are ignored. External hold requests can be made only from the seventh clock cycle of the self-refresh cycle.

In the halt acknowledge cycle and self-refresh cycle in STOP mode, all external hold requests are ignored.



Figure 5-17. CBR Self-Refresh Cycle

**Remark** A broken line indicates a high impedance.

# 5.10.5 Bus Cycle during Fly-by Transfer

This cycle occurs only when fly-by transfer is specified for the DMA.

In the fly-by cycle, I/O access and memory access are performed at the same time. Basically, the I/O and memory accesses are made in the same way as in the I/O and memory access cycles, respectively.

The wait count is set with the DWSn bit of programmable wait control register 2 (PWC2).

During DRAM off-page access and the SRAM cycle, wait states can be inserted by inputting the external READY signal.

#### (1) Fly-by read cycle

#### (a) Block transfer

# Figure 5-18. Fly-by Read Cycle during DMA Block Transfer (DRAM to External I/O Device)



#### Remarks 1. ROW : Row address

- COL : Column address
- 2. A broken line indicates a high impedance.
- 3. An arrow indicates a sampling timing.

# (b) Single transfer and single-step transfer





Remarks 1. ROW : Row address

COL : Column address

- **2.** A broken line indicates a high impedance.
- **3.** An arrow indicates a sampling timing.

# (2) Fly-by write cycle

#### (a) Block transfer

Figure 5-20. Fly-by Write Cycle during DMA Block Transfer (External I/O Device to DRAM)



Remarks 1. ROW : Row address

COL : Column address

- **2.** A broken line indicates a high impedance.
- **3.** An arrow indicates a sampling timing.

# (b) Single transfer and single-step transfer





Remarks 1. ROW : Row address

COL : Column address

- **2.** A broken line indicates a high impedance.
- **3.** An arrow indicates a sampling timing.

# 5.11 EXCEPTION HANDLING CYCLES

#### 5.11.1 Machine Fault Cycle

When a machine fault occurs, the machine fault cycle is initiated. During the I/O write cycle, the source code of a fatal exception (generated by ORing 0000H with the exception code), and the PSW and PC contents at that time are output onto the data bus, one after the other.

Table 5-3 indicates the correspondence between the data bus and address bus.

#### Table 5-3. Correspondence between the Address Bus and Data Bus in the Machine Fault Cycle

| Sequence | Address bus<br>(A0 - A23) | Data bus<br>(D0 - D15)                                                   |
|----------|---------------------------|--------------------------------------------------------------------------|
| 1        | 000000H                   | Source code of fatal exception (low-order)                               |
| 2        | 000002H                   | Source code of fatal exception (high-order) (The value is always FFFFH.) |
| 3        | 000004H                   | PSW at that time (low-order)                                             |
| 4        | 000006H                   | PSW at that time (high-order)                                            |
| 5        | 000008H                   | PC at that time (low-order)                                              |
| 6        | 00000AH                   | PC at that time (high-order)                                             |

Do not use addresses 000000H to 00000BH of address block 0 in the I/O space. The machine fault cycle replaces any data in these locations with arbitrary data.

During this write cycle, all wait and bus hold requests are valid. Requests using HLDRQ and READY are also valid during the machine fault cycle and the subsequent TI state.

The machine fault state can be released only by inputting a reset.

# Phase-out/Discontinued



Figure 5-22. Machine Fault Cycle



**Remarks 1.** A broken line indicates a high impedance.

2. An arrow indicates a sampling timing.

# 5.11.2 Halt Acknowledge Cycle

In the halt acknowledge cycle, the low-order 24 bits of the PC existing when the HALT instruction is executed are output onto the address bus, while the low-order 16 bits of the PSW are output onto the data bus.

Wait states cannot be inserted by inputting the external READY signal. The wait count is always 0. During the cycle, hold requests are ignored.

When idle or STOP mode is specified with the SMD bit of the standby control register (STBC), a self-refresh cycle is initiated immediately after the hold acknowledge cycle. (See **Section 5.10.4**.)



Figure 5-23. Halt Acknowledge Cycle

**Remark** A broken line indicates a high impedance.

# 5.12 CONTROL SIGNAL TIMING

This section explains the timings of the bus hold and bus lock operations.

#### 5.12.1 Bus Hold

When another processor requests bus mastership from the V821, the bus enters the bus hold state, and the bus is relinquished to the processor. In this case, the bus is placed in the floating state.

Figure 5-24 shows the timing at which the bus enters the bus hold state. In the different states, the following operations are performed:

- T2 state : At the falling edge of the clock signal, the READY and HLDRQ signals are sampled. If both signals are active, the bus enters the TI state.
- TI state : At the falling edge of the clock signal, the HLDRQ signal is sampled. If the signal is active, the bus enters the TH state.
- TH state : The bus is placed in the floating state, and the HLDAK signal is made active. If the HLDRQ signal remains active, the TH state continues. If the signal becomes inactive, the bus enters the TI state, and bus mastership is returned to the CPU.

Bus hold requests are accepted in ordinary mode, HALT mode, and IDLE mode. In addition, bus hold requests can be accepted during a reset. Under the following conditions, however, a bus hold request is not accepted:

- When the CAXI instruction is executed (The bus is locked.)
- In STOP mode (internal clock stopped state)
- During the halt acknowledge cycle in which halt or IDLE mode is entered, or during the first six cycles of the self-refresh cycle in IDLE mode

At power-on reset, the HLDRQ signal must be made inactive.

When the bus enters the bus hold state in IDLE mode, the REFRQ, RAS, UCAS, LCAS, MRD, and WE signals originally in the self-refresh cycle state, enter the floating state. Later, when the bus hold request is released, these signals become inactive, then, a self-refresh cycle is initiated.

If the bus cycle immediately before the bus hold state was a page-ROM cycle, the  $\overline{CS3}$  and  $\overline{MRD}$  pins, originally at the active level, are placed in the floating state. When the bus hold state is released, these pins become inactive.

Similarly, if the bus cycle immediately before the bus hold state was a DRAM cycle and an on-page access was enabled, the  $\overline{RAS}$  pin, originally at the active level, is placed in the floating state. When the bus hold state is released, the  $\overline{RAS}$  pin becomes inactive.

# Caution When the bus hold cycle is to be repeated, assure at least three clocks at the inactive period for the HLDRQ signal during the bus hold cycle.

Phase-out/Discontinued



Figure 5-24. Bus Hold Cycle

**Remarks 1.** A broken line indicates a high impedance.

**2.** An arrow indicates a sampling timing.

#### 5.12.2 Bus Lock

To prevent processors other than the V821 from using the bus, the BLOCK signal can be made active to lock the bus.

Phase-out/Discontinued

A bus lock occurs when a CAXI instruction is executed. For example, during a lock word access made using the CAXI instruction, the BLOCK signal becomes active in sync with the start of a read bus cycle, and the signal becomes inactive in sync with the end of the last write cycle.

The BLOCK pin is also used as the WDTOUT pin. To output a BLOCK signal to the pin, the BWOS bit of the WDT mode register must be set. (See **Section 11.4**.)



Figure 5-25. Bus Lock Cycle When the CAXI Instruction Is Executed

#### Note Read data

**Remarks 1.** A broken line indicates a high impedance.

2. An arrow indicates a sampling timing.



# **CHAPTER 6 WAIT CONTROL FUNCTIONS**

The wait control unit (WCU) manages the four blocks corresponding to the four chip select signals, generates the chip select signals, performs wait control, and selects the bus cycle types.

# 6.1 FEATURES

- Able to control up to four blocks in the memory and I/O spaces
- Linear address space of each block: 16 Mbytes
- Wait control
  - Automatic insertion of 0-7 waits per block
  - Insertion of waits using the READY pin
- Bus cycle selection function
  - Page-ROM cycle selectable (address block 3)
  - DRAM cycle selectable (address block 0)

#### 6.2 ADDRESS SPACES AND BLOCKS

The internal 4-Gbyte memory and I/O spaces are each divided into blocks of 1 Gbyte each. Built-in peripheral I/O registers are allocated to I/O block 3.

Each block has a linear address space of 16 Mbytes. For a 32-bit address, only the lower 24 bits are output.)

#### Figure 6-1. Memory and I/O Maps



(1) Memory map

(2) I/O map

# 6.3 CHIP SELECT CREATION AND BUS CYCLE SELECTION FUNCTIONS

The chip select signals ( $\overline{CS0}$ - $\overline{CS3}$ ) are output to block 0-3, as follows:

| Block name | Access type          | Chip select signal |
|------------|----------------------|--------------------|
| Block 0    | Memory or I/O access | CS0 signal         |
| Block 1    | Memory or I/O access | CS1 signal         |
| Block 2    | Memory or I/O access | CS2 signal         |
| Block 3    | Memory access        | CS3 signal         |

When memory access is selected for block 0, the DRAM cycle can be specified. In this case, the  $\overline{CS0}/\overline{REFRQ}$  pin is specified for either  $\overline{REFRQ}$  or  $\overline{CS0}$  output.  $\overline{CS0}$  output becomes active at both memory access and I/O access.

For memory access to block 3, the page-ROM cycle can be specified.

#### 6.4 PROGRAMMABLE WAIT FUNCTION

WCU allows the user to specify the number of waits to be inserted, using the WSn bits of the programmable wait control register (PWCn) corresponding to the signal  $\overline{\text{CSn}}$ . The programmable wait control register allows the specification of 0 to 7 waits. Additional waits can be inserted by using the  $\overline{\text{READY}}$  pin.

#### 6.4.1 Wait Control Using the READY Pin

Waits of eight or more clock pulses can be inserted using the  $\overline{READY}$  pin. In the cycles listed below, all of which have fixed waits, the  $\overline{READY}$  pin cannot be used to insert waits, however.

- Page-ROM cycle
- DRAM cycle (on-page)
- Internal I/O cycle
- CBR self refresh cycle
- Halt acknowledge cycle

The sampling of the READY pin is performed as follows, according to the cycle:

- DRAM cycle (off-page): At the rising edge of the third clock pulse in the T2 cycle
- CBR refresh cycle: At the rising edge of the fourth clock pulse in the T2 cycle
- Other cycles in which the READY pin is effective: At the falling edge of a clock pulse in the T2 cycle

The number of waits specified with the PWCn register and that specified with READY input are ORed, that is, that having the greater number of waits is inserted.

# Caution The CLKOUT signal must be synchronized so that the setup/hold time of READY input is ensured. Otherwise, the operation cannot be guaranteed.

# 6.4.2 Wait Control during DMA Transfer

#### (1) During two-cycle DMA transfer

- Read cycle: Dependent on the wait setting made for an address block specified with the SBN bit of the DMA source address register (DSA).
- Write cycle: Dependent on the wait setting made for an address block specified with the DBN bit of the DMA destination address register (DDA).

## (2) During fly-by DMA transfer

The 0-7 waits specified with the DWS0 and DWS1 bits of the PWC2 register can be inserted. An external  $\overline{\text{READY}}$  signal is effective at off-page access during the DRAM cycle and during the SRAM cycle of each block.

# 6.4.3 Bus Cycles during Which the Wait Function Is Effective

V821 supports the following wait insertion sources:

- Programmable wait (set with the PWC0 and PWC1 registers)
- Programmable wait (set with PWC2): During DMA fly-by transfer
- Wait with the READY pin
- Wait at off/on-page time in the DRAM cycle with DRAMC (fixed)
- Wait at off/on-page time in the page-ROM cycle with ROMC (fixed)

Table 6-1 lists the relationship between each bus cycle and the wait function. Table 6-2 lists the bus cycles for which programmable waits can be set, together with the corresponding control registers.

# Table 6-1. Bus Cycles during Which the Wait Function Is Effective

| Bus cycle                        |          | Programmable wait | Wait with the $\overline{\text{READY}}$ pin |  |  |
|----------------------------------|----------|-------------------|---------------------------------------------|--|--|
| SRAM (ROM) cycle (Blocks 0-3     | )        | 0-7 waits         | 0                                           |  |  |
| DRAM cycle (Block 0)             | off-page | 2 or 3 waits      | 0                                           |  |  |
|                                  | on-page  | 0 or 1 wait       | x                                           |  |  |
| Page-ROM cycle (Block 3)         | off-page | 0-7 waits         | x                                           |  |  |
|                                  | on-page  | 0 or 1 wait       | x                                           |  |  |
| External I/O cycle (Blocks 0-2)  |          | 0-7 waits         | 0                                           |  |  |
| Internal I/O cycle (Block 3)     |          | 1 or 2 waits      | x                                           |  |  |
| CBR refresh cycle                |          | Fixed (3 waits)   | 0                                           |  |  |
| CBR self-refresh cycle           |          | -                 | x                                           |  |  |
| Fly-by DMA transfer              |          |                   |                                             |  |  |
| SRAM (ROM) cycle (Blocks 0       | -3)      | 0-7 waits         | 0                                           |  |  |
| DRAM cycle (Block 0)             | off-page | 2-7 waits         | 0                                           |  |  |
|                                  | on-page  | 0-7 waits         | x                                           |  |  |
| Page-ROM cycle (Block 3)         | off-page | 0-7 waits         | x                                           |  |  |
|                                  | on-page  | 0-7 waits         | x                                           |  |  |
| Halt acknowledge cycle           |          | Fixed (0 wait)    | x                                           |  |  |
| Machine fault cycle (I/O block 0 | write)   | 0-7 wait          | 0                                           |  |  |

Remark o: Effective

x: Not effective



| Table 6-2. | Cycles during Which Programmable Waits Can Be Set, and |
|------------|--------------------------------------------------------|
|            | Corresponding Control Registers                        |

| Bus cyc             | le       | Control register                                                                                  |  |  |  |  |  |
|---------------------|----------|---------------------------------------------------------------------------------------------------|--|--|--|--|--|
| SRAM (ROM) cycle    |          | Programmable wait control registers 0 and 1 (PWC0 and PWC1)                                       |  |  |  |  |  |
| DRAM cycle          | off-page | DRAM configuration register (DRC)                                                                 |  |  |  |  |  |
|                     | on-page  |                                                                                                   |  |  |  |  |  |
| Page-ROM cycle      | off-page | Programmable wait control register 1 (PWC1)                                                       |  |  |  |  |  |
|                     | on-page  | Page-ROM configuration register (PRC)                                                             |  |  |  |  |  |
| External I/O cycle  |          | Programmable wait control registers 0 and 1 (PWC0 and PWC1)                                       |  |  |  |  |  |
| Fly-by DMA transfer |          |                                                                                                   |  |  |  |  |  |
| SRAM (ROM) cycle    |          | Programmable wait control register 2 (PWC2)                                                       |  |  |  |  |  |
| DRAM cycle          | off-page | Programmable wait control register 2 (PWC2) and DRAM configuration register (DRC) <sup>Note</sup> |  |  |  |  |  |
|                     | on-page  | Programmable wait control register 2 (PWC2)                                                       |  |  |  |  |  |
| Page-ROM cycle      | off-page |                                                                                                   |  |  |  |  |  |
|                     | on-page  |                                                                                                   |  |  |  |  |  |
| Machine fault cycle |          | Programmable wait control register 0 (PWC0)                                                       |  |  |  |  |  |

Note See Table 6-3.

# 6.5 CONTROL REGISTERS

WCU includes a bus cycle type control register (BCTC) and programmable wait control registers 0-2 (PWC0-PWC2), used for wait control.

# 6.5.1 Bus Cycle Type Control Register (BCTC)

This register is used to set the bus cycle types for address blocks 0-3. The register supports read/write in units of eight bits.

|      | 7 | 6   | 5 | 4   | 3 | 2   | 1  | 0 |                      |                    |
|------|---|-----|---|-----|---|-----|----|---|----------------------|--------------------|
| BCTC | 0 | СТЗ | 0 | CT2 | 0 | CT1 | СТ | 0 | Address<br>C0000020H | When reset,<br>01H |

| Bit position | Bit name |                                                                                                                                                                                  | Description                                                                                                                                                                          |                                                |                                                                                                                                                                                                                                                                                                                              |                      |  |  |  |  |  |
|--------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|--|--|--|--|--|
| 6            | СТЗ      | When<br>Specifi<br>0: S                                                                                                                                                          | ycle Type3<br>hen memory block 3 is accessed, the $\overline{CS3}$ signal is output.<br>becifies the cycle to be activated at that time.<br>0: SRAM (ROM) cycle<br>1: Page-ROM cycle |                                                |                                                                                                                                                                                                                                                                                                                              |                      |  |  |  |  |  |
| 4            | CT2      | Specifi<br>togeth<br>0: S                                                                                                                                                        | Cycle Type2<br>Specifies whether the CS2 signal should be output at memory or I/O access,<br>together with the cycle to be activated.<br>0: SRAM (ROM) cycle<br>1: I/O cycle         |                                                |                                                                                                                                                                                                                                                                                                                              |                      |  |  |  |  |  |
| 2            | CT1      | Cycle Type1<br>Specifies whether the CS1 signal should be output at memory or I/O access,<br>together with and the cycle to be activated.<br>0: SRAM (ROM) cycle<br>1: I/O cycle |                                                                                                                                                                                      |                                                |                                                                                                                                                                                                                                                                                                                              |                      |  |  |  |  |  |
| 1, 0         | СТО      | togeth<br>For the<br>an I/O<br>CS0 of                                                                                                                                            | es whe<br>er with<br>e DRAM<br>block,                                                                                                                                                | the cycle<br>I cycle,<br>or for RI<br>CT0 = 11 | $\overline{\text{CS0}}$ signal should be output at memory or I/O<br>to be activated.<br>the $\overline{\text{CS0}}/\text{REFRQ}$ pin can be specified for $\overline{\text{CS0}}$ of<br>$\overline{\text{FRQ}}$ output for DRAM. When the pin is speci<br>), the $\overline{\text{CS0}}$ signal becomes active at both I/O a | output for ified for |  |  |  |  |  |
|              |          |                                                                                                                                                                                  | C.                                                                                                                                                                                   | ТО                                             | Cycle to be activated                                                                                                                                                                                                                                                                                                        |                      |  |  |  |  |  |
|              |          |                                                                                                                                                                                  | 0                                                                                                                                                                                    | 0                                              | SRAM (ROM) cycle                                                                                                                                                                                                                                                                                                             |                      |  |  |  |  |  |
|              |          |                                                                                                                                                                                  | 0                                                                                                                                                                                    | 1                                              | DRAM cycle (REFRQ output)                                                                                                                                                                                                                                                                                                    |                      |  |  |  |  |  |
|              |          |                                                                                                                                                                                  | 1                                                                                                                                                                                    | 0                                              | I/O cycle                                                                                                                                                                                                                                                                                                                    |                      |  |  |  |  |  |
|              |          | 1 1 I/O cycle, DRAM cycle (CS0 output)                                                                                                                                           |                                                                                                                                                                                      |                                                |                                                                                                                                                                                                                                                                                                                              |                      |  |  |  |  |  |

# <sup>cl</sup> Phase-out/Discontinued

# 6.5.2 Programmable Wait Control Register 0 (PWC0)

This register is used to set the number of waits for access to address blocks 0 and 1.

The register supports read/write in units of eight bits.



| Bit position | Bit name | Description                       |                                  |                                    |                                   |                                                                                                                                                                               |        |  |  |  |  |
|--------------|----------|-----------------------------------|----------------------------------|------------------------------------|-----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|--|--|--|--|
| 6-4          | WS1      | CS1 s                             | ies the i<br>ignal is            |                                    | d, the nu                         | When address block 1 correspondin<br>umber of wait states specified with W                                                                                                    |        |  |  |  |  |
|              |          |                                   |                                  | WS1                                |                                   | Number of waits                                                                                                                                                               |        |  |  |  |  |
|              |          |                                   | 0                                | 0                                  | 0                                 | 0                                                                                                                                                                             |        |  |  |  |  |
|              |          |                                   | 0                                | 0                                  | 1                                 | 1                                                                                                                                                                             |        |  |  |  |  |
|              |          |                                   | 0                                | 1                                  | 0                                 | 2                                                                                                                                                                             |        |  |  |  |  |
|              |          |                                   | 0                                | 1                                  | 1                                 | 3                                                                                                                                                                             |        |  |  |  |  |
|              |          |                                   | 1                                | 0                                  | 0                                 | 4                                                                                                                                                                             |        |  |  |  |  |
|              |          |                                   | 1                                | 0                                  | 1                                 | 5                                                                                                                                                                             |        |  |  |  |  |
|              |          |                                   | 1                                | 1                                  | 0                                 | 6                                                                                                                                                                             |        |  |  |  |  |
|              |          |                                   | 1                                | 1                                  | 1                                 | 7                                                                                                                                                                             |        |  |  |  |  |
| 2-0          | WS0      | Specif<br>numbe<br>DRAM<br>and DI | er of wai<br>cycle is<br>RAMC ii | t states<br>s specifie<br>nserts a | specifie<br>d with th<br>fixed wa | When address block 0 is accessed,<br>d with WS0 is automatically inserted.<br>he CT0 bit of the BCTC register, WS0<br>ait state(s).<br>waits to be inserted for an I/O block. | If the |  |  |  |  |
|              |          |                                   |                                  | WS0                                |                                   | Number of waits                                                                                                                                                               |        |  |  |  |  |
|              |          |                                   | 0                                | 0                                  | 0                                 | 0                                                                                                                                                                             |        |  |  |  |  |
|              |          |                                   | 0                                | 0                                  | 1                                 | 1                                                                                                                                                                             |        |  |  |  |  |
|              |          |                                   | 0                                | 1                                  | 0                                 | 2                                                                                                                                                                             |        |  |  |  |  |
|              |          |                                   | 0                                | 1                                  | 1                                 | 3                                                                                                                                                                             |        |  |  |  |  |
|              |          |                                   | 1                                | 0                                  | 0                                 | 4                                                                                                                                                                             |        |  |  |  |  |
|              |          |                                   | 1                                | 0                                  | 1                                 | 5                                                                                                                                                                             |        |  |  |  |  |
|              |          |                                   |                                  |                                    |                                   |                                                                                                                                                                               |        |  |  |  |  |
|              |          |                                   | 1                                | 1                                  | 0                                 | 6                                                                                                                                                                             |        |  |  |  |  |

# 6.5.3 Programmable Wait Control Register 1 (PWC1)

This register is used to set the number of waits for access to address blocks 2 and 3. The register supports read/write in units of eight bits.



| Bit position | Bit name | Description               |                                |                        |                      |                                                                                                                                                    |          |  |  |  |  |
|--------------|----------|---------------------------|--------------------------------|------------------------|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|----------|--|--|--|--|
| 6-4          | WS3      | numbe<br>page-F           | ies the<br>er of wai<br>ROM cy | it states<br>cle is sp | specifie<br>ecified  | . When address block 3 is accessed, th<br>of with WS3 is automatically inserted. If<br>with the CT3 bit of the BCTC register, th<br>me is assumed. | the      |  |  |  |  |
|              |          |                           |                                | WS3                    |                      | Number of waits                                                                                                                                    |          |  |  |  |  |
|              |          |                           | 0                              | 0                      | 0                    | 0                                                                                                                                                  |          |  |  |  |  |
|              |          |                           | 0                              | 0                      | 1                    | 1                                                                                                                                                  |          |  |  |  |  |
|              |          |                           | 0                              | 1                      | 0                    | 2                                                                                                                                                  |          |  |  |  |  |
|              |          |                           | 0                              | 1                      | 1                    | 3                                                                                                                                                  |          |  |  |  |  |
|              |          |                           | 1                              | 0                      | 0                    | 4                                                                                                                                                  |          |  |  |  |  |
|              |          |                           | 1                              | 0                      | 1                    | 5                                                                                                                                                  |          |  |  |  |  |
|              |          |                           | 1                              | 1                      | 0                    | 6                                                                                                                                                  |          |  |  |  |  |
|              |          |                           | 1                              | 1                      | 1                    | 7                                                                                                                                                  |          |  |  |  |  |
| 2-0          | WS2      | Wait S<br>Specif<br>numbe | ies the i                      | number<br>it states    | of waits<br>specifie | . When memory or I/O block 2 is acces<br>d with WS2 is automatically inserted.                                                                     | sed, the |  |  |  |  |
|              |          |                           |                                | WS2                    |                      | Number of waits                                                                                                                                    |          |  |  |  |  |
|              |          |                           | 0                              | 0                      | 0                    | 0                                                                                                                                                  |          |  |  |  |  |
|              |          |                           | 0                              | 0                      | 1                    | 1                                                                                                                                                  |          |  |  |  |  |
|              |          |                           | 0                              | 1                      | 0                    | 2                                                                                                                                                  |          |  |  |  |  |
|              |          |                           | 0                              | 1                      | 1                    | 3                                                                                                                                                  |          |  |  |  |  |
|              |          |                           | 1                              | 0                      | 0                    | 4                                                                                                                                                  |          |  |  |  |  |
|              |          |                           | 1                              | 0                      | 1                    | 5                                                                                                                                                  |          |  |  |  |  |
|              |          |                           | 1                              | 1                      | 0                    | 6                                                                                                                                                  |          |  |  |  |  |
|              |          | 1                         |                                |                        |                      |                                                                                                                                                    |          |  |  |  |  |

# 6.5.4 Programmable Wait Control Register 2 (PWC2)

This register is used to set the number of waits for fly-by DMA transfer.

The register is used to set the number of waits to be inserted during fly-by DMA transfer, during which memory access (DRAM, page-ROM, ROM, and SRAM) and I/O access are performed concurrently.

This register supports read/write in units of eight bits.



| Bit position | Bit name | Description |                                |      |          |                                                  |  |  |  |  |
|--------------|----------|-------------|--------------------------------|------|----------|--------------------------------------------------|--|--|--|--|
| 6-4          | DWS1     |             | Vait Sta<br>ies the i<br>el 1. |      | of waits | s to be inserted during fly-by transfer with DMA |  |  |  |  |
|              |          |             |                                | DWS1 |          | Number of waits                                  |  |  |  |  |
|              |          |             | 0                              | 0    | 0        | 0                                                |  |  |  |  |
|              |          |             | 0                              | 0    | 1        | 1                                                |  |  |  |  |
|              |          |             | 0                              | 1    | 0        | 2                                                |  |  |  |  |
|              |          |             | 0                              | 1    | 1        | 3                                                |  |  |  |  |
|              |          |             | 1                              | 0    | 0        | 4                                                |  |  |  |  |
|              |          |             | 1                              | 0    | 1        | 5                                                |  |  |  |  |
|              |          |             | 1                              | 1    | 0        | 6                                                |  |  |  |  |
|              |          |             | 1                              | 1    | 1        | 7                                                |  |  |  |  |
| 2-0          | DWS0     |             | Vait Sta<br>ies the i<br>el 0. |      | of waits | s to be inserted during fly-by transfer with DMA |  |  |  |  |
|              |          |             |                                | DWS0 |          | Number of waits                                  |  |  |  |  |
|              |          |             | 0                              | 0    | 0        | 0                                                |  |  |  |  |
|              |          |             | 0                              | 0    | 1        | 1                                                |  |  |  |  |
|              |          |             | 0                              | 1    | 0        | 2                                                |  |  |  |  |
|              |          |             | 0                              | 1    | 1        | 3                                                |  |  |  |  |
|              |          |             | 1                              | 0    | 0        | 4                                                |  |  |  |  |
|              |          |             |                                |      | 1        |                                                  |  |  |  |  |
|              |          |             | 1                              | 0    | 1        | 5                                                |  |  |  |  |
|              |          |             | 1                              | 0    | 1<br>0   | 5<br>6                                           |  |  |  |  |

At off-page time during the DRAM cycle, and when the  $\overline{CS0}$  signal is specified for the DRAM cycle (CT0 in the BCTC register = 01 or 11), the number of waits for fly-by DMA transfer to and from memory block 0 will be influenced by the CWS bit of the DRAM configuration register (DRC), as follows:

# Table 6-3. Number of Waits to Be Inserted during Fly-by DMA Transfer(at off-page Time during DRAM Cycle)

| Number of waits specified with the CWS bit |   |   |   | 2 | 2 |   |   |   |   |   |   | 3 | 3 |   |   |   |
|--------------------------------------------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| Number of waits specified with the DWS bit | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
| Number of waits                            | 2 | 2 | 2 | 3 | 4 | 5 | 6 | 7 | 3 | 3 | 3 | 3 | 4 | 5 | 6 | 7 |



# CHAPTER 7 MEMORY ACCESS CONTROL FUNCTIONS

#### 7.1 DRAM CONTROLLER (DRAMC)

The DRAM controller (DRAMC) generates the REFRQ, RAS, LCAS, and UCAS signals, and controls access to DRAM. Access to DRAM is achieved by multiplexing the DRAM row and column addresses and outputting them from the address pins.

The microprocessor assumes the connected DRAM to be of x 4 bits or more, and that it supports high-speed page mode. There are two types of DRAM access cycles, on-page (2 or 3 clock pulses) and off-page (4 or 5 pulses).

Refresh uses the  $\overline{CAS}$  before  $\overline{RAS}$  method, allowing the user to set any refresh period. In idle and STOP modes, CBR self-refresh is performed.

#### 7.1.1 Features

- Generates the REFRQ, RAS, LCAS, and UCAS signals.
- Supports DRAM high-speed page mode.
- Address multiplexing function: 8, 9, 10, and 11 bits
- · CBR refresh and CBR self-refresh functions

#### 7.1.2 Connecting DRAM

The V821 can be directly connected to DRAM of x 4 bits or more, and which supports a high-speed page mode function (512 Kbytes to 8 Mbytes).

The DRAM cycle is activated upon being selected with CT0 of the bus cycle type control register (BCTC) and address block 0 is accessed.

Table 7-1 lists the DRAM control pins of the V821.

| V821 DRAM control pins | DRAM pins    |
|------------------------|--------------|
| A0-A23                 | Address pins |
| D0-D15                 | Data pins    |
| RAS, REFRQ             | RAS          |
| LCAS                   | CAS          |
| UCAS                   |              |
| WE                     | WE           |
| MRD                    | ŌĒ           |

#### Table 7-1. DRAM Control Pins

# Phase-out/Discontinued

Byte control during DRAM access is performed using only the  $\overline{\text{LCAS}}$  and  $\overline{\text{UCAS}}$  signals. Thus, throughout DRAM access, the  $\overline{\text{UMWR}}$  signals are inactive. To prevent the DRAM from entering test mode, the  $\overline{\text{WE}}$  signal is always inactive during the refresh cycle. **Chapter 2** explains each pin in detail.

Figures 7-1 and 7-2 show examples of connecting DRAM.



Figure 7-1. Connection of 16-Mbyte (1-Mbyte x 16) DRAM





CHAPTER 7 ME Phase-out/Discontinued

#### 7.1.3 Address Multiplexing Function

In the DRAM cycle, row and column addresses are multiplexed according to the value of the DAW bits of the DRAM configuration register (DRC), then output, as shown in Figure 7-3. In Figure 7-3, a0-a23 are the addresses output from the CPU, while A0-A23 are the address pins of the V821. For example, if DAW = 11, row address a12-a22 and column address a1-a11 are output from address pins (A1-A11).

Table 7-2 lists the relationship between the connectable DRAMs and address multiplexing widths. Depending on the connected DRAM, the DRAM space can be between 128 Kbytes and 8 Mbytes.



#### Figure 7-3. Output of Row and Column Addresses



| Address multiplexing width | DRAM c   | apacity (in bi | DRAM space (in bytes) |          |       |
|----------------------------|----------|----------------|-----------------------|----------|-------|
|                            | 256 K    | 1 M            | 4 M                   | 16 M     |       |
| 8 bits                     | 64 K x 4 | -              | -                     | -        | 128 K |
| 9 bits                     | -        | 256 K x 4      | 256 K x 16            | -        | 512 K |
|                            | -        | -              | 512 K x 8             | -        | 1 M   |
| 10 bits                    | -        | -              | 1 M x 4               | 1 M x 16 | 2 M   |
|                            | -        | -              | -                     | 2 M x 8  | 4 M   |
| 11 bits                    | -        | -              | -                     | 4 M x 4  | 8 M   |

# 7.1.4 DRAM Configuration Register (DRC)

This register is used to set the address multiplexing width, number of waits, and the data output timing used during DRAM access.

The register supports read/write in units of eight bits.



| Bit position | Bit name |                                                                                                                          | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |    |                                             |               |  |  |  |  |
|--------------|----------|--------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|---------------------------------------------|---------------|--|--|--|--|
| 7            | ADC      | Sets th<br>Effection<br>0: 1<br>1: 1<br>During                                                                           | <ul> <li>Avoid Data Conflict</li> <li>Sets the output timing of the write data.</li> <li>Effective during SRAM and I/O cycles other than the DRAM cycle.</li> <li>0: The output of data starts at the falling edge of a clock pulse in T1.</li> <li>1: The output of data starts at the rising edge of a clock pulse in T2.</li> <li>During the DRAM on-page write cycle, one wait state is inserted when ADC is</li> <li>1, unless the previous cycle was a write cycle.</li> </ul> |    |                                             |               |  |  |  |  |
| 6            | PAE      | Contro<br>high-sı<br>0: A                                                                                                | Page-mode Access Enable<br>Controls the activation of the on-page access cycle conforming to the DRAM<br>high-speed page mode.<br>0: Activation disabled<br>1: Activation enabled                                                                                                                                                                                                                                                                                                    |    |                                             |               |  |  |  |  |
| 2            | CWS      | Compulsory Wait State<br>Sets the number of waits to be inserted in the DRAM off-page cycle.<br>0: 2 waits<br>1: 3 waits |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |    |                                             |               |  |  |  |  |
| 1, 0         | DAW      | Sets th                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |    | iplexing width used when a row address is o | output during |  |  |  |  |
|              |          |                                                                                                                          | DA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | ٩W | Multiplexing width                          |               |  |  |  |  |
|              |          |                                                                                                                          | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0  | 8 bits                                      |               |  |  |  |  |
|              |          |                                                                                                                          | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 1  | 9 bits                                      |               |  |  |  |  |
|              |          |                                                                                                                          | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0  | 10 bits                                     |               |  |  |  |  |
|              |          |                                                                                                                          | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 1  | 11 bits                                     |               |  |  |  |  |

# 7.1.5 DRAM Read/Write Cycles

The DRAM cycle is activated when CT0 of the BCTC register is 01 or 11 address block 0 is accessed. The width of the row and column addresses to be output to DRAM is selected by setting the DAW bits of the DRC register.

The DRAM write cycle is an early write cycle.

There are two types of DRAM read/write cycles, on-page cycle and off-page cycle, according to the number of clock pulses in the cycle and the timing of the DRAM control signals ( $\overline{RAS}$ ,  $\overline{LCAS}$ , and  $\overline{UCAS}$ ). In the on-page write cycle, a wait state is inserted when ADC of the DRC register is 1, unless the previous cycle was a write cycle.

| Cycle          | Conditions                                                                                                                          | Number of clock pulses |
|----------------|-------------------------------------------------------------------------------------------------------------------------------------|------------------------|
| on-page cycle  | • RAS = 0 and the same row address as that in the previous DRAM read or write cycle                                                 | 2 (0 wait)Note         |
| off-page cycle | <ul> <li>RAS = 1</li> <li>RAS = 0 and a row address that differs from that used in the previous DRAM read or write cycle</li> </ul> | 4 + n<br>(2 + n waits) |

**Note** During the write cycle, when ADC of the DRC register is 1 and the previous bus cycle was a read cycle for other than internal I/O: 3 (1 wait) clock pulses

Remark n: Values of the CWS bits of the DRC register

Once active, the RAS signal remains active until an off-page cycle or refresh cycle occurs; when an offpage cycle occurs, the signal becomes active again after the completion of RAS precharge; when a refresh cycle occurs, it becomes inactive after performing refresh.

In an off-page cycle, wait control can be applied by using the READY pin.

- The DRAM cycle for address block 0 is always in the off-page cycle after the I/O cycle.
- \*



## Figure 7-4. DRAM Read Cycle

Phase-out/Discontinued

Remarks 1. ROW : Row address

- **2.** A broken line indicates a high impedance.
- **3.** An arrow indicates a sampling timing.

# CHAPTER 7 ME Phase-out/Discontinued



# (1) When ADC = 0



Remarks 1. ROW : Row address

- COL : Column address
- 2. A broken line indicates a high impedance.
- **3.** An arrow indicates a sampling timing.



# (2) When ADC = 1



Remarks 1. ROW : Row address

- 2. A broken line indicates a high impedance.
- 3. An arrow indicates a sampling timing.

# 7.1.6 Wait Control for DRAM Cycle

Programmable wait control for the DRAM cycle is possible during fly-by DMA transfer only. The number of waits to be inserted is set with programmable wait control register 2 (PWC2). (See **Section 6.5.4**.)

The timing of wait insertion differs during read and write. During DRAM read, the access time for the  $\overline{LCAS}$  and  $\overline{UCAS}$  signals is extended; during DRAM write, the timing at which the  $\overline{LCAS}$  and  $\overline{UCAS}$  signal become active is delayed.

Wait control using the external READY pin is effective during the off-page cycle for normal DRAM access, DRAM access with fly-by DMA, and during the CBR refresh cycle.

The READY signal is sampled from the T2 cycle at the third clock pulse, at the rising edge of the clock pulse, half a clock pulse earlier than during a normal SRAM cycle.

Figures 7-6 and 7-7 show the timings of the DRAM read and write cycles when waits are inserted.

# Figure 7-6. Insertion of Wait State (1 Wait) during DRAM Read for Fly-by DMA Transfer (DRAM to External I/O)



# Remarks 1. ROW : Row address

- **2.** A broken line indicates a high impedance.
- 3. An arrow indicates a sampling timing.





Phase-out/Discontinued

Remarks 1. ROW : Row address

- **2.** A broken line indicates a high impedance.
- **3.** An arrow indicates a sampling timing.

# CHAPTER 7 ME Phase-out/Discontinued

# 7.1.7 Refresh Function

DRAMC can automatically generate the distributed CBR refresh cycle needed to refresh external DRAM. Whether refresh should be enabled or disabled, and the refresh interval, are specified using the refresh control register (RFC).

While another bus master is occupying a bus, DRAMC cannot forcibly acquire the bus. In this case, in response to a refresh request issued from DRAMC, BAU makes the  $\overline{HLDAK}$  pin inactive to post notification of the occurrence of a refresh request. In this state, by making the  $\overline{HLDRQ}$  pin inactive, the refresh cycle is activated. **Section 5.3** explains the priorities of bus cycles other than refresh.

# (1) Refresh control register (RFC)

This register is used to specify whether refresh should be enabled or disabled, as well as the refresh interval.

The refresh interval is determined using the following formula:

Refresh interval (in  $\mu$ s) = Refresh count clock pulses (TRCY) x Interval factor

The refresh count clock pulses and interval factor are specified with the RCC and RI bits of the RFC register, respectively.

The register supports read/write in units of eight bits.



| Bit position | Bit name | Description                                                                                                                                 |                                                                                                                                               |   |   |   |   |    |  |  |  |  |  |  |
|--------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|----|--|--|--|--|--|--|
| 7            | REN      | Specif<br>0: F                                                                                                                              | Refresh Enable<br>Specifies whether to enable or disable CBR refresh.<br>0: Refresh disabled<br>1: Refresh enabled                            |   |   |   |   |    |  |  |  |  |  |  |
| 6            | RCC      | Specif<br>0: 1                                                                                                                              | Refresh Count Clock<br>Specifies refresh count clock pulses (T <sub>RCY</sub> ).<br>0: T <sub>RCY</sub> = 32/φ<br>1: T <sub>RCY</sub> = 128/φ |   |   |   |   |    |  |  |  |  |  |  |
| 5-0          | RI       | Refresh Interval         Sets the interval factor for the interval timer used for creating refresh timing.         RI       Interval factor |                                                                                                                                               |   |   |   |   |    |  |  |  |  |  |  |
|              |          |                                                                                                                                             |                                                                                                                                               | 0 | 0 | 0 | 0 | 4  |  |  |  |  |  |  |
|              |          |                                                                                                                                             | 0                                                                                                                                             | 0 |   |   | 0 | 1  |  |  |  |  |  |  |
|              |          |                                                                                                                                             | 0                                                                                                                                             | 0 | 0 | 0 | 1 | 2  |  |  |  |  |  |  |
|              |          |                                                                                                                                             | 0                                                                                                                                             | 0 | 0 | 1 | 0 | 3  |  |  |  |  |  |  |
|              |          |                                                                                                                                             |                                                                                                                                               |   | : |   |   | :  |  |  |  |  |  |  |
|              |          |                                                                                                                                             | 1                                                                                                                                             | 1 | 1 | 1 | 1 | 64 |  |  |  |  |  |  |
|              |          |                                                                                                                                             |                                                                                                                                               |   |   |   |   |    |  |  |  |  |  |  |

# **Phase-out/Discontinued**

# (2) DRAM refresh intervals and examples of setting the RFC register

Table 7-4 lists the refresh cycles and the refresh intervals for a DRAM of between 256 Kbits to 16 Mbits. Table 7-5 lists examples of setting the interval factor (set with the RI bit of the RFC register) needed to determine the refresh interval.

| Capacity | Refresh cycles (cycles/ms) | Refresh interval (µs) |
|----------|----------------------------|-----------------------|
| 256 K    | 256/4                      | 15.6                  |
| 1 M      | 512/8                      | 15.6                  |
|          | 512/64                     | 125                   |
| 4 M      | 512/128                    | 250                   |
|          | 1 K/16                     | 15.6                  |
|          | 1 K/128                    | 125                   |
| 16 M     | 1 K/256                    | 250                   |
|          | 2 K/256                    | 125                   |
|          | 4 K/64                     | 15.6                  |
|          | 4 K/256                    | 62.5                  |

#### Table 7-4. DRAM Refresh Intervals

# Table 7-5. Examples of Setting the Interval Factor

#### • When Trcy = $32/\phi$

| Standard refresh interval (µs) | Value of the interval factor |           |           |           |  |  |  |  |
|--------------------------------|------------------------------|-----------|-----------|-----------|--|--|--|--|
|                                | 12.5 MHz                     | 16 MHz    | 20 MHz    | 25 MHz    |  |  |  |  |
| 15.6                           | 5 (12.8)                     | 7 (14.0)  | 9 (14.4)  | 11 (14.1) |  |  |  |  |
| 62.5                           | 24 (61.4)                    | 31 (62.0) | 38 (60.8) | 48 (61.4) |  |  |  |  |
| 125                            | 48 (122.9)                   | 62 (124)  | -         | -         |  |  |  |  |
| 250                            | -                            | -         | -         | -         |  |  |  |  |

• When Trcy =  $128/\phi$ 

| Standard refresh interval (μs) | Value of the interval factor |            |            |            |  |  |  |  |
|--------------------------------|------------------------------|------------|------------|------------|--|--|--|--|
|                                | 12.5 MHz                     | 16 MHz     | 20 MHz     | 25 MHz     |  |  |  |  |
| 15.6                           | -                            | -          | -          | -          |  |  |  |  |
| 62.5                           | -                            | -          | -          | -          |  |  |  |  |
| 125                            | -                            | -          | 19 (121.6) | 24 (122.9) |  |  |  |  |
| 250                            | 24 (245.8)                   | 31 (248.0) | 38 (243.2) | 48 (245.8) |  |  |  |  |

**Remark** The values in parentheses are calculated refresh interval values (µs).

-: Not applicable.

# (3) CBR refresh cycle

The refresh cycle is performed by holding the bus, as shown in Figure 7-8. One bus cycle requires at least seven clock pulses, or at least nine clock pulses when including the preceding and succeeding idle cycles.



Figure 7-8. CBR Refresh Cycle

Remarks 1. A broken line indicates a high impedance.

**2.** An arrow indicates a sampling timing.

DRAMC generates the CBR self-refresh cycle in idle and STOP modes. The self-refresh cycle is activated by setting the SMD bit of the standby control register (STBC) to idle or STOP mode and executing the HALT instruction.

Phase-out/Discontinue

To enable DRAM to perform self-refresh, the standard  $\overline{RAS}$  pulse width for DRAM (100 µs or greater) must be ensured.

Self-refresh is canceled using the RESET or NMI pin. The procedure for cancellation by RESET input is the same as that for normal reset. The other procedures for canceling self-refresh are explained below.

# (1) Cancellation with NMI input

As soon as an  $\overline{\text{NMI}}$  interrupt occurs during the CBR self-refresh cycle in IDLE mode, DRAMC makes the  $\overline{\text{REFRQ}}$ ,  $\overline{\text{RAS}}$ ,  $\overline{\text{LCAS}}$ , and  $\overline{\text{UCAS}}$  signals inactive to cancel CBR self-refresh.

When an NMI interrupt occurs during the CBR self-refresh cycle in STOP mode, DRAMC secures the time required for oscillation to settle, then makes the above signals inactive, thus canceling CBR self-refresh.

# Figure 7-9. Cancellation of CBR Self Refresh with NMI Input

#### (a) In IDLE mode



**Remarks 1.** A broken line indicates a high impedance.

2. The noise eliminator introducing an analog delay is used for input of NMI. Therefore, the time from when NMI is input until REFRQ, RAS, LCAS, and UCAS become inactive depends on the use condition.

# CHAPTER 7 ME Phase-out/Discontinued

# (b) In STOP mode



**Remark** A broken line indicates a high impedance.

# (2) Cancellation with HLDRQ input (in IDLE mode)

When a hold request is issued during the CBR self-refresh cycle in IDLE mode, the DRAM control pins are set to high impedance and enter the bus hold state. When the hold request is canceled, the CBR self refresh cycle is reactivated.







2. An arrow indicates a sampling timing.

# 7.2 ROM CONTROLLER (ROMC)

The ROM controller supports access to ROM having a page access function (page-ROM).

The ROM controller performs address comparison with the previous bus cycle and performs wait control

for normal access (off-page)/page access (on-page). It supports page widths of 8-64 bytes.

The page-ROM cycle is supported with address block 3.

#### 7.2.1 on-page/off-page Decision

Whether the page-ROM cycle is on-page or off-page is determined by latching the address during the previous cycle and comparing it with the address during the current cycle.

The address(es) (A3-A5) to be masked (not compared) is set using the page-ROM configuration register (PRC), according to the configuration of the connected page-ROM and the number of consecutively readable bits.

#### Figure 7-11. on-page/off-page Decision When ROM Having a Page Access Function Is Connected

# (1) For 16-Mbit ROM (1-Mbit x 16)



Consecutively readable bits: 16 bits x 4

# (2) For 16-Mbit ROM (2-Mbit x 8)



Consecutively readable bits: 8 bits x 8

CHAPTER 7 ME Phase-out/Discontinued

#### 7.2.2 Page-ROM Access

Access to page-ROM is made with 0 or 1 wait during the on-page cycle, and with 0-7 waits during the offpage cycle. The number of waits in the on-page cycle is specified with the WA bit of the page-ROM configuration register (PRC).

Figure 7-12 shows the timing of the page-ROM cycle. Figures 7-13 and 1-14 show examples of connecting page-ROM to the V821.





**Remark** A broken line indicates a high impedance.









CHAPTER 7 ME Phase-out/Discontinued

# 7.2.3 Page-ROM Configuration Register (PRC)

This register is used to set the address(es) (A3-A5) to be masked (not compared) according to the configuration of the connected page-ROM and the number of consecutively readable bits. It is also used to set a wait according to the system clock.

The register supports read/write in units of eight bits.



| Bit position | Bit name | Description                                                                                                                                                                                                                                                                                 |     |     |                                        |  |  |  |  |  |                                             |  |  |  |  |
|--------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-----|----------------------------------------|--|--|--|--|--|---------------------------------------------|--|--|--|--|
| 7            | WA       | <ul> <li>Wait Adjustment</li> <li>Sets a wait according to the system clock.</li> <li>The wait set with this bit is inserted in the on-page cycle only. In the off-page cycle, the wait(s) set with WS3 of the PWC1 register are inserted.</li> <li>0: 0 wait</li> <li>1: 1 wait</li> </ul> |     |     |                                        |  |  |  |  |  |                                             |  |  |  |  |
| 2-0          | MA5-MA3  | B) according to the values of MA5-MA3 (1 for<br>not compared as part of on/off-page decision.<br>number of consecutively readable bits.                                                                                                                                                     |     |     |                                        |  |  |  |  |  |                                             |  |  |  |  |
|              |          | MA5                                                                                                                                                                                                                                                                                         | MA4 | MA3 | Number of consecutively readable bits  |  |  |  |  |  |                                             |  |  |  |  |
|              |          | 0                                                                                                                                                                                                                                                                                           | 0   | 0   | 4 words x 16 bits (8 words x 8 bits)   |  |  |  |  |  |                                             |  |  |  |  |
|              |          |                                                                                                                                                                                                                                                                                             |     |     |                                        |  |  |  |  |  | 0 0 1 8 words x 16 bits (16 words x 8 bits) |  |  |  |  |
|              |          |                                                                                                                                                                                                                                                                                             |     |     |                                        |  |  |  |  |  |                                             |  |  |  |  |
|              |          | 0                                                                                                                                                                                                                                                                                           | 1   | 1   | 16 words x 16 bits (32 words x 8 bits) |  |  |  |  |  |                                             |  |  |  |  |



[MEMO]



# CHAPTER 8 DMA FUNCTIONS (DMA CONTROLLER)

The V821 includes a DMA (Direct Memory Access) controller that executes and controls DMA transfer. The DMAC (DMA controller) transfers data between memory and I/O, or within memory, based on DMA requests issued by the built-in peripheral hardware (serial interfaces and timer), external DREQ pins, or software triggers.

# 8.1 FEATURES

- Two independent DMA channels
- Transfer units: 8/16 bits
- Maximum transfer count: 65,536 (216)
- Two types of transfer
  - Fly-by (one-cycle) transfer
  - Two-cycle transfer
- Three transfer modes
  - Single transfer mode
  - Single-step transfer mode
  - Block transfer mode
- Transfer requests
  - External DREQ pin (x 2)
  - Requests from built-in peripheral hardware (serial interfaces and timer)
  - Requests from software
- Transfer objects
  - Memory to I/O and vice versa
  - Memory to memory and vice versa
- Programmable wait function
- DMA transfer end output signal (TC)

# 8.2 CONFIGURATION



Figure 8-1. Block Diagram of DMAC

#### 8.3 DMA CONTROL REGISTERS

#### 8.3.1 DMA Source Address Registers 0 and 1 (DSA0 and DSA1)

These registers are used to set the DMA source addresses (24 bits each) and the DMA source address blocks for DMA channels 0 and 1. They are divided into two 16-bit registers, DSAnH and DSAnL, respectively. During DMA transfer, the registers store the next DMA source addresses.

When fly-by transfer is specified with the TTYP bits of the DMA channel control registers (DCHC0 and DCHC1), the memory addresses are set with the DSAn registers. The settings made with DMA destination address registers 0 and 1 (DDA0 and DDA1) are ignored.

# (1) DMA source address registers 0H and 1H (DSA0H and DSA1H)

These registers support read/write in 16-bit units.

|                | 15 | 14 | 13 | 12 | 11 | 10  | 98  | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |                                   |                                           |
|----------------|----|----|----|----|----|-----|-----|------|------|------|------|------|------|------|------|-----------------------------------|-------------------------------------------|
| DSA0H<br>DSA1H | 0  | 0  | 0  | 0  | 0  | SBT | SBN | SA23 | SA22 | SA21 | SA20 | SA19 | SA18 | SA17 | SA16 | Address<br>C0000040H<br>C0000048H | When reset,<br>Not defined<br>Not defined |

**CHAPTER 8** 

Phase-out/Discontinued

| Bit position | Bit name  |                                                                                                                                                                | Description                                                                                                                                                                 |    |               |  |  |  |  |  |  |
|--------------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|---------------|--|--|--|--|--|--|
| 10           | SBT       | Source Block Type<br>Specifies whether the source address block will be a memory or I/O block.<br>Must be set to 0 for fly-by transfer.<br>0: memory<br>1: I/O |                                                                                                                                                                             |    |               |  |  |  |  |  |  |
| 9, 8         | SBN       | Source Block Number<br>Specifies the source address block number.                                                                                              |                                                                                                                                                                             |    |               |  |  |  |  |  |  |
|              |           |                                                                                                                                                                | SE                                                                                                                                                                          | ЗN | Address block |  |  |  |  |  |  |
|              |           |                                                                                                                                                                | 0                                                                                                                                                                           | 0  | 0             |  |  |  |  |  |  |
|              |           |                                                                                                                                                                | 0                                                                                                                                                                           | 1  | 1             |  |  |  |  |  |  |
|              |           |                                                                                                                                                                | 1                                                                                                                                                                           | 0  | 2             |  |  |  |  |  |  |
|              |           |                                                                                                                                                                | 1                                                                                                                                                                           | 1  | 3             |  |  |  |  |  |  |
|              |           |                                                                                                                                                                |                                                                                                                                                                             |    |               |  |  |  |  |  |  |
| 7-0          | SA23-SA16 | Sets th                                                                                                                                                        | Source Address<br>Sets the DMA source address (A23-A16). During DMA transfer, it stores the<br>next DMA source address. During fly-by transfer, it stores a memory address. |    |               |  |  |  |  |  |  |

#### (2) DMA source address registers 0L and 1L (DSA0L and DSA1L)

The registers support read/write in 16-bit units.



| Bit position | Bit name | Description                                                                                                            |  |  |  |  |  |
|--------------|----------|------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 15-0         | SA15-SA0 | Source Address<br>Sets the DMA source address (A15-A0). During DMA transfer, it stores the<br>next DMA source address. |  |  |  |  |  |

# 8.3.2 DMA Destination Address Registers 0 and 1 (DDA0 and DDA1)

These registers are used to set the DMA destination addresses (24 bits each) and the DMA destination address blocks for DMA channels 0 and 1. They are divided into two 16-bit registers, DDAnH and DDAnL, respectively.

During DMA transfer, these registers store the next DMA destination addresses.

When fly-by transfer is specified with the TTYP bits of the DMA channel control registers (DCHC0 and DCHC1), the settings made with registers DDA0 and DDA1 are ignored.

# (1) DMA destination address registers 0H and 1H (DDA0H and DDA1H)

The registers allow read/write in 16-bit units.



| Bit position | Bit name  |                                                                                                                                 | Description                                                                                                                                                              |    |               |  |  |  |  |  |  |
|--------------|-----------|---------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|---------------|--|--|--|--|--|--|
| 10           | DBT       | Destination Block Type<br>Specifies whether the destination address block will be a memory or I/O block.<br>0: memory<br>1: I/O |                                                                                                                                                                          |    |               |  |  |  |  |  |  |
| 9, 8         | DBN       | Destination Block Number<br>Specifies the destination address block number.                                                     |                                                                                                                                                                          |    |               |  |  |  |  |  |  |
|              |           |                                                                                                                                 | DE                                                                                                                                                                       | BN | Address block |  |  |  |  |  |  |
|              |           |                                                                                                                                 | 0                                                                                                                                                                        | 0  | 0             |  |  |  |  |  |  |
|              |           |                                                                                                                                 | 0                                                                                                                                                                        | 1  | 1             |  |  |  |  |  |  |
|              |           |                                                                                                                                 | 1                                                                                                                                                                        | 0  | 2             |  |  |  |  |  |  |
|              |           | 1 1 3                                                                                                                           |                                                                                                                                                                          |    |               |  |  |  |  |  |  |
|              |           |                                                                                                                                 |                                                                                                                                                                          |    |               |  |  |  |  |  |  |
| 7-0          | DA23-DA16 | Sets th                                                                                                                         | Destination Address<br>Sets the DMA destination address (A23-A16). During DMA transfer, it stores<br>the next DMA source address. During fly-by transfer, it is ignored. |    |               |  |  |  |  |  |  |

# (2) DMA destination address registers 0L and 1L (DDA0L and DDA1L)

These registers support read/write in 16-bit units.

|                | 15   | 14   | 13   | 12   | 11   | 10   | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |                                   |                                           |
|----------------|------|------|------|------|------|------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----------------------------------|-------------------------------------------|
| DDA0L<br>DDA1L | DA15 | DA14 | DA13 | DA12 | DA11 | DA10 | DA9 | DA8 | DA7 | DA6 | DA5 | DA4 | DA3 | DA2 | DA1 | DA0 | Address<br>C0000046H<br>C000004EH | When reset,<br>Not defined<br>Not defined |

| Bit position | Bit name | Description                                                                                                                                                                  |
|--------------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-0         | DA15-DA0 | Destination Address<br>Sets the DMA destination address (A15-A0). During DMA transfer, it stores<br>the next DMA destination address. During fly-by transfer, it is ignored. |



#### 8.3.3 DMA Byte Count Registers 0 and 1 (DBC0 and DBC1)

These 16-bit registers are used to set the byte transfer counts for DMA channels 0 and 1.

They store the remaining transfer counts during DMA transfer.

These registers are decremented by 1 for byte transfer and by two for 16-bit transfer. Transfer ends when a borrow occurs. Thus, "transfer count -1" should be set for byte transfer and "(transfer count -1) x 2" for 16-bit transfer.

The registers support read/write in 16-bit units.



| Bit position | Bit name |                                                                                                                  | Description                                                                              |  |  |  |  |  |
|--------------|----------|------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|--|--|--|--|--|
| 15-0         | BC       | Byte Count<br>Sets the byte transfer count. During DMA transfer, it stores the remaining<br>byte transfer count. |                                                                                          |  |  |  |  |  |
|              |          |                                                                                                                  | BC State                                                                                 |  |  |  |  |  |
|              |          | 00H Byte transfer count 1 or the remaining byte transfer count                                                   |                                                                                          |  |  |  |  |  |
|              |          |                                                                                                                  | 01H Byte transfer count 2 or the remaining byte transfer count                           |  |  |  |  |  |
|              |          |                                                                                                                  |                                                                                          |  |  |  |  |  |
|              |          |                                                                                                                  | FFFFH Byte transfer count 65,536 (2 <sup>16</sup> ) or the remaining byte transfer count |  |  |  |  |  |
|              |          |                                                                                                                  |                                                                                          |  |  |  |  |  |

# Phase-out/Discontinued

#### 8.3.4 DMA Channel Control Registers 0 and 1 (DCHC0 and DCHC1)

These 16-bit registers are used to control the DMA transfer modes for DMA channels 0 and 1. Note that 16-bit transfer with an odd address is not possible. (The A0 pin must be set to 0). These registers support read/write in 16-bit units. (Bit 15 can be read only.)



| Bit position | Bit name |                                                                                                                                                                                                                                                                                         |           |    | Description        |  |  |  |
|--------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|----|--------------------|--|--|--|
| 15           | тс       | Terminal Count<br>This status bit indicates whether DMA transfer through DMA channel n has<br>ended.<br>This bit can only be read. It is set when DMA transfer ends with a terminal<br>count and reset when it is read.<br>0: DMA transfer has not ended.<br>1: DMA transfer has ended. |           |    |                    |  |  |  |
| 11, 10       | SAD      | Source Address count Direction<br>Sets the count direction of the source address for DMA channel n.                                                                                                                                                                                     |           |    |                    |  |  |  |
|              |          | SAD Count direction                                                                                                                                                                                                                                                                     |           |    |                    |  |  |  |
|              |          |                                                                                                                                                                                                                                                                                         | 0         | 0  | Increment          |  |  |  |
|              |          |                                                                                                                                                                                                                                                                                         | 0         | 1  | Decrement          |  |  |  |
|              |          |                                                                                                                                                                                                                                                                                         | 1 0 Fixed |    |                    |  |  |  |
|              |          | 1 1 Setting prohibited                                                                                                                                                                                                                                                                  |           |    |                    |  |  |  |
| 9, 8         | DAD      | Destination Address count Direction<br>Sets the count direction of the destination address for DMA channel n.                                                                                                                                                                           |           |    |                    |  |  |  |
|              |          |                                                                                                                                                                                                                                                                                         | DA        | ٩D | Count direction    |  |  |  |
|              |          |                                                                                                                                                                                                                                                                                         | 0         | 0  | Increment          |  |  |  |
|              |          |                                                                                                                                                                                                                                                                                         | 0         | 1  | Decrement          |  |  |  |
|              |          |                                                                                                                                                                                                                                                                                         | 1 0 Fixed |    |                    |  |  |  |
|              |          |                                                                                                                                                                                                                                                                                         | 1         | 1  | Setting prohibited |  |  |  |
|              |          |                                                                                                                                                                                                                                                                                         |           |    |                    |  |  |  |

CHAPTER 8 Phase-out/Discontinued

| Bit position | Bit name | Description                                                                                                                                                                                                                                                                                                                  |      |    |   |                                                    |  |  |
|--------------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----|---|----------------------------------------------------|--|--|
| 7-5          | ТТҮР     | Transfer Type<br>Sets the cause of the activation of DMA transfer and the transfer direction.                                                                                                                                                                                                                                |      |    |   |                                                    |  |  |
|              |          |                                                                                                                                                                                                                                                                                                                              | TTYP |    |   | Activation cause and transfer direction            |  |  |
|              |          |                                                                                                                                                                                                                                                                                                                              | 0    | 0  | 0 | Activated by the DREQn signal: two-cycle transfer  |  |  |
|              |          |                                                                                                                                                                                                                                                                                                                              | 0    | 0  | 1 | Activated by the DREQn signal: fly-by transfer     |  |  |
|              |          |                                                                                                                                                                                                                                                                                                                              | 0    | 1  | 0 | Activated by software: two-cycle transfer          |  |  |
|              |          |                                                                                                                                                                                                                                                                                                                              | 0    | 1  | 1 | Setting prohibited                                 |  |  |
|              |          |                                                                                                                                                                                                                                                                                                                              | 1    | 0  | 0 | Activated by the INTST signal: two-cycle transfer  |  |  |
|              |          |                                                                                                                                                                                                                                                                                                                              | 1    | 0  | 1 | Activated by the INTSR signal: two-cycle transfer  |  |  |
|              |          |                                                                                                                                                                                                                                                                                                                              | 1    | 1  | 0 | Activated by the INTCSI signal: two-cycle transfer |  |  |
|              |          |                                                                                                                                                                                                                                                                                                                              | 1    | 1  | 1 | Activated by the INTCM1 signal: two-cycle transfer |  |  |
| 3, 2         | ТМ       | 1: I/O to memory (write)         Transfer Mode         Sets the transfer mode during DMA transfer.                                                                                                                                                                                                                           |      |    |   |                                                    |  |  |
|              |          |                                                                                                                                                                                                                                                                                                                              |      | ТМ |   | Transfer mode                                      |  |  |
|              |          |                                                                                                                                                                                                                                                                                                                              | 0    | 0  | S | ngle mode                                          |  |  |
|              |          |                                                                                                                                                                                                                                                                                                                              | 0    | 1  | S | ngle-step mode                                     |  |  |
|              |          |                                                                                                                                                                                                                                                                                                                              | 1    | 0  | В | ock mode                                           |  |  |
|              |          |                                                                                                                                                                                                                                                                                                                              | 1    | 1  | S | etting prohibited                                  |  |  |
| 1            | DS       | Data Size<br>Sets the transfer data size for DMA transfer.<br>0: 8 bits<br>1: 16 bits                                                                                                                                                                                                                                        |      |    |   |                                                    |  |  |
| 0            | EN       | <ul> <li>Finable</li> <li>Specifies whether DMA transfer through DMA channel n is to be enabled or disabled. It is reset when DMA transfer ends with a terminal count. It is also reset when transfer is forcibly ended by means of NMI input.</li> <li>O: DMA transfer disabled</li> <li>1: DMA transfer enabled</li> </ul> |      |    |   |                                                    |  |  |

#### 8.4 TRANSFER MODES

#### 8.4.1 Single Transfer Mode

In single transfer mode, DMAC releases the bus at each byte/word transfer. If there is subsequently a DMA transfer request, transfer is performed again. This operation continues until a terminal count occurs.

While DMAC is releasing the bus, if another higher priority DMA transfer request is issued, the higher priority DMA request always takes precedence.

Figures 8-2 and 8-3 show examples of single transfer. Figure 8-3 shows an example of single transfer in which a higher priority DMA request is issued. DMA channel 0 is in block transfer mode and channel 1 is in single transfer mode.



#### 8.4.2 Single-Step Transfer Mode

In single-step transfer mode, DMAC releases the bus at each byte/word transfer. Once a request signal (DREQ) is received, this operation continues until a terminal count occurs.

While DMAC is releasing the bus, if another higher priority DMA transfer request is issued, the higher priority DMA request always takes precedence.

Figures 8-4 and 8-5 show examples of single-step transfer.





DMA ch1 terminal count



CPU

DMA0 CPU ŚΜΔſ

CPU бма OMA

CPU

DMA ch1 terminal count



CPU

DMA

CPU

DMA

#### 8.4.3 Block Transfer Mode

(CPU)

DREQ1

In block transfer mode, once transfer starts, the transfer continues without the bus being released, until a terminal count occurs. No other DMA requests are accepted during block transfer.

After the block transfer ends and DMAC releases the bus, another DMA transfer can be accepted. Figure 8-6 shows an example of block transfer. In this block transfer example, a higher priority DMA request is issued. DMA channels 0 and 1 are in block transfer mode.





# 8.5 DMA TRANSFER TYPES AND TRANSFER OBJECTS

#### 8.5.1 Two-Cycle Transfer

In two-cycle transfer, data transfer is performed in two cycles, source to DMAC then DMAC to destination. In the first cycle, the source address is output to perform reading from the source to DMAC. In the second cycle, the destination address is output to perform writing from DMAC to the destination.

Figure 8-7 shows an example of two-cycle transfer.

#### Figure 8-7. Timing of Two-Cycle, Single-Step DMA Transfer (External I/O to DRAM (on-page))



**Remark** A broken line indicates a high impedance.

CHAPTER 8

Phase-out/Discontinue

#### 8.5.2 Fly-by Transfer

In fly-by transfer, data transfer between memory and I/O is performed in one cycle. To achieve single-cycle transfer, the memory address is always output irrespective of whether it is that of the source or the destination, and the read/write signals for the memory and I/O are made active at the same time.

I/O is selected with the  $\overline{\text{DACK}}$  signal.

Figure 8-8 shows an example of fly-by DMA transfer in which one wait is inserted.





**Remark** A broken line indicates a high impedance.

#### 8.5.3 Transfer Objects

Table 8-1 lists the relationships between transfer types and transfer objects.

| Table 8-1. 1 | <b>Fransfer</b> | Types | vs. | Transfer | Objects |
|--------------|-----------------|-------|-----|----------|---------|
|--------------|-----------------|-------|-----|----------|---------|

| DMA transfer objects                                                    | Transfer type |
|-------------------------------------------------------------------------|---------------|
| External I/O selected with the DACK signal to memory and vice versa     | Fly-by        |
| I/O (external or internal) to memory and vice versa                     | Two-cycle     |
| Memory to memory and vice versa                                         | Two-cycle     |
| I/O (external or internal) to I/O (external or internal) and vice versa | Two-cycle     |

#### 8.6 DMA CHANNEL PRIORITIES

The DMA channel priorities are fixed, as follows:

DMA channel 0 > DMA channel 1

These priorities are valid in the TI state only. In block transfer mode, the channel used for transfer is never switched.

In single-step transfer mode, if a higher priority DMA transfer request is issued while the bus is being released (in the TI state), higher priority DMA transfer request is accepted.

#### 8.7 DMA TRANSFER REQUESTS

There are three types of DMA transfer requests, those received from the external DREQ pins, those issued by software, and those received from built-in peripheral hardware. These are set with the DMA channel control registers (DCHC).

#### (1) Requests received from the DREQ pins

A request received from a DREQ pin is sampled at the falling edge of every clock pulse. The request must not be released until the corresponding  $\overline{DACK}$  signal becomes active. If a DREQ pin becomes active while DMAC is in the TI state, DMAC enters the T0 state to start DMA transfer.

#### (2) Requests issued by software

#### (3) Requests received from built-in peripheral hardware

There are four types of transfer request signals (interrupt request signals) that can be received from builtin peripheral hardware:

- Reception completion interrupt (INTSR) from UART
- Transmission completion interrupt (INTST) from UART
- Transmission/reception completion interrupt (INTCSI) from CSI
- Match interrupt of compare register 1 (CM1) (INTCM1) from RPU

#### 8.8 DMA TRANSFER END INTERRUPTS

When DMA transfer ends and the TC bit of the corresponding DCHC register is set to "1," a DMA transfer end interrupt is issued to the interrupt controller. The interrupt is the OR of the interrupt information for channel 0 and channel 1. (See **Table 4-1**.)

CHAPTER 8 (

Phase-out/Discontinued

#### 8.9 DMA TRANSFER END OUTPUT

In the T2F or T2W state of the cycle in which DMA transfer ends,  $\overline{TC}$  output becomes active for one clock pulse. Figure 8-9 shows the timing of  $\overline{TC}$  output during SRAM two-cycle DMA transfer and SRAM fly-by DMA transfer.

 $\overline{\text{TC}}$  output is the OR of the DMA transfer end outputs for channels 0 and 1. By ANDing the  $\overline{\text{TC}}$  output with the  $\overline{\text{DACK0}}$  and  $\overline{\text{DACK1}}$  signal in an external circuit, the DMA transfer end outputs for channels 0 and 1 can be obtained.

1

#### Figure 8-9. Timing of DMA Transfer End Output



Note Active after completion of DMA transfer.

**Remarks 1.** A broken line indicates a high impedance.

2. An arrow indicates a sampling timing.

#### 8.10 FORCIBLE INTERRUPTION

During DMA transfer, DMA transfer can be interrupted forcibly with  $\overline{\text{NMI}}$  input. With this input, DMAC sets the EN bits of the DCHC registers for both channels to 0 to disable DMA transfer.

In this state, the DMA transfer can be resumed from the point at which it was interrupted by setting the EN bits to 1.

#### 8.11 DATA FLOW DURING DMA TRANSFER

Figures 8-10 and 8-11 illustrate two-cycle byte transfer and 16-bit transfer. Figure 8-12 illustrates fly-by transfer. In these figures, L represents the lower eight bits of 16-bit data and U the upper eight bits.

#### Figure 8-10. Data Flow during DMA Transfer (Two-Cycle Byte Transfer)

#### (1) When the source is at an odd address







#### (2) When the source is at an even address









#### Figure 8-12. Data Flow during DMA Transfer (Fly-by Transfer)

#### (1) Byte transfer with an even memory address



(2) Byte transfer with an odd memory address



# (3) 16-bit transfer





# **CHAPTER 9 SERIAL INTERFACE FUNCTION**

#### 9.1 FEATURES

The V821 provides two transmission and reception channels as part of its serial interface function.

The two interface modes listed below are supported, one channel being provided for each mode. The two modes operate independently of each other.

(1) Asynchronous serial interface (UART)

(2) Synchronous serial interface (CSI)

In UART mode, one-byte serial data is transmitted or received after a start bit, and full-duplex communication is enabled.

In CSI mode, data is transferred using three signal lines (three-wire serial I/O): the serial clock (SCLK), serial input (SI), and serial output (SO).

#### 9.2 ASYNCHRONOUS SERIAL INTERFACE (UART)

#### 9.2.1 Features

- Transfer rate 110 bps to 38,400 bps (when BRG is used with  $\phi = 25$  MHz) 781 Kbps maximum (when  $\phi/2$  is used with  $\phi = 25$  MHz)
- Full-duplex communication
- Two-pin configuration TXD: Transmission data output pin

RXD: Reception data input pin

- Reception error detection function
  - Parity error
  - Framing error
  - Overrun error
- Interrupt source (3 types)
  - Reception error interrupt (INTSER)
  - Reception completion interrupt (INTSR)
  - Transmission completion interrupt (INTST)
- The character length for transmission and reception data is specified upon ASIM reception.
- Character length: 7 or 8 bits

9 bits (when an extended bit is used)

- Parity function: Odd parity, even parity, zero parity, without parity
- Transmission stop bit: 1 or 2 bits
- On-chip baud rate generator

# 9.2.2 Configuration

The asynchronous serial interface is controlled by the asynchronous serial interface mode register (ASIM) and asynchronous serial interface status register (ASIS). Reception data is held in the reception buffer (RXB), and transmission data is written into a transmission shift register (TXS).

The asynchronous serial interface is configured as shown in Figure 9-1.

# (1) Asynchronous serial interface mode register (ASIM)

The ASIM register is an 8-bit register for specifying asynchronous serial interface operation.

# (2) Asynchronous serial interface status register (ASIS)

The ASIS register consists of flags for indicating the states of reception errors as well as a transmission status flag. If a reception error occurs, the corresponding reception error flag is set to 1; the flag is reset to 0 when data is read from the reception buffer (RXB/RXBL) or the next data is received. (If the next data contains an error, the corresponding error flag is set.)

The transmission status flag is set to 1 when data transmission starts; the flag is reset to 0 when data transmission ends.

# (3) Reception control parity check

Reception is controlled according to the setting of the ASIM register. During reception, error checks such as a parity error check are made. If an error is detected, the corresponding value is set in the ASIS register.

# (4) Reception shift register

The reception shift register converts serial data, applied to the RXD pin, to parallel data. When one-byte data is received, the received data is transferred to the reception buffer. The reception shift register cannot be manipulated directly from the CPU.

# (5) Reception buffer (RXB, RXBL)

RXB is a 9-bit buffer register which is used to hold received data; when a 7-bit or 8-bit character is received, 0 is held in the high-order bit position(s).

Specify RXB for 16-bit access to this register. Specify RXBL to access the low-order 8 bits.

In the reception enabled state, reception data is transferred from the reception shift register to the reception buffer upon the completion of shift-in processing for one frame.

When data is transferred to the reception buffer, a reception completion interrupt request (INTSR) is generated.

# (6) Transmission shift register (TXS, TXSL)

TXS is a 9-bit shift register for transmission processing. When data is written into this register, transmission is started.

Upon the completion of the transmission of one frame including TXS data, a transmission completion interrupt request (INTST) is generated.

Specify TXS for 16-bit access to this register. Specify TXSL to access the low-order 8 bits.



#### (7) Transmission control parity bit addition

Transmission is controlled by adding a start bit, parity bit, and stop bit to the data written into the TXS register, according to the setting of the ASIM register.

#### (8) Selector

The selector is used to select a serial clock source.





# 9.2.3 UART Control Registers

#### (1) Asynchronous serial interface mode register (ASIM)

The asynchronous serial interface mode register specifies the UART transfer mode. This register allows 8-bit read and write operations.



| Bit position | Bit name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|--------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7            | RXE      | Receive Enable<br>This bit specifies the reception enabled or reception disabled state.<br>0: Reception disabled state<br>1: Reception enabled state<br>In the reception disabled state, the reception shift register does not detect a<br>start bit. Shift-in processing and transfer to the reception buffer are not<br>performed, but the contents of the reception buffer are preserved.<br>In the reception enabled state, reception shift operation is started upon the<br>detection of a start bit. Upon the completion of reception of one frame, the<br>contents of the reception shift register are transferred to the reception buffer.<br>A reception completion interrupt (INTSR) is generated in sync with transfer to<br>the reception buffer. |

# CHAI Phase-out/Discontinued

| Bit position | Bit name | Description                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                            |                                                                                                                                                                      |  |  |  |
|--------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 6, 5         | PS       | Parity<br>These                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                            | ecify the                                                                                                                                                                                                                  | e parity bit.                                                                                                                                                        |  |  |  |
|              |          |                                                                                                                                                                                                                                                                                     | Р                                                                                                                                                                                                                                                                          | S                                                                                                                                                                                                                          | Operation                                                                                                                                                            |  |  |  |
|              |          |                                                                                                                                                                                                                                                                                     | 0                                                                                                                                                                                                                                                                          | 0                                                                                                                                                                                                                          | Without parity. Extended bit operation is enabled.                                                                                                                   |  |  |  |
|              |          |                                                                                                                                                                                                                                                                                     | 0                                                                                                                                                                                                                                                                          | 1                                                                                                                                                                                                                          | Zero parity<br>Transmission side -> Data is transmitted<br>with the parity bit set to 0.<br>Reception side -> No parity error is<br>generated when data is received. |  |  |  |
|              |          |                                                                                                                                                                                                                                                                                     | 1                                                                                                                                                                                                                                                                          | 0                                                                                                                                                                                                                          | Odd parity                                                                                                                                                           |  |  |  |
|              |          |                                                                                                                                                                                                                                                                                     | 1                                                                                                                                                                                                                                                                          | 1                                                                                                                                                                                                                          | Even parity                                                                                                                                                          |  |  |  |
|              |          | even<br>data                                                                                                                                                                                                                                                                        | the number of bits set to 1 in transmission data that includes a parity bit is<br>even. When data is received, the number of bits set to 1 in the received<br>data that includes a parity bit is counted; a parity error is generated if the<br>number is found to be odd. |                                                                                                                                                                                                                            |                                                                                                                                                                      |  |  |  |
|              |          | data that includes a parity bit is counted; a parity error is generate                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                            |                                                                                                                                                                      |  |  |  |
|              |          | Odd parity                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                            |                                                                                                                                                                      |  |  |  |
|              |          | In contrast to even parity, control is exercised so that the number<br>to 1 in transmission data that includes a parity bit is odd. When d<br>received, a parity error is generated when the number of bits set to<br>received data that includes a parity bit is found to be even. |                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                            |                                                                                                                                                                      |  |  |  |
|              |          | • Zero parity                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                            |                                                                                                                                                                      |  |  |  |
|              |          | trans<br>That                                                                                                                                                                                                                                                                       | When data is transmitted, the parity bit is set to 0, regardless of the transmission data. When data is received, no parity bit check is performed. That is, no parity error is generated, regardless of whether the parity bit is set to 0 or 1.                          |                                                                                                                                                                                                                            |                                                                                                                                                                      |  |  |  |
|              |          | • With                                                                                                                                                                                                                                                                              | Without parity                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                            |                                                                                                                                                                      |  |  |  |
|              |          | use                                                                                                                                                                                                                                                                                 | of no pa                                                                                                                                                                                                                                                                   | arity bit is added to the transmission data. When data is received, the of no parity bit is assumed. No parity error is generated because no other bit is used. With the EBS bit, extended bit operation can be specified. |                                                                                                                                                                      |  |  |  |

| Bit position | Bit name |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                     |  | Description |  |  |  |
|--------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------|--|-------------|--|--|--|
| 4            | EBS      | Extended Bit Select<br>This bit specifies extended bit operation for transmission and reception data<br>when no parity bit is used (PS = 00).<br>0: Disables extended bit operation.<br>1: Enables extended bit operation.<br>When extended bit operation is specified, a higher data bit is added to the 8-<br>bit transmission and reception data to enable 9-bit data communication.<br>Extended bit operation is enabled only when the PS bits are set for operation<br>without parity. When zero parity, odd parity, or even parity operation is<br>specified, the EBS bit is ignored; no extended bit is added. |                                                                                                     |  |             |  |  |  |
| 2            | CL       | This bi<br>0: 7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Character Length<br>This bit specifies the character length of one frame.<br>0: 7 bits<br>1: 8 bits |  |             |  |  |  |
| 1            | SL       | Stop Bit Length<br>This bit specifies the number of stop bits.<br>0: 1 bit<br>1: 2 bits                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                     |  |             |  |  |  |
| 0            | SCLS     | 1: 2 bitsSerial Clock SourceThis bit specifies a serial clock source.0: A serial clock source is specified using the BRG and BPRM registers.1: $\phi/2$ • When SCLS = 1As the serial clock source, $\phi/2$ (serial clock) is selected. In asynchronous<br>mode, a sampling rate of x 16 is used, so that the baud rate can be<br>expressed by the following:Baud rate = $\frac{\phi/2}{16}$ bpsThe baud rates determined from the above expression when using typical<br>clocks are: $\phi$ 25 MHz20 MHz16 MHzBaud rate781 K625 K500 K                                                                               |                                                                                                     |  |             |  |  |  |
|              |          | <ul> <li>When SCLS = 0         As the serial clock source, the output from the baud rate generator is selected. For details of the baud rate generator, see Section 9.4.     </li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                     |  |             |  |  |  |

# Caution If the value of this register is changed while the UART is used for transmission or reception, the operation of the UART will be unpredictable.

# CHAI Phase-out/Discontinued

#### (2) Asynchronous serial interface status register (ASIS)

The asynchronous serial interface status register consists of three error flags (three bits), used to indicate any error status that may be present when reception using the UART has ended, and a transmission status flag.

Each of the status flags used to indicate a reception error indicates the latest error state. That is, if the same error occurs more than once before the reception data is read, the state of only the last error is preserved.

If a reception error occurs, read the reception buffer RXB or RXBL after reading the ASIS register, then clear the error flag.

This register supports only 8-bit read operations.



| Bit position | Bit name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|--------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7            | SOT      | Status Of Transmission<br>This bit is a status flag for indicating the transmission status.<br>Set to 1 : Transmission start timing (write to the TXS register)<br>Cleared to 0 : Transmission end timing (INTST generation)<br>This flag is used to determine whether it is possible to write to the<br>transmission shift register before serial data transfer is started.                                                                                                                                                                                               |
| 2            | PE       | Parity Error<br>This bit is a status flag for indicating a parity error.<br>Set to 1 : When there is a mismatch between the transmission and<br>reception parities<br>Cleared to 0 : Processing to read data from the reception buffer                                                                                                                                                                                                                                                                                                                                     |
| 1            | FE       | Framing Error<br>This bit is a status flag for indicating a framing error.<br>Set to 1 : When no stop bit is detected<br>Cleared to 0 : Processing to read data from the reception buffer                                                                                                                                                                                                                                                                                                                                                                                  |
| 0            | OVE      | Overrun Error<br>This bit is a status flag for indicating an overrun error.<br>Set to 1 : When the UART completes the next receive processing before<br>reception data is read from the reception buffer<br>Cleared to 0 : Processing to read data from the reception buffer<br>Note that, to receive each frame, the contents of the reception shift register<br>are transferred to the reception buffer. So, if an overrun error occurs, the<br>reception buffer is overwritten by the next reception data, thus causing the<br>previous reception data to be discarded. |

#### (3) Reception buffer (RXB, RXBL)

RXB is a 9-bit buffer register used to hold received data; when a 7- or 8-bit character is received, 0 is held at the higher bit position(s).

Specify RXB for 16-bit access to this register. Specify RXBL to access the low-order 8 bits.

In the reception enabled state, reception data is transferred from the reception shift register to the reception buffer upon the completion of shift-in processing for one frame. When data is transferred to the reception buffer, a reception completion interrupt request (INTSR) is generated.

In the reception disabled state, reception data is not transferred to the reception buffer, even upon the completion of shift-in processing for one frame; the contents of the reception buffer are preserved, and no reception completion interrupt request is generated.

RXB supports only 16-bit read access, while RXBL supports only 8-bit read access.



| Bit position | Bit name          | Description                                                                                                                                                  |
|--------------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8            | RXEB              | Receive Extended Buffer<br>This bit is an extended bit for 9-bit character reception. Zero is read from this<br>bit when a 7-or 8-bit character is received. |
| 7-0          | RXBn<br>(n = 7-0) | Receive Buffer<br>These bits are used to store received data. Zero is read from RXB7 when a<br>7-bit character is received.                                  |

# CHAIN Phase-out/Discontinued

#### (4) Transmission shift register (TXS, TXSL)

TXS is a 9-bit shift register used for transmission. When data is written to this register, transmission is started.

When the transmission of one frame including TXS data is completed, a transmission completion interrupt request (INTST) is generated.

Specify TXS for 16-bit access to this register. Specify TXSL to access the low-order 8 bits. TXS supports only 16-bit write access. TXSL supports only 8-bit write access.



| Bit position | Bit name          | Description                                                                             |
|--------------|-------------------|-----------------------------------------------------------------------------------------|
| 8            | TXED              | Transmit Extended Data<br>This bit is an extended bit for 9-bit character transmission. |
| 7-0          | TXSn<br>(n = 7-0) | Transmit Shifter<br>Transmission data is written to these bit positions.                |

Caution The UART of the V821 has no transmission buffer, so that an interrupt request is generated not at the time of transmission completion (completion of transfer to a buffer) but upon the completion of the transmission of one-frame data.

#### 9.2.4 Interrupt Requests

The UART generates three types of interrupt requests:

- Reception error interrupt
- Reception completion interrupt
- Transmission completion interrupt

The default priorities for these types of interrupt requests are such that the reception error interrupt has the highest priority, the reception completion interrupt has the next-highest priority, and the transmission completion interrupt has the lowest priority.

### Table 9-1. Generated Interrupts and Default Priorities

| Interrupt               | Priority |
|-------------------------|----------|
| Reception error         | 1        |
| Reception completion    | 2        |
| Transmission completion | 3        |

#### (1) Reception error interrupt (INTSER)

In the reception enabled state, a reception error interrupt is generated according to the logical OR of the three types of reception errors described in **Section 9.2.3 (2)**.

In the reception disabled state, no reception error interrupt is generated.

#### (2) Reception completion interrupt (INTSR)

In the reception enabled state, a reception completion interrupt is generated when data is shifted into the reception shift register, then is transferred to the reception buffer.

A reception completion interrupt is also generated when a reception error occurs. In this case, however, the reception error interrupt is assigned higher priority.

In the reception disabled state, a reception completion interrupt is not generated.

#### (3) Transmission completion interrupt (INTST)

The UART of the V821 does not have a transmission buffer. So, a transmission completion interrupt is generated when one-frame transmission data including a 7-, 8-, or 9-bit character is shifted out from the transmission shift register.

A transmission completion interrupt is output when transmission of the last bit of the transmission data is started.

#### 9.2.5 Operation

#### (1) Data format

Full-duplex serial data transmission and reception are performed.

Figure 9-2 shows the format of the transmission and reception data. As shown in the figure, one data frame consists of a start bit, character bits, a parity bit, and one or two stop bits.

The asynchronous serial interface mode register (ASIM) is used to specify the number of character bits, select a parity option, and specify a stop bit length within a data frame.

# Figure 9-2. Format of Transmission and Reception Data Transferred via Asynchronous Serial Interface



- Start bit : 1 bit
- Character bit : 7 bits/8 bits/9 bits (when an extended bit is used)
- Parity bit : Even parity/odd parity/zero parity/without parity
- Stop bit : 1 bit/2 bits

### (2) Transmission

Transmission is started when data is written into the transmission shift register (TXS or TXSL). When a transmission completion interrupt (INTST) is generated, the next data is written into the TXS or TXSL register.

#### (a) Transmission enabled state

The UART of the V821 is always placed in the transmission enabled state. The V821 does not have an input pin for a transmission enable signal. To check whether the remote receiver is in the reception enabled state, therefore, a general I/O port should be used.

#### (b) Starting transmission

Transmission is started when data is written into the transmission shift register (TXS/TXSL). Transmission data is transferred, starting with a start bit and followed by the LSB of the character data. A start bit, parity bit, and stop bit(s) are added automatically.

#### (c) Transmission interrupt request

Upon the completion of the transmission of one-frame data, a transmission completion interrupt request (INTST) is generated.

If the next transmission data is not written into TXS or TXSL, transmission stops.

If the next transmission data is not written into TXS or TXSL immediately after the completion of one transmission operation, the communication rate is reduced.

- Cautions 1. A transmission completion interrupt (INTST) is usually generated once the transmission shift register (TXS or TXSL) becomes empty. However, no transmission completion interrupt (INTST) is generated even when the transmission shift register (TXS or TXSL) is forcibly emptied by inputting a RESET signal.
  - 2. During transmission before INTST generation, write data, even if written into the TXS or TXSL register, is ignored.

#### Figure 9-3. Timing of Transmission Completion Interrupt via Asynchronous Serial Interface

#### (a) Number of stop bits: 1



#### (3) Reception

When reception is enabled, sampling of the RXD pin starts. Then, when a start bit is detected, data reception is started. Each time one-frame data reception ends, a reception completion interrupt (INTSR) is generated. Usually, reception data is transferred from the reception buffer (RXB/RXBL) to memory by means of this interrupt handling.

#### (a) Reception enabled state

Reception can be enabled by setting the RXE bit of the ASIM register to 1.

RXE = 1: Reception enabled state RXE = 0: Reception disabled state

When reception is disabled, the reception hardware enters the initial state. In the reception disabled state, neither a reception completion interrupt nor a reception error interrupt is generated, the data in the reception buffer being preserved.

#### (b) Starting reception

Reception is started upon the detection of a start bit.

The RXD pin is sampled using the serial clock specified with the ASIM register. Eight serial clock cycles after a falling edge is detected on the RXD pin, the RXD pin is sampled again. If a low level is detected at this time, the presence of a start bit is assumed, and receive processing is started. Then, the RXD pin is sampled every 16 clock cycles.

If a high level is detected eight clock cycles after a falling edge is detected on the RXD pin, the falling edge is not regarded as being a start bit. The serial clock counter, used to generate a sampling timing signal, is initialized and stops operating, then waits for the next falling edge to be applied.

#### (c) Reception completion interrupt request

If one-frame data reception is completed when RXE = 1, the reception data held in the shift register is transferred to RXB, after which a reception completion interrupt request (INTSR) is generated. Even if an error occurs, reception data including an error is transferred to the reception buffer (RXB/ RXBL), and both a reception completion interrupt (INTSR) and a reception error interrupt (INTSER) are generated.

When the RXE bit is reset to 0 during reception, receive processing stops immediately. At this time, the contents of the reception buffer (RXB/RXBL) and the asynchronous serial interface status register (ASIS) remain as is, and neither a reception completion interrupt (INTSR) nor a reception error interrupt (INTSER) is generated.

#### Figure 9-4. Timing of Reception Completion Interrupt via Asynchronous Serial Interface



#### (d) Reception error flags

The three error flags for a parity error, framing error, and overrun error are affected by receive processing.

Phase-out/Discontinue

A reception error interrupt is generated according to the logical OR of these three error flags.

By reading the ASIS register in reception error interrupt (INTSER) handling, the error which occurred during reception can be determined.

The contents of the ASIS register are reset to 0 when the reception buffer (RXB/RXBL) is read or the next data is received. (If the next reception data contains an error, the corresponding error flag is set.)

| Reception error | Cause                                                                                  |  |  |  |  |
|-----------------|----------------------------------------------------------------------------------------|--|--|--|--|
| Parity error    | Parity specified for transmission does not match the parity of the reception data.     |  |  |  |  |
| Framing error   | No stop bit is detected                                                                |  |  |  |  |
| Overrun error   | Reception of the next data is completed before data is read from the reception buffer. |  |  |  |  |



#### Figure 9-5. Timing of Reception Error

### 9.3 SYNCHRONOUS SERIAL INTERFACE (CSI)

#### 9.3.1 Features

- High-speed transfer 6.25 Mbps maximum (when  $\phi/2$  is used with  $\phi = 25$  MHz)
- Half-duplex communication
- Character length: 8 bits
- Switchable between the MSB and LSB to lead data transfer
- Allows selection between external serial clock input and internal serial clock output
- Three-wire method SO : Serial data output
  - SI : Serial data input
  - SCLK : Serial clock I/O pin
- One interrupt source
  - Interrupt request signal (INTCSI)

The synchronous serial interface is controlled using the synchronous serial interface mode register (CSIM). Transmission/reception data can be read from or written to the SIO register.

#### (1) Synchronous serial interface mode register (CSIM)

The CSIM register is an 8-bit register for specifying synchronous serial interface operation.

#### (2) Shift register (SIO)

The shift register (SIO) is an 8-bit register used to convert serial data to parallel data or vice versa. SIO is used for both transmission and reception.

Data is shifted in (for reception) or shifted out (for transmission), starting from the MSB or LSB. Transmission and reception are actually controlled by SIO read/write operation.

#### (3) Serial clock selector

The serial clock selector is used to select the serial clock to be used.

#### (4) Serial clock control circuit

The serial clock control circuit controls the supply of a serial clock to the shift register. When an internal clock is used, the serial clock control circuit controls the clock signal output on the  $\overline{\text{SCLK}}$  pin.

#### (5) Serial clock counter

To check whether 8-bit data transfer is performed, the serial clock counter counts the number of serial clock pulses output or applied in reception or transmission.

#### (6) Interrupt signal generation control circuit

The interrupt signal generation control circuit applies control to determine whether to generate an interrupt request when 8 serial clock pulses are counted with the serial clock counter.

# 9.3.2 Configuration



### 9.3.3 CSI Control Registers

# (1) Synchronous serial interface mode register (CSIM)

The synchronous serial interface mode register specifies a basic CSI operating mode. This register supports 8-bit read and write operations. However, bit 5 can be only read.

|      | 7    | 6    | 5   | 4 | 3 | 2   | 1 | 0  | _                    |                    |
|------|------|------|-----|---|---|-----|---|----|----------------------|--------------------|
| CSIM | CTXE | CRXE | SOT | 0 | 0 | MOD | С | LS | Address<br>C0000090H | When reset,<br>00H |

| Bit position | Bit name | Description                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                         |                          |                                      |          |  |
|--------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|--------------------------------------|----------|--|
| 7            | СТХЕ     | CSI Transmit Enable<br>This bit specifies the transmission enabled state or transmission disabled<br>state.<br>0: Transmission disabled state<br>1: Transmission enabled state<br>When CTXE = 0, the output buffers of the SO and SI pins become high-<br>impedance.                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                         |                          |                                      |          |  |
| 6            | CRXE     | This b<br>0: F<br>1: F<br>If a se                                                                                                                                                                                                                                                                                                                                                                             | <ul> <li>CSI Receive Enable</li> <li>This bit specifies the reception enabled state or reception disabled state.</li> <li>0: Reception disabled state</li> <li>1: Reception enabled state</li> <li>If a serial clock is applied while transmission is disabled (CTXE = 0) and reception is disabled, 0s are written into the shift register.</li> </ul> |                          |                                      |          |  |
| 5            | SOT      | Status Of Transmission<br>This bit indicates that transfer is in progress.<br>Set to 1 : Transmission start timing (write to the SIO register)<br>Cleared to 0 : Transmission end timing (INTCSI generation)<br>This bit is used to check whether data can be written into the serial I/O shift<br>register (SIO) when serial data transfer is to be started in the transmission<br>enabled state (CTXE = 1). |                                                                                                                                                                                                                                                                                                                                                         |                          |                                      |          |  |
| 2            | MOD      | Mode<br>This bit specifies the bit from which data transfer is to start.<br>0: MSB<br>1: LSB                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                         |                          |                                      |          |  |
| 1,0          | CLS      | Clock<br>These                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                         | e<br>pecify a serial clo | ck.                                  |          |  |
|              |          | С                                                                                                                                                                                                                                                                                                                                                                                                             | LS                                                                                                                                                                                                                                                                                                                                                      | S                        | erial clock specification            | SCLK pin |  |
|              |          | 0                                                                                                                                                                                                                                                                                                                                                                                                             | 0                                                                                                                                                                                                                                                                                                                                                       | External clock           |                                      | Input    |  |
|              |          | 0                                                                                                                                                                                                                                                                                                                                                                                                             | 1                                                                                                                                                                                                                                                                                                                                                       | Internal clock           | Specified by the BPRM registerNote 1 | Output   |  |
|              |          | 1                                                                                                                                                                                                                                                                                                                                                                                                             | 0                                                                                                                                                                                                                                                                                                                                                       |                          | $\phi/4$ Note 2                      | Output   |  |
|              |          | 1                                                                                                                                                                                                                                                                                                                                                                                                             | 1                                                                                                                                                                                                                                                                                                                                                       |                          | $\phi/2$ Note 2                      | Output   |  |
|              |          | <ul> <li>Notes 1. For details of the setting of the BPRM register, see Section 9.4.</li> <li>2. φ/4 and φ/2 are frequency-divided signals (φ = system clock).</li> </ul>                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                         |                          |                                      |          |  |

#### (2) Serial I/O shift register (SIO)

The serial I/O shift register converts 8-bit serial data to 8-bit parallel data or vice versa. Transmission and reception are actually controlled by an SIO register read/write operation.

When CTXE = 1 or CRXE = 1, a shift operation is performed.

This register supports 8-bit read and write operations.



| Bit position | Bit name          | Description                                                                                                          |
|--------------|-------------------|----------------------------------------------------------------------------------------------------------------------|
| 7-0          | SIOn<br>(n = 7-0) | Serial I/O<br>Data is shifted in (for reception) or shifted out (for transmission), starting from<br>the MSB or LSB. |

#### 9.3.4 Basic Operation

#### (1) Transfer format

For the CSI of the V821, three wires are used: one clock line, and two data lines.

Serial transfer is started by executing an instruction for writing transfer data into the SIO register.

During transmission, data is output on the SO pin on a falling edge of  $\overline{SCLK}$ .

During reception, input data applied to the SI pin is latched on a rising edge of  $\overline{SCLK}$ .  $\overline{SCLK}$  stops when the serial clock counter overflows (at the eighth rising edge), and  $\overline{SCLK}$  remains high until the next data is transmitted, or reception is started. At this time, an interrupt request signal (INTCSI) is generated.

# Caution Serial transfer is not performed even if the value of CTXE is changed from 0 to 1 after transmission data is written into the shift register.





#### (2) Enabling transmission and reception

The CSI of the V821 has only one 8-bit shift register and has no buffer, so that transmission and reception are performed at the same time.

#### (a) Prerequisite transmission and reception conditions

When CTXE = 1, transmission is enabled.When CRXE = 1, reception is enabled.When CTXE = CRXE = 1, both transmission and reception are enabled.

#### (i) Disabling SIO output with CTXE

When CTXE = 0, the serial output becomes high-impedance. When CTXE = 1, the data held in the shift register is output.

#### (ii) Disabling SIO input with CRXE

When CRXE = 0, 0s are written into the shift register. When CRXE = 1, serial input data is applied to the shift register.

#### (iii)Transmission data check

By setting CTXE = CRXE = 1, transmission data can be locally received to check where there is a bus contention.

#### (b) Starting transmission and reception

Transmission/reception is started by reading from or writing to the shift register (SIO). The start of transmission/reception is controlled by setting the transmission enable bit (CTXE) and reception enable bit (CRXE) as indicated below.

| CTXE | CRXE   | Start condition                 |  |  |  |
|------|--------|---------------------------------|--|--|--|
| 0    | 0      | Not started                     |  |  |  |
| 0    | 1      | Reading from the shift register |  |  |  |
| 1    | 0      | Writing to the shift register   |  |  |  |
| 1    | 1      | Writing to the shift register   |  |  |  |
| 1    | 0 -> 1 | Rewriting the CRXE bit          |  |  |  |

Data transfer does not take place even if the shift register is read from or written to when CTXE = 0, after which CTXE is set to 1.

If the setting of CRXE is changed from 0 to 1 when CTXE = 0, a serial clock is generated to start reception.

#### 9.3.5 Transmission in Three-Wire Serial I/O Mode

Transmission starts when data is written into the SIO register after transmission is enabled with the synchronous serial interface mode register (CSIM).

#### (1) Starting transmission

Transmission is started by writing transmission data into the shift register (SIO) after setting the CTXE bit of the synchronous serial interface mode register (CSIM) to 1 and setting the CRXE bit to 0. Note that when the CTXE bit is reset to 0, the SO pin is placed in the high-impedance state.

#### (2) Data transmission synchronized with the serial clock

#### (a) When an internal clock is selected as the serial clock

When transmission is started, a serial clock is output on the SCLK pin, and data is sequentially shifted out, from SIO to the SO pin, on a falling edge of the serial clock.

#### (b) When an external clock is selected as the serial clock

When transmission is started, data is sequentially shifted out from SIO to the SO pin on a falling edge of a serial clock applied to the  $\overline{SCLK}$  pin after the start of transmission. If a serial clock is applied to the  $\overline{SCLK}$  pin before transmission is started, a shift operation is not performed, and the output level of the SO pin does not change.



#### Figure 9-6. Timing of Three-Wire Serial I/O Mode (Transmission)

# CHAI Phase-out/Discontinued

#### 9.3.6 Reception in Three-Wire Serial I/O Mode

Reception starts when the reception disabled state is changed to the reception enabled state with the synchronous serial interface mode register (CSIM), or when the SIO register is read when reception is enabled.

#### (1) Starting reception

Reception is enabled in either of two ways:

- <1> Changing the setting of the CRXE bit of the CSIM register from 0 (to disable reception) to 1 (to enable reception)
- <2> Reading reception data from the shift register (SIO) when the CRXE bit of the CSIM register is set to 1 (to enable reception)

When the CRXE bit of the CSIM register is set to 1, reception is not started even if 1 is again written into the CRXE bit. Note that when CRXE = 0, 0s are written into the shift register.

#### (2) Data reception synchronized with the serial clock

(a) When an internal clock is selected as the serial clock

When reception is started, a serial clock is output on the SCLK pin, and data applied to the SI pin is sequentially shifted into SIO on a rising edge of the serial clock.

#### (b) When an external clock is selected as the serial clock

When reception is started, data applied to the SI pin is sequentially shifted into SIO on a rising edge of a serial clock applied to the  $\overline{SCLK}$  pin after the start of reception. If a serial clock is applied to the  $\overline{SCLK}$  pin before reception is started, a shift operation is not performed.



Figure 9-7. Timing of Three-Wire Serial I/O Mode (Reception)

#### 9.3.7 Transmission and Reception in Three-Wire Serial I/O Mode

Transmission and reception can be performed at the same time by enabling transmission and reception with the synchronous serial interface mode register (CSIM).

#### (1) Starting transmission and reception

When both the CTXE bit and CRXE bit of the synchronous serial interface mode register (CSIM) are set to 1, transmission and reception can be performed at the same time. Transmission and reception can be started in the following:

• Writing transmission data into the shift register (SIO) when both the CTXE bit and CRXE bit of the CSIM register are set to 1 (to enable transmission and reception).

#### (2) Data transmission synchronized with the serial clock

#### (a) When an internal clock is selected as the serial clock

When transmission and reception are started, a serial clock is output on the  $\overline{SCLK}$  pin, and data is sequentially shifted out from SIO to the SO pin on a falling edge of the serial clock. At the same time, data applied to the SI pin is sequentially shifted into SIO on a rising edge of the serial clock.

#### (b) When an external clock is selected as the serial clock

When transmission and reception are started, data is sequentially shifted out from SIO to the SO pin on a falling edge of a serial clock applied to the  $\overline{SCLK}$  pin, after the start of transmission and reception. At the same time, data applied to the SI pin is sequentially shifted into SIO on a rising edge of the serial clock. If a serial clock is applied to the  $\overline{SCLK}$  pin when transmission and reception are not started, a shift operation is not performed, and the output level on the SO pin does not change.







Caution When transmission and reception are started for the first time, the setting of the CRXE bit is always changed from 0 to 1. This change causes transmission and reception to start immediately, such that arbitrary data may be output. Accordingly, while transmission and reception are disabled (by resetting both the CTXE bit and CRXE bit to 0), write initial transmission data into the SIO register. Then, enable transmission and reception.

#### 9.3.8 Example System Configuration

This section introduces an example system configuration, in which 8-bit data is transferred using three signal lines: the serial clock ( $\overline{SCLK}$ ), serial input (SI), and serial output (SO). This configuration is useful for making a connection to a display controller or peripheral I/O device having a built-in conventional synchronous serial interface.

To enable connection to multiple devices, handshaking lines are also required.

The user can select either the MSB or LSB as the bit from which data transmission will begin, thus enabling communications with a wide variety of devices.



Figure 9-9. Example System Configuration Using CSI

#### 9.4 BAUD RATE GENERATOR (BRG)

#### 9.4.1 Configuration and Function

With the serial interface, a serial clock chosen from the baud rate generator output and clocks generated using the system clock ( $\phi$ ) can be used as a baud rate.

A serial clock source can be specified by using the SCLS bit of the ASIM register when the UART is used, or by using the CLS bit of the CSIM register when the CSI is used.

When baud rate generator output is specified, the baud rate generator is selected as the clock source.

The same serial clock is used for both transmission and reception on a channel, so that the same baud rate applies to transmission and reception.





CHAI Phase-out/Discontinued

The dedicated baud rate generator, BRG, consists of a dedicated 8-bit timer (TMBRG), compare register (BRG), and prescaler for generating a shift clock for transmission and reception.

#### (1) Input clock

The system clock ( $\phi$ ) is applied to BRG.

#### (2) Setting for BRG

#### (a) UART

If the dedicated baud rate generator is specified when the UART is used, the actual baud rate is given by the following formula because a sampling rate of x 16 is used:

Baud rate =  $\frac{\phi}{2 \text{ x m x } 2^{n} \text{ x } 16 \text{ x } 2}$  [bps]

 $\phi$  = System clock frequency [Hz] m = BRG setting (1 ≤ m ≤ 256<sup>Note</sup>) n = BRG prescaler setting (n = 0, 1, 2, 3, 4)

**Note** By writing 0s to the BRG register, m = 256 can be set.

#### (b) CSI

If use of the dedicated baud rate generator is specified when the CSI is being used, the actual baud rate is given by the following formula:

Baud rate =  $\frac{\phi}{2 \text{ x m x } 2^n \text{ x } 2}$  [bps]

 $\phi$  = System clock frequency [Hz] m = BRG setting (1 ≤ m ≤ 256Note) n = BRG prescaler setting (n = 0, 1, 2, 3, 4)

**Note** By writing 0s to the BRG register, m = 256 can be set.

Table 9-2 lists examples of baud rate generator settings using typical clocks.

| Baud ra | ite [bps] | $\phi$ = 25 MHz |     |           |     | ¢ = 20 M⊦ | łz    | $\phi$ = 16 MHz |     |           |
|---------|-----------|-----------------|-----|-----------|-----|-----------|-------|-----------------|-----|-----------|
| UART    | CSI       | BPR             | BRG | Error     | BPR | BRG       | Error | BPR             | BRG | Error     |
| 110     | 1,760     | 4               | 222 | 0.02%     | 4   | 178       | 0.25% | 4               | 142 | 0.03%     |
| 150     | 2,400     | 4               | 163 | 0.15%     | 4   | 130       | 0.16% | 3               | 208 | 0.16%     |
| 300     | 4,800     | 3               | 163 | 0.15%     | 3   | 130       | 0.16% | 2               | 208 | 0.16%     |
| 600     | 9,600     | 2               | 163 | 0.15%     | 2   | 130       | 0.16% | 1               | 208 | 0.16%     |
| 1,200   | 19,200    | 1               | 163 | 0.15%     | 1   | 130       | 0.16% | 0               | 208 | 0.16%     |
| 2,400   | 38,400    | 0               | 163 | 0.15%     | 0   | 130       | 0.16% | 0               | 104 | 0.16%     |
| 4,800   | 76,800    | 0               | 81  | 0.47%     | 0   | 65        | 0.16% | 0               | 52  | 0.16%     |
| 9,600   | 153,600   | 0               | 41  | 0.76%     | 0   | 33        | 1.36% | 0               | 26  | 0.16%     |
| 10,400  | 166,400   | 0               | 38  | 1.16%     | 0   | 30        | 0.16% | 0               | 24  | 0.16%     |
| 19,200  | 307,200   | 0               | 20  | 1.73%     | 0   | 16        | 1.73% | 0               | 13  | 0.16%     |
| 38,400  | 614,400   | 0               | 10  | 1.73%     | 0   | 8         | 1.73% | 0               | 7   | 6.99%Note |
| 76,800  | 1,228,800 | 0               | 5   | 1.73%     | 0   | 4         | 1.73% | -               | -   | -         |
| 153,600 | 2,457,600 | 0               | 2   | 27.2%Note | 0   | 2         | 1.73% | -               | -   | -         |

 Table 9-2.
 BRG Setting Data

Phase-out/Discontinued

Note Unusable because of an excessive error

#### (3) Baud rate error

A baud rate error is expressed as follows:

Error [%] = 
$$\left(\frac{\text{Actual baud rate (baud rate including an error)}}{\text{Desired baud rate (normal baud rate)}} -1\right) \times 100$$

Example: (9,520/9,600 -1) x 100 = -0.833 [%] (5,000/4,800 -1) x 100 = +4.167 [%]

#### (4) Allowable error ranges for baud rate generator

The allowable error ranges depend on the number of bits in one frame.

When there are 16 bits in one frame, a baud rate error of  $\pm 5\%$  and a sampling timing of  $\pm 4.5\%$  are the basic allowable ranges.

Practically, however, a baud rate error of only  $\pm 2.3\%$  can be allowed, assuming that both transmission and reception involve a degree of error.

## CHAI Phase-out/Discontinued

#### 9.4.2 Baud Rate Generator Register (BRG)

The baud rate generator register is an 8-bit compare register, used to set a timer count value for the dedicated baud rate generator.

This register supports 8-bit read and write operations.



### Caution BRG register write clears the internal timer (TMBRG). So, never rewrite the BRG register by software during transmission or reception.

#### 9.4.3 Baud Rate Generator Prescaler Mode Register (BPRM)

The baud rate generator prescaler mode register controls the timer count operation, and selects a count clock.

This register supports 8-bit read and write operations.

|      | 7    | 6 | 5 | 4 | 3 | 2 | 1   | 0 |                      |                    |
|------|------|---|---|---|---|---|-----|---|----------------------|--------------------|
| BPRM | BRCE | 0 | 0 | 0 | 0 |   | BPR |   | Address<br>C00000A2H | When reset,<br>00H |

| Bit position | Bit name |                                                                                                                                                                                                   |                         |         |        | Description        |  |  |
|--------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|---------|--------|--------------------|--|--|
| 7            | BRCE     | <ul><li>Baud Rate Generator Count Enable</li><li>This bit controls the BRG count operation.</li><li>0: Stops the count operation, with BRG cleared.</li><li>1: Enables count operation.</li></ul> |                         |         |        |                    |  |  |
| 2-0          | BPR      | Baud Rate Generator Prescaler<br>These bits specify the count clock to be applied to TMBRG.                                                                                                       |                         |         |        |                    |  |  |
|              |          |                                                                                                                                                                                                   | BPR Count clock         |         |        |                    |  |  |
|              |          |                                                                                                                                                                                                   | 0                       | 0       | 0      | $\phi/2 \ (n = 0)$ |  |  |
|              |          |                                                                                                                                                                                                   | 0                       | 0       | 1      | $\phi/4 \ (n = 1)$ |  |  |
|              |          |                                                                                                                                                                                                   | 0                       | 1       | 0      | φ/8 (n = 2)        |  |  |
|              |          |                                                                                                                                                                                                   | 0 1 1 $\phi/16 (n = 3)$ |         |        |                    |  |  |
|              |          | 1 x x $\phi/32$ (n = 4)                                                                                                                                                                           |                         |         |        |                    |  |  |
|              |          | n: Pre                                                                                                                                                                                            | escaler s               | setting | φ: Sys | tem clock          |  |  |

Caution Never change the count clock during transmission or reception.



[MEMO]



### CHAPTER 10 TIMER/COUNTER FUNCTIONS (REAL-TIME PULSE UNIT)

The real-time pulse unit (RPU) measures pulse intervals and frequencies, and outputs programmable pulses. It is capable of 16-bit measurement. It can also generate various types of pulses, such as interval pulse and one-shot pulse.

#### **10.1 FEATURES**

- Timer 0 (TM0)
  - 16-bit timer/event counter
  - Two count clock sources (system clock frequency division selected or external pulse input)
  - Four capture/compare registers
  - Count clear pin (TCLR)
  - Five interrupt sources
  - Two external pulse outputs
- Timer 1 (TM1)
  - 16-bit interval timer
  - · Count clock generated by dividing the system clock frequency
  - Compare register
  - Interrupt source

#### **10.2 BASIC CONFIGURATION**

The basic configuration of the real-time pulse unit is listed below.

| Table 10-1. Config | guration of | the | RPU |
|--------------------|-------------|-----|-----|
|--------------------|-------------|-----|-----|

| Timer   | Count clock    | Register | Read/write | Generated<br>interrupt<br>signal | Capture<br>trigger | Timer<br>output SR | Other<br>functions |   |
|---------|----------------|----------|------------|----------------------------------|--------------------|--------------------|--------------------|---|
| Timer 0 | <i>φ</i> /2    | ТМО      | Read       | INTOV0                           | -                  | -                  | External clear     |   |
|         | φ/4<br>φ/8     | CC00     | Read/write | INTCC00                          | INTP00             | TO00 (S)           | -                  |   |
|         | φ/16<br>φ/32   |          | CC01       | Read/write                       | INTCC01            | INTP01             | TO00 (R)           | - |
|         |                |          | CC02       | Read/write                       | INTCC02            | INTP02             | TO01 (S)           | - |
|         | TI pin input   | CC03     | Read/write | INTCC03                          | INTP03             | TO01 (R)           | -                  |   |
| Timer 1 | φ/32<br>φ/64   | TM1      | Read       | -                                | -                  | -                  | -                  |   |
|         | φ/128<br>φ/256 | CM1      | Read/write | INTCM1                           | -                  | -                  | -                  |   |

**Remark** φ : System clock SR : Set/reset

#### (1) Timer 0 (16-bit timer/event counter)



Notes 1. Internal count clock

- 2. External count clock
- **3.** A reset takes precedence.

**Remark**  $\phi$ : System clock

#### (2) Timer 1 (16-bit interval timer)



Note Internal count clock

**Remark**  $\phi$ : System clock

#### 10.2.1 Timer 0

#### (1) Timer 0 (TM0)

TM0 functions as a 16-bit free-running timer or external signal event counter. It can be used mainly for period measurement, frequency measurement, and pulse output. TM0 can be read from only in 16-bit units.



TM0 is used to count the internal or external count clock pulses. The timer is started and stopped using bit CE0 of timer control register 0 (TMC0).

TMC0 is used to select whether internal or external count clock is to be selected.

#### (a) When the external count clock is selected

TM0 functions as an event counter. An effective edge is specified using timer unit mode register 0 (TUM0), and TM0 is incremented according to the TI pin input.

#### (b) When the internal count clock is selected

TM0 functions as a free-running timer. It is used to count the internal clock ( $\phi/2$  to  $\phi/64$ ) pulses specified in register TMC0.

When the timer overflows, an overflow interrupt can be generated. Setting register TUM0 properly can stop the timer after an overflow occurs.

External input TCLR can clear and start the timer. Because the prescaler is cleared at the same time, the time between the input of TCLR and the first time the timer reaches its full count is fixed according to the frequency division ratio of the prescaler. TUM0 specifies the behavior.

Inputting  $\overline{\text{RESET}}$  clears (0) all bits of TM0.

#### (2) Capture/compare registers 00 to 03 (CC00 to CC03)

Each capture/compare register consists of 16 bits and is connected to TM0. The capture/compare registers are used as either capture or compare registers according to the setting of timer unit mode register 0 (TMU0). They can be read from and written to in 16-bit units.



#### (a) When a capture/compare register is specified as a capture register

If a capture/compare register is specified as a capture register, it detects the effective edge of the corresponding external interrupt (INTP00 to INTP03) as a capture trigger. Timer 0 latches the count in synchronization with the capture trigger (capturing). Capturing occurs asynchronously with the count clock. The latched value is held in the capture register until capturing occurs again.

If capturing (latching) and writing by an instruction contend for the capture register, instruction execution takes precedence, and capturing is ignored.

The effective edges (rising edge, falling edge or both rising and falling edges) of an external interrupt can be selected using the ICU mode register (IMOD). (See **Section 4.4.5**.)

If a capture/compare register is specified as a capture register, an interrupt occurs on the effective edge of INTP00 to INTP03. In this case, INTCCn (compare register match signal) cannot be used to cause an interrupt.

#### (b) When a capture/compare register is specified as a compare register

If a capture/compare register is specified as a compare register, the value in the register is compared with the content of the timer each time the timer is incremented. When they match, an interrupt is generated.

The compare register provides a set/reset output function. It sets or resets the corresponding timer output in synchronization with the occurrence of the a match signal.

The interrupt source that becomes effective varies with the function of the selected register.

If a capture/compare register is specified as a compare register, register TUM0 can be used to select either INTCCn (match signal) or INTPn (effective edge detection) as an interrupt signal. If INTPn is selected, an external interrupt becomes acceptable in concurrence with timer output specification.

#### 10.2.2 Timer 1

#### (1) Timer 1 (TM1)

TM1 is a 16-bit timer. It can be used mainly as an interval timer for software. TM1 can be read from in 16-bit units. It is a read-only register.



TM1 is started and stopped using bit CE1 of timer control register 1 (TMC1).

For the count clock, the ratio of frequency division by the prescaler can be selected from  $\phi/32$ ,  $\phi/64$ ,  $\phi/128$ , and  $\phi/256$  according to the setting of register TMC1.

Inputting RESET clears (0) all bits of TM1.

Caution Once a comparison match occurs, the timer is cleared on the next count clock pulse. So, if the frequency division ratio is large, the timer value may not be zero even when it is read immediately after the occurrence of a comparison match interrupt.

#### (2) Compare register 1 (CM1)

CM1 is a 16-bit register and is connected to TM1. It can be read from and written to in 16-bit units.



The content of TM1 is compared with that of CM1 each time TM1 is incremented. When a match is detected, it causes an interrupt (INTCM1). At the same time, TM1 is cleared.

#### **10.3 CONTROL REGISTERS**

#### (1) Timer unit mode register 0 (TUM0)

TUM0 is a register used to control the behavior of timer 0. It specifies the operation mode of the capture/ compare registers.

TUM0 can be read from and written to in 16-bit units.



| Bit position | Bit name |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                    |    | Description                           |  |  |
|--------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|----|---------------------------------------|--|--|
| 13           | OST      | <ul> <li>Overflow Stop</li> <li>Specifies the action to be taken after the timer overflows. This flag is effective only for TM0.</li> <li>0: The timer keeps to increment after it overflows.</li> <li>1: The timer stops and holds 0000H when it overflows.</li> <li>CE0 of TMC0 remains to be 1. The timer is caused to restart incrementing by:</li> <li>Setting CE0 to 1, when ECLR0 = 0, or</li> <li>Inputting a trigger to the timer clear pin (TCLR), when ECLR0 = 1</li> </ul> |                    |    |                                       |  |  |
| 12           | ECLR0    | <ul> <li>External Input Timer Clear</li> <li>Enables the timer to be cleared according to an external clear input (TCLR) to TMO.</li> <li>0: TM0 is not cleared by an external input.</li> <li>1: TM0 is cleared by an external input. After cleared, it restarts incrementing.</li> </ul>                                                                                                                                                                                             |                    |    |                                       |  |  |
| 11, 10       | TES0     | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | e Selec<br>ies the |    | edge of an external clock input (TI). |  |  |
|              |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | TE                 | S0 | Effective edge                        |  |  |
|              |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 0                  | 0  | RFU (reserved)                        |  |  |
|              |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 0 1 Fa             |    | Falling edge                          |  |  |
|              |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 1                  | 0  | Rising edge                           |  |  |
|              |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 1                  | 1  | Both rising and falling edges         |  |  |

# **Phase-out/Discontinued**

| Bit position | Bit name    |                                                                                                                                                                                                                                                                                             |                     |           | Description                                                                                                                                         |       |  |
|--------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------|-------|--|
| 9, 8         | CES0        | TCLR Edge Select<br>Specifies the effective edge of an external clear input (TCLR).                                                                                                                                                                                                         |                     |           |                                                                                                                                                     |       |  |
|              |             |                                                                                                                                                                                                                                                                                             | CES0 Effective edge |           |                                                                                                                                                     |       |  |
|              |             |                                                                                                                                                                                                                                                                                             | 0                   | 0         | RFU (reserved)                                                                                                                                      |       |  |
|              |             |                                                                                                                                                                                                                                                                                             | 0                   | 1         | Falling edge                                                                                                                                        |       |  |
|              |             |                                                                                                                                                                                                                                                                                             | 1                   | 0         | Rising edge                                                                                                                                         |       |  |
|              |             |                                                                                                                                                                                                                                                                                             | 1 1                 |           | Both rising and falling edges                                                                                                                       |       |  |
| 7-4          | CMS00-CMS03 | Capture/Compare Mode Select<br>Selects the operation mode of the capture/compare registers (CC00 to CC03).<br>0: The capture/compare registers work as capture registers. Capturing can<br>occur only when CE0 of TMC0 is 1.<br>1: The capture/compare registers work as compare registers. |                     |           |                                                                                                                                                     |       |  |
| 3-0          | IMS00-IMS03 | Selects<br>0: C                                                                                                                                                                                                                                                                             | s INTPr<br>ompare   | e registe | CCn as an interrupt source (n = 00 to 03).<br>er match signal INTCCn is used as an interrupt sig<br>it signal INTPn is used as an interrupt signal. | gnal. |  |

#### (2) Timer control register 0 (TMC0)

TMC0 controls the behavior of TM0.

TMC0 can be read from and written to in 8-bit units.



| Bit position | Bit name |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                        |    | Description                                            |  |  |  |
|--------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|----|--------------------------------------------------------|--|--|--|
| 7            | CE0      | <ul> <li>Count Enable</li> <li>Controls the behavior of the timer.</li> <li>0: The timer stops at 0000H. It does not work.</li> <li>1: The timer works, except when ECLR0 of TUM0 is 1. When ECLR0 is 1, the timer waits for a TCLR input. When a TCLR input occurs, the timer starts counting.</li> <li>If ECLR0 = 0, the timer starts the instant 1 is written to CE0. If CE0 is set to 1 with ECLR0 = 1, the timer will not start even when ECLR0 is reset to 0.</li> </ul> |                        |    |                                                        |  |  |  |
| 4            | ETI      | <ul> <li>External TI Input</li> <li>Switches between the external and internal count clocks.</li> <li>0: Specifies a φ-based clock (internal).</li> <li>1: Specifies TI (external).</li> </ul>                                                                                                                                                                                                                                                                                 |                        |    |                                                        |  |  |  |
| 3, 2         | PRS0     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | aler Cloo<br>s an inte |    | ct<br>bunt clock ( $\phi$ m is an intermediate clock). |  |  |  |
|              |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | PR                     | S0 | Count clock                                            |  |  |  |
|              |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 0                      | 0  | <i>ø</i> m                                             |  |  |  |
|              |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 0                      | 1  | φm/4                                                   |  |  |  |
|              |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 1                      | 0  | φm/8                                                   |  |  |  |
|              |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 1                      | 1  | <i>φ</i> m/16                                          |  |  |  |
| 0            | PRM0     | Prescaler Clock Mode<br>Selects an intermediate count clock φm (where φ is the system clock).<br>0: φ/2<br>1: φ/4                                                                                                                                                                                                                                                                                                                                                              |                        |    |                                                        |  |  |  |

#### Caution Do not change the count clock when the timer is operating.

#### (3) Timer control register 1 (TMC1)

TMC1 controls the behavior of TM1.

TMC1 can be read from and written to in 8-bit units.



| Bit position | Bit name |                                                                                                       |                                                                                                                                           |                    | Description |  |  |  |  |
|--------------|----------|-------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|--------------------|-------------|--|--|--|--|
| 7            | CE1      | Contro<br>0: 1                                                                                        | Count Enable<br>Controls the behavior of the timer.<br>0: The timer stops at 0000H. It does not work.<br>1: The timer works.              |                    |             |  |  |  |  |
| 2            | PRS1     | Select<br>0: ¢                                                                                        | Prescaler Clock Select<br>Selects an internal count clock ( <i>φ</i> m is an intermediate clock).<br>0: <i>φ</i> m/16<br>1: <i>φ</i> m/32 |                    |             |  |  |  |  |
| 1, 0         | PRM1     | Prescaler Clock Mode Selects an intermediate count clock $\phi$ m (where $\phi$ is the system clock). |                                                                                                                                           |                    |             |  |  |  |  |
|              |          |                                                                                                       | PR                                                                                                                                        | M1                 | φm          |  |  |  |  |
|              |          |                                                                                                       | 0                                                                                                                                         | 0                  | φ/2         |  |  |  |  |
|              |          |                                                                                                       | 0 1 φ/4                                                                                                                                   |                    |             |  |  |  |  |
|              |          |                                                                                                       | 1 0 φ/8                                                                                                                                   |                    |             |  |  |  |  |
|              |          |                                                                                                       |                                                                                                                                           | 1 1 RFU (reserved) |             |  |  |  |  |

Caution Do not switch the count clock when the timer is operating.

#### (4) Timer output control register 0 (TOC0)

TOC0 controls the timer output from the pins TO00 and TO01. TOC0 can be read from and written to in 8-bit units.



| Bit position | Bit name          | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|--------------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7, 5         | ENTO01,<br>ENTO00 | <ul> <li>Enable TOxx pin</li> <li>Disables or enables the corresponding timer outputs (TO00 and TO01).</li> <li>0: The timer output is disabled. The reversed (inactive) level of the ALV bit is output from the corresponding TO00 and TO01 pins. If a match signal occurs with the corresponding compare register, the level at TO00 or TO01 does not change.</li> <li>1: The timer output is enabled. When a match signal occurs with the corresponding compare register, the timer output changes. The reverse (inactive) level of the ALV bit is output, until the first match signal occurs after the timer output is enabled.</li> </ul> |
| 6, 4         | ALV01,<br>ALV00   | Active Level TOxx pin<br>Specifies the active level of the timer output.<br>0: Active low level<br>1: Active high level                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 1, 0         | TOPC01,<br>TOPC00 | Timer Output Control<br>Specifies the pin function of the TO01/INTP02 and TO00/INTP00 dual-function<br>pins.<br>0: <u>TO01 a</u> nd T <u>O00 out</u> puts<br>1: INTP02 and INTP00 inputs                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

**Remark** For the TO00 and TO01 output flip-flops, a reset takes precedence.

### Caution The TO00 or TO01 output does not change on an external interrupt signal (INTP0n). To use TO00 and TO01, it is necessary to specify the capture/compare registers as the compare registers (CMS0n = 1).

#### (5) ICU mode register (IMOD)

This is a control register for specifying the effective edge of an external interrupt signal. (See **Chapter 4** for details.)

#### (6) Timer overflow status register (TOVS)

TOVS holds flags to indicate an overflow from TM0 or TM1.

TOVS can be read from and written to in 8-bit units.

TOVS can be tested and reset by software to poll about the occurrence of an overflow.



| Bit position | Bit name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|--------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1, 0         | OVFn     | <ul> <li>Overflow Flag</li> <li>Overflow flag for TMn (n = 0 or 1)</li> <li>0: TMn has not overflowed.</li> <li>1: TMn has overflowed.</li> <li>Caution TM0 causes an interrupt request signal INTOV0 to be sent to the interrupt controller in synchronization with an overflow. However, an interrupt operation is completely independent of TOVS. Similarly to other overflow flags, the TM0 overflow flag can be operated on by software. This does not affect the interrupt request flag in the interrupt controller corresponding to INTOV0.</li> </ul> |
|              |          | No transfer occurs to the TOVS register during access from the CPU. If an overflow occurs while the TOVS register is being read from, the flag is not changed. Instead, it is changed at the next read timing.                                                                                                                                                                                                                                                                                                                                                |

#### **10.4 OPERATION OF TIMER 0**

#### 10.4.1 Counting

Timer 0 functions as a 16-bit free-running timer or external signal event counter. Timer control register 0 (TMC0) is used to specify the behavior of timer 0.

If timer 0 is working as a free-running timer, when the content of a register (CC00 to CC03) matches the count in TM0, an interrupt signal can be generated, and timer output TOxx can be set and reset. In addition, the count in TM0 can be captured in a register (CC00 to CC03) in synchronization with the effective edge detected at the external interrupt request input pin (external trigger). The captured value is retained until the next capture trigger occurs.





#### 10.4.2 Count Clock Selection

There are two types of count clocks for timer 0, that is internal and external. The ETI bit of register TMC0 specifies which count clock is to be used.

Caution Do not switch the count clock when the timer is operating.

#### (1) Internal count clock (ETI bit = 0)

An internal count clock is selected from  $\phi/2$ ,  $\phi/4$ ,  $\phi/8$ ,  $\phi/16$ ,  $\phi/32$ , and  $\phi/64$  according to the setting of bits PRS0 and PRM0 of register TMC0.

| PR | S0 | PRM0 | Count clock  |
|----|----|------|--------------|
| 0  | 0  | 0    | φ/2          |
| 0  | 0  | 1    | φ/4          |
| 0  | 1  | 0    | φ/8          |
| 0  | 1  | 1    | <i>ф</i> /16 |
| 1  | 0  | 0    | <i>ф</i> /16 |
| 1  | 0  | 1    | <i>φ</i> /32 |
| 1  | 1  | 0    | <i>φ</i> /32 |
| 1  | 1  | 1    | <i>ф</i> /64 |

#### (2) External count clock (ETI bit = 1)

TM0 counts signals input at the TI pin. It can function also as an event counter. The effective edge of a signal at TI is specified using bit TES0 of register TUM0.

| TES0 |   | Effective edge                |  |
|------|---|-------------------------------|--|
| 0    | 0 | RFU (reserved)                |  |
| 0    | 1 | Falling edge                  |  |
| 1    | 0 | Rising edge                   |  |
| 1    | 1 | Both rising and falling edges |  |

#### 10.4.3 Overflow

If TM0 overflows when it is counting external or internal count clock pulses, bit OVF0 of the TOVS register is set to generate an overflow interrupt (INTOV).

Setting the OST bit of TUM0 to 1 can cause the timer to stop after an overflow occurs. If the timer stops due to an overflow, it will not restart until CE0 is set to 1 by software.

Setting CE0 to 1 when the timer is counting does not affect the operation of the timer.





#### 10.4.4 Clearing/Starting the Timer by the TCLR Input

Timer 0 usually starts counting when bit CE0 of register TMC0 is set to 1. However, external input TCLR can be used to clear TM0 and cause it to start counting.

When ECLR0 = 1 and OST = 0, setting CE0 to 1, then inputting an effective edge to TCLR causes the timer to start counting. When TM0 is operating, inputting an effective edge to TCLR clears the timer and causes it to restart counting. (See **Figure 10-3**.)

When ECLR0 = 0 and OST = 1, setting CE0 to 1, then inputting an effective edge to TCLR causes TM0 to start counting. When TM0 overflows, it stops counting and is kept from restarting until an effective edge is input to TCLR. If an effective edge is detected at TCLR when TM0 is operating, TM0 is cleared, then starts and continues counting. (See **Figure 10-4**.)





Figure 10-4. Clearing/Starting TM0 by a TCLR Input and the Related Overflow (When ECLR0 = 0 and OST = 1)



#### 10.4.5 Capturing

The capture register can capture the count value from TM0 in synchronization with an external trigger, independently of the count clock of TM0. This operation is called capturing. An effective edge detected at an external interrupt request input pin INTPn (n = 00 to 03) is used as an external trigger (called capture trigger) for capturing. The count value is sent from TM0 to a capture register in synchronization with this capture trigger signal. The capture register retains its content until another capture trigger occurs.

In addition, the INTPn input signal causes an interrupt signal INTCCn.

| Capture register | Capture trigger signal |
|------------------|------------------------|
| CC00             | INTP00                 |
| CC01             | INTP01                 |
| CC02             | INTP02                 |
| CC03             | INTP03                 |

Table 10-2. Capture Trigger Signal for the 16-Bit Capture Register (TM0)

Remark CC00 to CC03 are capture/compare registers. Timer unit mode register 0 (TUM0) is used to specify whether a capture/compare register is to be used as a capture register or compare register.

The effective edge of the capture trigger is specified using the ICU mode register (IMOD).

If both rising and falling edges are specified as capture triggers, it is possible to measure the width of an external input pulse. If either a rising or a falling edge is specified as a capture trigger, it is possible to measure the period of an input pulse.

Figure 10-5. Example of TM0 Capturing (When Both Rising and Falling Edges Are Specified)



**Remark** Dn (n = 0, 1, 2, ...): TM0 count value

If CE0 is cleared (0), inputting an interrupt signal does not trigger capturing.

### CHAPTER 10 TIMER/COUNTER Phase-out/Discontinued





#### 10.4.6 Comparison

A value in a compare register is compared with the count value in TM0. This operation is called comparison. When a value previously set in the compare register matches the count value in TM0, a match signal is sent to the output control circuit. (See **Figure 10-7**.) The match signal changes the level at the timer output pins (TO00 and TO01), and generates an interrupt request signal at the same time.

| Table 10-3. | Interrupt Request | t Signal from the | 16-Bit Compare Register | (TM0) |
|-------------|-------------------|-------------------|-------------------------|-------|
|             |                   |                   |                         |       |

| Compare register | Interrupt request signal |
|------------------|--------------------------|
| CC00             | INTCC00                  |
| CC01             | INTCC01                  |
| CC02             | INTCC02                  |
| CC03             | INTCC03                  |

**Remark** CC00 to CC03 are capture/compare registers. Timer unit mode register 0 (TUM0) is used to specify whether a capture/compare register is to be used as a capture register or compare register.



**Remark** A match is detected immediately after the timer is incremented, generating a match detection signal.

TM0 has two timer output pins (TO00 and TO01).

When the count value in TM0 is compared with the content of CC00, if they match, the output level of TO00 is set. When the count value in TM0 is compared with the content of CC01, if they match, the output level of TO00 is reset.

Similarly, when the count value in TM0 is compared with the content of CC02, if they match, the output level of TO01 is set. When the count value in TM0 is compared with the content of CC03, if they match, the output level of TO01 is reset.

The output level of TO00 and TO01 can be specified using TOC0.





#### **10.5 OPERATION OF TIMER 1**

#### 10.5.1 Counting

Timer 1 functions as a 16-bit interval timer. Timer control register 1 (TMC1) is used to specify the operation of timer 1.

Timer 1 counts internal count clock pulses ( $\phi$ /32 to  $\phi$ /256) specified by bits PRS0 and PRM0 of register TMC1.

When the count value in TM1 matches the content of CM1, TM1 is cleared, and a match interrupt (INTCM1) is generated simultaneously.



#### Figure 10-9. Basic Operation of Timer 1

#### 10.5.2 Input Clock Selection

An internal count clock is selected from  $\phi/32$ ,  $\phi/64 \phi/128$ , and  $\phi/256$  according to the setting of bits PRS0 and PRM0 of register TMC1.

Caution Do not switch the count clock when the timer is operating.

| PF | RS0 | PRM0 | Count clock    |
|----|-----|------|----------------|
| 0  | 0   | 0    | φ/32           |
| 0  | 0   | 1    | <i>ф</i> /64   |
| 0  | 1   | 0    | <i>ф</i> /128  |
| 0  | 1   | 1    | RFU (reserved) |
| 1  | 0   | 0    | <i>ф</i> /64   |
| 1  | 0   | 1    | <i>ф</i> /128  |
| 1  | 1   | 0    | <i>ф</i> /256  |
| 1  | 1   | 1    | RFU (reserved) |

#### 10.5.3 Overflow

If TM1 overflows when it counts an internal count clock pulses, bit OVF1 of the TOVS register is set.

#### 10.5.4 Comparison

A value in the compare register (CM1) is compared with the count value in TM1. This operation is called comparison.

If a match is detected in comparison, an interrupt (INTCM1) occurs. After an interrupt occurs, TM1 is cleared to 0 at the next count timing. (See **Figure 10-10**.) This function enables timer 1 to be used as an interval timer.

CM1 can be set with 0. If CM1 overflows and TM1 becomes 0, a match is detected, and INTCM1 occurs. TM1 is cleared (0) at the next count timing, but INTCM1 does not occur on this match. (See **Figure 10-11**.)



Figure 10-10. Operation from When CM1 Is 1 until It Is FFFFH

**Remark** Interval = (n + 1) x count clock period n = 1 to 65,535 (FFFFH)

### CHAPTER 10 TIMER/COUNTER Phase-out/Discontinued



Figure 10-11. Operation with CM1 Cleared to 0

Remark Interval = (FFFFH + 2) x count clock period

#### **10.6 EXAMPLES OF APPLICATIONS**

#### (1) Operation as an interval timer (timer 1)

In this example, timer 1 is set with an interval previously set in compare register CM1, and used as an interval timer to generate interrupts repeatedly at the set intervals. Figure 10-12 shows the timing, and Figure 10-13 is the flowchart of the setting procedure.





#### Remark n : Value in CM1

t : Interval timer = (n + 1) x count clock period





#### (2) Pulse width measurement (timer 0)

Timer 0 is used for pulse width measurement. In this example, the timer is used to measure the width of the high or low level of an external pulse input at pin INTP02.

As shown in Figure 10-14, a capture/compare register (CC02) captures the count value from timer 0 (TM0) in synchronization with an effective edge (either rising or falling edge) of an input to INTP02.

When the nth effective edge is detected, CC02 captures the count value (Dn) from TM0 on that effective edge, and the difference between this count value (Dn) and the count value (Dn-1) captured at the previous effective edge (n-1) is calculated. The pulse width is obtained by multiplying this difference by the count clock period.

Figure 10-15 shows the procedure for setting up pulse width measurement.



Figure 10-14. Pulse Width Measurement Timing (Timer 0)

**Remark** Dn: TM0 count value (n = 0, 1, 2, ...)

#### Figure 10-15. Pulse Width Measurement Setting Procedure (Timer 0)



Figure 10-16. Pulse Width Calculation Interrupt Request Handling Routine (Timer 0)



Caution If an overflow occurs more than once between the (n-1)th capture and nth capture, it is impossible to measure the pulse width.

#### (3) Operation as PWM output (timer 0)

An arbitrary square waveform can be output from the timer output pins (TO00 and TO01) by combining timer 0 and the timer output function.

#### (a) How to use timer 0

PWM output uses two capture/compare registers (CC00 and CC01). INTP00/TO00 should be placed in the set/reset output mode. This setting enables outputting a PWM signal with 16-bit precision from pin TO00. The timing relationships are shown in Figure 10-17.

When timer 0 is used as a 16-bit timer, a value in a capture/compare register CC00 determines the timing of the rising edge of the PWM output, and a value in CC01 determines the timing of the falling edge, as shown in Figure 10-17.

Figure 10-18 shows the procedure for setting up the PWM output.



Figure 10-17. PWM Output Timing (TM0)

**Remark** Dxx: Value set in a compare register

 $t1 = \{(FFFFH - D00) + D01\} x count clock period$ 

t2 = {(FFFFH - D10) + D11} x count clock period

#### Figure 10-18. PWM Output Setting Procedure (Timer 0)







#### (4) Period measurement (timer 0)

Timer 0 can be used to measure the period of an external pulse input at pin INTPn (n = 00 to 03). In this example, the period of an external pulse input at INTP00 is measured with 16-bit precision by combining timer 0 and CC00 (capture/compare register).

The IMOD register is used to specify the rising edge of an input signal at INTP00 as an effective edge. When the nth rising edge is detected, CC00 captures the count value (Dn) from TM0 on that edge, and the difference between this count value (Dn) and the count value (Dn-1) captured at the previous rising edge (n-1) is calculated. The pulse period is obtained by multiplying this difference by the count clock period.

Figure 10-21 shows the procedure for setting up period measurement.





**Phase-out/Discontinued** 







#### Figure 10-22. Period Calculation Interrupt Request Handling Routine (Timer 0)



#### **10.7 CAUTIONS**

The detection of a match using a compare register is always carried out immediately after the timer is incremented. A match is not detected in the following cases.

#### (1) When writing to a compare register (TM0 and TM1)



#### (2) When cleared externally (TM0)



#### (3) When cleared by a timer (TM1)

Timer value

| Count clock                  |                                                           |
|------------------------------|-----------------------------------------------------------|
| Timer value                  | 65,534 X 65,535 X 0 X 0 X 1                               |
| Internal match clear         |                                                           |
| Match detection              | ·                                                         |
|                              | A match does not occur.                                   |
| If a timer is operating in a | free-running mode, when it overflows, it is cleared to 0. |
| Count clock                  |                                                           |

Overflow interrupt

0

1

2

3

65,535

65,534



### **CHAPTER 11 WATCHDOG TIMER FUNCTIONS**

The watchdog timer is intended to prevent program crash and deadlock.

#### **11.1 FEATURES**

- The following three different time-out time values can be specified: 10.5 ms, 41.9 ms, and 167.8 ms (when system clock  $\phi = 25$  MHz)
- Watchdog timer time-out output (WDTOUT)

#### **11.2 CONFIGURATION**



Figure 11-1. Watchdog Timer Block Diagram

**Remark**  $\phi$ : System clock

#### (1) Watchdog timer

One of the watchdog timer functions is to secure the oscillation settling time of the system clock. When the system is reset or placed in the STOP mode, the timer is cleared to 00H.

The watchdog timer behaves in the standby modes as follows:

#### (a) STOP mode

The watchdog timer stops counting. When the system is released from the STOP mode, the timer value is cleared.

The watchdog timer starts counting at 00H, and keeps counting until a time-out occurs. A time-out signal is supplied to the oscillation settling time control circuit, thus starting to supply the system clock pulse. At this point, the WDTOUT pin does not become active. If the system is released from the STOP mode by the  $\overline{\text{NMI}}$  pin, the timer continues counting.

#### (b) IDLE mode

The watchdog timer stops counting, but it holds the count value.

When the system is released from the IDLE mode, the watchdog timer resumes counting by starting at the current count value.

#### (c) HALT mode

The watchdog timer continues counting.

#### (2) Active timer

The watchdog timer outputs the WDTOUT signal when it times out. The active timer retains this signal for 32 clock cycles.

When the watchdog timer times out, it can cause a system reset by connecting the WDTOUT and RESET pins through an external circuit.

#### **11.3 OPERATION**

The watchdog timer indicates that the program or system is running normally, by keeping the WDTOUT pin from becoming active.

To use the watchdog timer, it is necessary to specify the WDTM register so that the watchdog timer is cleared (restarted to count) at constant intervals during program execution or at the beginning of a subroutine. If the watchdog timer expires because it is not cleared within a specified period of time, the WDTOUT pin becomes active, indicating a program failure. In addition, the WDT time-out flag (OV) is set. This flag is cleared by clearing the WDT counter.

To use a watchdog timer time-out as an interrupt source, it is necessary to connect the WDTOUT pin to an external interrupt request pin ( $\overline{INTPn}$  or  $\overline{NMI}$ ) through an external circuit.

### 11.4 WDT MODE REGISTER (WDTM)

The WDT mode register controls the behavior of the watchdog timer. The WDT mode register can be read from and written to in 8-bit units.



|       | Description                                                                                                                                                                                                                                       |                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| KEY   | <ul> <li>KEY data</li> <li>Identifies data. KEY should be set as follows:</li> <li>KEY = 011</li> <li>A value other than 011 cannot be written to the WDTM register. A value read from this register is always 000.</li> </ul>                    |                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
| BWOS  | BLOCK/WDTOUT Output Select<br>Selects the BLOCK or WDTOUT output signal as output.<br>0: WDTOUT output<br>1: BLOCK output                                                                                                                         |                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
| EN    | Enable<br>Causes the watchdog timer to start or stop counting.<br>0: Stop counting<br>1: Start counting                                                                                                                                           |                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
| CL/OV | Clear/Overflow<br>When the watchdog timer is write-accessed, this bit specifies whether the<br>count value in the watchdog timer and the time-out flag are cleared.                                                                               |                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
|       |                                                                                                                                                                                                                                                   | CL                                                                                                                                                                           | Operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
|       |                                                                                                                                                                                                                                                   | 0                                                                                                                                                                            | Neither the count value nor the time-out flag is cleared (nothing is carried out).                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
|       |                                                                                                                                                                                                                                                   | 1                                                                                                                                                                            | The count value and the time-out flag are cleared.                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
|       | When the watchdog timer is read-accessed, this bit specifies that the watchdog timer time-out flag can be read-accessed. If a time-out occurs the system is released from the STOP mode, the time-out flag is not set.         OV       Operation |                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
|       |                                                                                                                                                                                                                                                   |                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
|       |                                                                                                                                                                                                                                                   | 0                                                                                                                                                                            | A time-out has not occurred.                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
|       |                                                                                                                                                                                                                                                   | 1                                                                                                                                                                            | A time-out has occurred.                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
|       | BWOS                                                                                                                                                                                                                                              | Identifi<br>KEY<br>A valu<br>from th<br>BWOS BLOCH<br>Select:<br>0: W<br>1: E<br>EN Enable<br>Cause<br>0: \$<br>1: \$<br>CL/OV Clear/O<br>When<br>count of<br>When<br>watcho | Identifies data.         KEY = 011         A value other that         from this registe         BWOS       BLOCK/WDTOU         Selects the BLO         0:       WDTOUT 0         1:       BLOCK ou         EN       Enable         Causes the watch         0:       Stop count         1:       Start count         CL/OV       Clear/Overflow         When the watch       0         1       When the watch         vatchdog timer the system is rel       0         0       0 | Identifies data. KEY should be set as follows:         KEY = 011         A value other than 011 cannot be written to the WDTM register. A value from this register is always 000.         BWOS       BLOCK/WDTOUT Output Select         Selects the BLOCK or WDTOUT output signal as output.         0: WDTOUT output         1: BLOCK output         1: BLOCK output         2: WDTOUT output         1: BLOCK output         2: Stop counting         1: Start counting         CL/OV         Clear/Overflow         When the watchdog timer is write-accessed, this bit specifies whether the count value in the watchdog timer and the time-out flag are cleared.         Image: CL/OV         CL       Operation         0       Neither the count value nor the time-out flag is cleared (nothing is carried out).         1       The count value and the time-out flag are cleared.         When the watchdog timer is read-accessed, this bit specifies that the watchdog timer time-out flag can be read-accessed. If a time-out occurs the system is released from the STOP mode, the time-out flag is not set.         OV       Operation         0       A time-out has not occurred. |  |  |

| Bit position | Bit name | Description                                                                                                                              |                                                                |   |                          |        |        |              |
|--------------|----------|------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------|---|--------------------------|--------|--------|--------------|
| 1, 0         | WDTI     |                                                                                                                                          | WDT Input<br>Specifies the count clock for the watchdog timer. |   |                          |        |        |              |
|              |          |                                                                                                                                          | WDTI Count clock Time-out time (ms)                            |   |                          |        |        |              |
|              |          |                                                                                                                                          | $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$         |   |                          | 16 MHz | 20 MHz | 25 MHz       |
|              |          |                                                                                                                                          |                                                                |   | 2 <sup>10</sup> / $\phi$ | 16.4   | 13.1   | 10.5         |
|              |          |                                                                                                                                          |                                                                |   | 65.5                     | 52.4   | 41.9   |              |
|              |          |                                                                                                                                          | 1                                                              | 0 | 2 <sup>14</sup> / $\phi$ | 262.1  | 209.7  | 167.8        |
|              |          | 1 1 This setting is inhibited.                                                                                                           |                                                                |   |                          |        |        |              |
|              |          | <ul> <li>Ø: System clock</li> <li>If this bit is changed while the watchdog timer is running, normal operation of guaranteed.</li> </ul> |                                                                |   |                          |        |        |              |
|              |          |                                                                                                                                          |                                                                |   |                          |        |        | operation is |



### **CHAPTER 12 PORT FUNCTIONS**

The V821 pins are dual-function pins that can function as both port and control pins. See **Section 2.1** for details of each pin.

### **12.1 FEATURES**

• 10 input/output ports (P00 to P09)

### **12.2 CONFIGURATION**



### **12.3 PIN FUNCTIONS OF PORT 0**

Port register 0 (P0) is a 16-bit input/output port. For this register, it is possible to specify input/output in 16-bit units.



| Bit position | Bit name | Description                    |
|--------------|----------|--------------------------------|
| 9-0          | P9-P0    | Port data<br>Input/output port |

## Caution If port register 0 is read when control mode is specified, the level at the corresponding pin of port 0 is read. The level of the pin, such as DACK0, that functions as an output pin in control mode is not read.

Port mode register 0 (PM0) is used to specify whether port 0 is to work as an input or output port.

### (1) When specified as an output port (PM0 = 0)

When the port register is write-accessed, a value is written to the output latch. When it is read-accessed, a value is read from the output latch.

### (2) When specified as an input port (PM0 = 1)

When the port register is write-accessed, a value is written to the output latch. When it is read-accessed, the level of the corresponding pin of port 0 is read.

### **12.4 CONTROL REGISTER**

The input/output ports are controlled using port mode control register 0 (PMC0) and port mode register 0 (PM0).

### 12.4.1 Port Mode Control Register 0 (PMC0)

The control mode is selected if the corresponding bit of PMC0 is set (1). The port mode is selected if the bit is reset (0).

PMC0 can be read from and written to in 16-bit units.



| Bit position | Bit name | Description                                    |  |  |  |
|--------------|----------|------------------------------------------------|--|--|--|
| 9-0          | MS9-MS0  | Mode Select<br>0: Port mode<br>1: Control mode |  |  |  |

### 12.4.2 Port Mode Register 0 (PM0)

If the port mode is selected, PM0 specifies the port pin as either input or output. Table 12-1 lists how the port behaves when PMC0 is set to the control mode.

PM0 can be read from and written to in 16-bit units.



| Bit position | Bit name | Description                                                                         |  |  |  |
|--------------|----------|-------------------------------------------------------------------------------------|--|--|--|
| 9-0          | PM9-PM0  | Port Mode<br>0: Output mode (output buffer on)<br>1: Input mode (output buffer off) |  |  |  |

| Port name   | Port operation       |           |                   |            |  |  |
|-------------|----------------------|-----------|-------------------|------------|--|--|
|             | MSr                  | n = 0     | MSn = 1           |            |  |  |
|             | PMn = 0              | PMn = 1   | PMn = 0           | PMn = 1    |  |  |
| P00/TCLR    | P00 output           | P00 input | TCLR input        |            |  |  |
| P01/DREQ0   | P01 output           | P01 input | DREQ0 input       |            |  |  |
| P02/DACK0   | P02 output P02 input |           | DACK0 input       |            |  |  |
| P03/DREQ1   | P03 output P03 input |           | DREQ1 input       |            |  |  |
| P04/DACK1   | P04 output           | P04 input | DACK1 input       |            |  |  |
| P05/SI      | P05 output           | P05 input | SI input          |            |  |  |
| P06/SO      | P06 output           | P06 input | SO output         |            |  |  |
| P07/SCLK    | P07 output P07 input |           | SCLK input/output |            |  |  |
| P08/TXD/UBE | P08 output           | P08 input | UBE output        | TXD output |  |  |
| P09/RXD/TC  | P09 output           | P09 input | TC output         | RXD input  |  |  |

Table 12-1. Port Operation



### **CHAPTER 13 CLOCK GENERATION FUNCTIONS**

The clock generator generates and controls the internal clock pulse ( $\phi$ ) for the CPU and other built-in hardware units.

### **13.1 FEATURES**

- Frequency multiplication (5 times) using a PLL (phase locked loop) synthesizer
- Clock sources
  - Resonator-based oscillation:  $fxx = 1/5 \times \phi$  (PLL mode)
  - External clock:  $fxx = 1/5 x \phi$  (PLL mode)
  - External clock:  $fxx = 2 x \phi$  (direct mode)

### ★ 13.2 CONFIGURATION



 $\phi$  : Internal clock frequency ( $\phi = 1/2 \cdot 10 \cdot fxx$ : PLL mode) Internal clock frequency ( $\phi = 1/2 \cdot fxx$ : Direct mode)

OSC : Oscillator (only for the PLL mode)

### **13.3 INPUT CLOCK SELECTION**

The clock generator consists of a clock oscillator and PLL synthesizer. Connecting, for example, a 5 MHz quartz or ceramic resonator to the X1 and X2 pins can generate a 25 MHz system clock pulse.

Moreover, an external clock pulse can be input directly to the oscillator. In this case, the clock signal should be supplied to the X1 pin, and the X2 pin should be left open.

The clock generator supports two basic operation modes: PLL and direct modes. Either operation mode is selected during a reset using the TCLR pin. The input signal at the TCLR pin is latched when the RESET pin becomes inactive. However, the input signal should be kept at the same level during a reset (while the RESET pin is active). Assume that the hold time for RESET signal rising at the TCLR pin is one clock. A malfunction may occur if the level of the TCLR pin varies during a reset.

| TCLR | Operation mode |  |  |  |
|------|----------------|--|--|--|
| 0    | PLL mode       |  |  |  |
| 1    | Direct mode    |  |  |  |

#### 13.3.1 Direct Mode

In the direct mode, an external clock pulse having a frequency twice as high as the frequency of the system clock is input to the clock generator. Operation with low power dissipation is possible in this mode, because the OSC and PLL synthesizer do not operate. The direct mode is suitable for applications in which the V821 operates at a relatively low frequency. To minimize influence by noise, the frequency (fxx) of the external clock should be kept at about 32 MHz or less (system clock  $\phi = 16$  MHz).

To use the external clock directly, it is necessary to keep the TCLR pin at 1 during a reset.

#### 13.3.2 PLL Mode

In the PLL mode, the system clock pulse ( $\phi$ ) is generated by connecting an external resonator or supplying an external clock pulse and multiplying its frequency in the PLL synthesizer.

A frequency of up to 25 MHz can be obtained using a 3 to 5 MHz external resonator or clock. So, the PLL mode can be used to implement a low-noise, low-power dissipation system. The frequency (5 x fxx) of the generated system clock pulse ( $\phi$ ) is five times as high as that (fxx) of the external resonator or clock.

To use the PLL mode, it is necessary to keep the TCLR pin at 0 during a reset.

#### Examples of clocks used in the PLL mode

| System clock frequency ( $\phi$ ) | External resonator/clock frequency (fxx) |
|-----------------------------------|------------------------------------------|
| 25.000 MHz                        | 5.0000 MHz                               |
| 20.000 MHz                        | 4.0000 MHz                               |
| 16.384 MHz                        | 3.2768 MHz                               |

### (1) Back-up mode

In PLL mode, even if the crystal or built-in oscillator is failed for some reason and clock supply is stopped, the internal system clock ( $\phi$ ) at the self-sustained frequency of the VCO can be supplied continuously. This increases the reliablity of the application system. This is called the back-up mode. This function is available only for the PLL mode. The BU bit indicates whether the clock is in the back-up mode.

Caution If the clock shifts to the back-up mode, it is detected after a lock-up state (UL bit = 0) is entered. This function is provided in case of failures. It does not guarantee all operations at the self-sustained frequency. It is not recommended that clock input be stopped intentionally to enter back-up mode.

### (2) Lock-up time

Immediately after the system is switched on or released from the stop or idle mode, a frequency settling time (lock-up time) is required before the PLL enters a phase locked state at the specified frequency and becomes stable. This condition is called the unlocked state, while the condition under which the oscillation frequency is stable is called the locked state.

The stable state of the PLL frequency is indicated in the UL flag of the clock control register (CGC). Once a factor that causes the unlocked state (such as clock stop or power break) occurs, processing that depends on software execution speed, such as real-time processing, should check the UL flag by software immediately after it starts and waits until the clock becomes stable if necessary.

On the other hand, static processing, such as setting on-chip hardware or initializing register or memory data, can be performed without waiting until the UL flag is reset.

The UL flag remains set to "0" as long as the lock-up state is maintained and is not initialized by means of system reset.

This flag is read-only and cannot be written.

### 13.4 CLOCK OUTPUT CONTROL

The behavior of the CLKOUT pin can be specified using the COE bit of the clock control register (CGC). It is possible to save power effectively by combining the standby modes such as halt, idle, and stop.

### (1) Clock output disabled mode

The clock output from the CLKOUT pin is disabled.

In this mode, the CLKOUT operation is kept at a complete stop, so it is possible to reduce power dissipation further and suppress noise radiation from the CLKOUT pin.



### 13.5 CLOCK CONTROL REGISTER (CGC)

The CGC register controls the output of the CLKOUT pin.

This register can be read from and written to in 8-bit units except for bits 1 and 2, which can only be readaccessed.



| Bit position | Bit name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|--------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-4          | KEY      | <ul> <li>KEY data</li> <li>Identifies data. KEY should be set as follows:</li> <li>KEY = 0111</li> <li>If KEY is set to other than 0111, it is impossible to write to the CGC register.</li> <li>When read-accessed, the CGC register always outputs 0000.</li> </ul>                                                                                                                                                                                     |
| 3            | CESEL    | Crystal External Select<br>Specifies the function of the X1 and X2 pins.<br>0: A resonator is connected to the X1 and X2 pins.<br>1: An external clock is connected to the X1 pin.<br>The X1 pin is provided with a pull-down transistor. During the stop mode, it<br>keeps the X1 bit at the ground level to stop the oscillator.<br>To use an external clock in the PLL mode, it is necessary to set CESEL to 1.                                        |
| 2            | BU       | <ul> <li>Back Up</li> <li>Flag to indicate whether the back-up mode has been selected.</li> <li>0: The back-up mode has not been selected.</li> <li>1: The back-up mode has been selected.</li> <li>The back-up mode is indicated in the BU bit after a lock-up state is entered (UL = 0). This bit is cleared to 0 by a system reset or when the stop mode is selected.</li> <li>It is a read-only bit. An attempt to write to it is ignored.</li> </ul> |
| 1            | UL       | Unlock<br>Flag to indicate whether the unlock state has been entered.<br>0: Locked state<br>1: Unlocked state<br>The UL bit is set to 1 by a system reset or when the stop mode is selected.<br>Once the clock is locked, it is kept in that state.<br>This bit is a read-only bit. An attempt to write to it is ignored.                                                                                                                                 |
| 0            | COE      | Clock Out Enable<br>Enables or disables the CLKOUT output.<br>0: Disables output (the CLKOUT pin is fixed at the high level.)<br>1: Enables output.                                                                                                                                                                                                                                                                                                       |



### **CHAPTER 14 STANDBY FUNCTIONS**

The V821 supports three standby modes to suppress power dissipation. In these standby modes, the operation of the clock is controlled. The HALT instruction is used to select a standby mode. Mode switching is controlled using the standby control register.

### **14.1 FEATURES**

- HALT mode (Only the CPU clock stops.)
- IDLE mode (The CPU and peripheral operation clocks stop. The clock generator continues to operate.)
- STOP mode (The entire system, including the clock generator, stops.)

### 14.2 STANDBY MODE

The standby modes of the V821 are detailed below.

#### (1) HALT mode

In this mode, the clock generator (oscillator and PLL synthesizer) continues operation, but the CPU clock stops. Clock supply to other built-in peripheral functions continues to allow them to keep running. Intermittent operation achieved using this standby mode in conjunction with the ordinary operation mode can reduce the total power dissipation of the system.

#### (2) IDLE mode

In this mode, the clock generator (oscillator and PLL synthesizer) continues operation, but internal system clock supply is stopped to bring the entire system to a stop.

When the system is released from the IDLE mode, it is unnecessary to secure oscillation settling time for the oscillator, and therefore it is possible for the system to shift to the ordinary operation quickly. For the oscillation settling time and current drain, the IDLE mode lies in between the stop and HALT modes. The IDLE mode is suitable for an application where it is necessary to cut the oscillation settling time using a low current drain mode.

### (3) STOP mode

In this mode, the clock generator (oscillator and PLL synthesizer) is stopped to bring the entire system to a stop. This mode can generate an ultra-low power dissipation condition; only leak current occurs.

### (a) PLL mode

In this mode, the PLL synthesizer clock output is stopped simultaneously with the oscillator. After the system is released from the STOP mode, it is necessary to allow oscillation settling time for the oscillator. Some programs require a PLL lock-up time.

### (b) Direct mode

In the direct mode, it is unnecessary to secure lock-up time.

Table 14-1 lists the operation of the clock generator in the ordinary, halt, idle, and STOP modes. An effective low power dissipation system can be implemented by combining and switching these modes.

| Clock       | Clock source         |          | Oscillator<br>(OSC) | PLL<br>synthesizer | Clock supply<br>to the pe-<br>ripheral I/O | Clock supply to the CPU |
|-------------|----------------------|----------|---------------------|--------------------|--------------------------------------------|-------------------------|
| PLL mode    | Resonator-           | Ordinary | 0                   | 0                  | 0                                          | 0                       |
|             | based<br>oscillation | Halt     | 0                   | 0                  | 0                                          | х                       |
|             |                      | Idle     | 0                   | 0                  | х                                          | х                       |
|             |                      | Stop     | х                   | x                  | х                                          | х                       |
|             | External clock       | Ordinary | х                   | 0                  | 0                                          | 0                       |
|             |                      | Halt     | х                   | 0                  | 0                                          | х                       |
|             |                      | Idle     | х                   | 0                  | х                                          | х                       |
|             |                      | Stop     | х                   | х                  | х                                          | х                       |
| Direct mode |                      | Ordinary | х                   | х                  | 0                                          | 0                       |
|             |                      | Halt     | х                   | х                  | 0                                          | х                       |
|             |                      | Idle     | х                   | х                  | х                                          | х                       |
|             |                      | Stop     | х                   | x                  | х                                          | х                       |

Table 14-1. Clock Generator Operation under Standby Control

o: Operating

x: Stop

## **Phase-out/Discontinued**

### State transition



### 14.3 STANDBY CONTROL REGISTER (STBC)

The standby control register controls standby.

The STBC register can be read from and written to in 8-bit units.



| Bit position | Bit name | Description                                                                                                                                                                                                                                                             |                                                                       |   |                          |           |               |          |  |  |
|--------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------|---|--------------------------|-----------|---------------|----------|--|--|
| 7-4          | KEY      | <ul> <li>KEY data</li> <li>Identifies data. KEY should be set as follows:</li> <li>KEY = 0111</li> <li>If KEY is set to other than 0111, it is impossible to write to the STBC register.</li> <li>When read-accessed, the STBC register always outputs 0000.</li> </ul> |                                                                       |   |                          |           |               |          |  |  |
| 3, 2         | WT       |                                                                                                                                                                                                                                                                         | Wait Time<br>Specifies the count clock for oscillation settling time. |   |                          |           |               |          |  |  |
|              |          |                                                                                                                                                                                                                                                                         | W                                                                     | Т | Count clock              | Oscillati | on settling t | ime (ms) |  |  |
|              |          |                                                                                                                                                                                                                                                                         |                                                                       |   |                          | 16 MHz    | 20 MHz        | 25 MHz   |  |  |
|              |          |                                                                                                                                                                                                                                                                         | 0                                                                     | 0 | 2 <sup>19</sup> / $\phi$ | 32.8      | 26.2          | 21.0     |  |  |
|              |          |                                                                                                                                                                                                                                                                         | 0                                                                     | 1 | 218/ <i>φ</i>            | 16.4      | 13.1          | 10.5     |  |  |
|              |          |                                                                                                                                                                                                                                                                         | 1                                                                     | 0 | 2 <sup>17</sup> / $\phi$ | 8.2       | 6.6           | 5.2      |  |  |
|              |          |                                                                                                                                                                                                                                                                         | 1                                                                     | 1 | 2 <sup>16</sup> / $\phi$ | 4.1       | 3.3           | 2.6      |  |  |
|              |          | φ: Sy                                                                                                                                                                                                                                                                   | φ : System clock                                                      |   |                          |           |               |          |  |  |
| 1, 0         | SMD      | Standby Mode<br>Specifies a standby mode.<br>The HALT instruction places the system in a standby mode selected according<br>to the setting of SMD.                                                                                                                      |                                                                       |   |                          |           |               |          |  |  |
|              |          | SMD Standby mode                                                                                                                                                                                                                                                        |                                                                       |   |                          |           |               |          |  |  |
|              |          |                                                                                                                                                                                                                                                                         | 0                                                                     | 0 | HALT mode                |           |               |          |  |  |
|              |          |                                                                                                                                                                                                                                                                         | 0                                                                     | 1 | This setting is inhi     | bited.    |               | ]        |  |  |
|              |          |                                                                                                                                                                                                                                                                         | 1 0 IDLE mode                                                         |   |                          |           |               |          |  |  |
|              |          |                                                                                                                                                                                                                                                                         | 1 1 STOP mode                                                         |   |                          |           |               |          |  |  |

### 14.4 HALT MODE

### 14.4.1 Placing the System in the HALT Mode and Operation State

In the HALT mode, the clock generator (oscillator and PLL synthesizer) continues operation, but the CPU clock is stopped. Clock supply to other built-in peripheral functions continues to allow them to keep running. The total power dissipation of the system can be reduced by placing the CPU in the HALT mode when it is not running.

Executing the HALT instruction with the SMD bits of the standby control register (STBC) reset to 00 starts the halt acknowledge cycle, then shifting the system to the HALT mode.

In the HALT mode, program execution stops, but the contents of all registers are retained. In addition, the on-chip peripheral functions independent of CPU instruction execution continues operation.

If the HALT instruction is executed to shift the system to the HALT mode during a DMA block transfer, an actual shift to the HALT mode occurs only after the block transfer ends. If the HALT instruction is executed to shift the system to the HALT mode during a DMA single or single-step transfer, the DMAC opens the bus to the CPU at the end of each bus cycle. At this point, a halt acknowledge cycle begins, thus shifting the system to the HALT mode.

Table 14-2 lists the state in which each piece of the hardware is during HALT mode.

| Function               |                                                                                                                          | Operation state                                   |  |  |
|------------------------|--------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------|--|--|
| Clock generator        | Operating                                                                                                                |                                                   |  |  |
| Internal system clock  | Operating                                                                                                                |                                                   |  |  |
| CPU                    | Stop                                                                                                                     |                                                   |  |  |
| I/O line               | Retained                                                                                                                 |                                                   |  |  |
| Peripheral function    | Operating                                                                                                                |                                                   |  |  |
| Internal data          | All internal data such as CPU register contents retains the state in which it is before the system enters the HALT mode. |                                                   |  |  |
| A0-A23, UBE            | PC output                                                                                                                | High impedance when $\overline{\text{HLDAK}} = 0$ |  |  |
| D0-D15                 | High impedance                                                                                                           |                                                   |  |  |
| CS0-CS3                | 1                                                                                                                        | High impedance when $\overline{\text{HLDAK}} = 0$ |  |  |
| IORD, IOWR             |                                                                                                                          |                                                   |  |  |
| WE/LMWR, UMWR          |                                                                                                                          |                                                   |  |  |
| REFRQ, RAS, LCAS, UCAS | 1 Note                                                                                                                   |                                                   |  |  |
| HLDRQ                  | Operating                                                                                                                |                                                   |  |  |
| CLKOUT                 | Clock output (un                                                                                                         | less disabled)                                    |  |  |

### Table 14-2. Operations during the HALT Mode

Note Except during CBR refresh

### 14.4.2 Releasing the System from the HALT Mode

The system is released from the HALT mode by a nonmaskable interrupt request, unmasked maskable interrupt request, or a  $\overrightarrow{\text{RESET}}$  pin input.

### (1) Release by a nonmaskable interrupt request (NMI)

When the active level of the  $\overline{\text{NMI}}$  pin is detected, CPU clock supply is resumed. Because the  $\overline{\text{NMI}}$  input is a level input, it must be retained until a branch occurs to the  $\overline{\text{NMI}}$  handler (at this point, it is insured that the interrupt has been accepted).

### (2) Release by a maskable interrupt request

When an unmasked maskable interrupt request occurs, CPU clock supply is resumed.

To select the HALT mode in the interrupt handling routine, it is necessary to enable an interrupt that can release the system from the HALT mode before executing the HALT instruction. More specific, it is necessary to enable an interrupt (PSW.ID = 0, EP = 0) and to specify the interrupt enable level (PSW.I3 to I0).

### Operation after the system is released from the HALT mode by an interrupt request

| Cause of release           | EI state (PSW.ID = 0)         | DI state (PSW.ID = 1) |
|----------------------------|-------------------------------|-----------------------|
| NMI request                | Branch to the handler address |                       |
| Maskable interrupt request | Branch to the handler address | Not released          |

### (3) Release by the $\overline{\text{RESET}}$ pin input

Same as the ordinary reset operation

### 14.5 IDLE MODE

#### 14.5.1 Placing the System in the IDLE Mode and Operation State

In the IDLE mode, the clock generator (oscillator and PLL synthesizer) continues operation, but internal system clock pulse supply stops, bringing the entire system to a stop.

When the system is released from the IDLE mode, it is unnecessary to secure oscillation settling time for the oscillator or lock-up time for the PLL, and therefore, the system can resume the ordinary operation quickly.

When the HALT instruction is executed with the SMD bits of the standby control register (STBC) set to 10, the halt acknowledge cycle begins. After this cycle begins, the CBR self-refresh cycle also begins, thus shifting the system to the IDLE mode.

When the system enters the IDLE mode, all programs are stopped, and the contents of all registers are retained. The built-in peripheral functions also stop operating.

A bus hold request is accepted during the IDLE mode. When a bus hold request is accepted, the bus is placed in a high-impedance state. When the hold request is canceled, the CBR self-refresh cycle restarts. Note that a bus hold request is not accepted during the halt acknowledge cycle and the first six clock cycles of the CBR self-refresh cycle after the system is put in the IDLE mode.

If the HALT instruction is executed to shift the system to the IDLE mode during a DMA block transfer, an actual shift to the IDLE mode occurs only after the block transfer ends. If the HALT instruction is executed to shift the system to the IDLE mode during a DMA single or single-step transfer, the DMAC opens the bus to the CPU at the end of each bus cycle. At this point, a halt acknowledge cycle is started, thus shifting the system to the IDLE mode.

If the bus hold function is used when the DRAM controller is used in IDLE mode, do not input  $\overline{\text{NMI}}$  while  $\overline{\text{CS0}}/\overline{\text{REFRQ}}$  output is inactive or in the high-impedance state, so as not to suspend restart of the self-refresh cycle after bus hold.

Table 14-3 lists the state in which each piece of the hardware is during IDLE mode.

| Function               |                                                                                                                          | Operation state                                   |  |
|------------------------|--------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------|--|
| Clock generator        | Operating                                                                                                                |                                                   |  |
| Internal system clock  | Stop                                                                                                                     |                                                   |  |
| CPU                    | Stop                                                                                                                     |                                                   |  |
| I/O line               | Retained                                                                                                                 |                                                   |  |
| Peripheral function    | Stop                                                                                                                     |                                                   |  |
| Internal data          | All internal data such as CPU register contents retains the state in which it is before the system enters the IDLE mode. |                                                   |  |
| A0-A23, UBE            | PC output                                                                                                                | High impedance when $\overline{\text{HLDAK}} = 0$ |  |
| D0-D15                 | High impedance                                                                                                           |                                                   |  |
| CS0-CS3                | 1                                                                                                                        | High impedance when $\overline{\text{HLDAK}} = 0$ |  |
| IORD, IOWR             |                                                                                                                          |                                                   |  |
| WE/LMWR, UMWR          |                                                                                                                          |                                                   |  |
| REFRQ, RAS, LCAS, UCAS | CBR self-refresh                                                                                                         |                                                   |  |
| HLDRQ                  | Operating                                                                                                                |                                                   |  |
| CLKOUT                 | Clock output (unless disabled)                                                                                           |                                                   |  |

### Table 14-3. Operations during the IDLE Mode

### 14.5.2 Releasing the System from the IDLE Mode

The system is released from the IDLE mode by a nonmaskable interrupt request or a RESET pin input.

### (1) Release by a nonmaskable interrupt request (NMI)

When the active level of the  $\overline{\text{NMI}}$  pin is detected, CPU clock supply is resumed. Because the  $\overline{\text{NMI}}$  input is a level input, it must be retained until a branch occurs to the NMI handler (at this point, it is insured that the interrupt has been accepted).

Interrupt handling started when the system is released from the IDLE mode by an NMI input is treated in the same way as the ordinary NMI processing performed at an emergency (because the address of the NMI handler is unique). If it is necessary to identify the two types of processing by program, a software status flag should be prepared and set before the execution of the HALT instruction. The NMI interrupt handler can check this flag to distinguish itself from the ordinary NMI processing.

For the system to enter the IDLE mode during execution of the NMI handler, it is necessary to reset PSW.NP to 0 before the HALT instruction is executed so that an NMI request becomes acceptable.



Figure 14-1. Bus Hold in IDLE Mode and Restart of Self-Refresh

### **Remarks 1.** A broken line indicates a high impedance.

- 2. An arrow indicates a sampling timing.
- Caution When the DRAM controller is used and the bus hold function is used in IDLE mode, restart of self-refresh cycle must not be suspended after the bus is held. Do not input  $\overline{\text{NMI}}$  while the  $\overline{\text{CS0}/\text{REFRQ}}$  output is at a high impedance or inactive (high level).

### (2) Release by the $\overline{\text{RESET}}$ pin input

Same as the ordinary reset operation

### 14.6 STOP MODE

### 14.6.1 Placing the System in the STOP Mode and Operation State

In the STOP mode, the clock generator (oscillator and PLL synthesizer) is stopped to bring the entire system to a stop. This mode can generate an ultra-low power dissipation condition; only leak current occurs.

When the HALT instruction is executed with the SMD bits of the standby control register (STBC) set to 11, the halt acknowledge cycle is started. After this cycle begins, the CBR self-refresh cycle also begins, thus shifting the system to the STOP mode.

In the PLL mode (TCLR pin = 0 during a reset) and the resonator-based mode (CESEL of the clock control register (CGC) = 0), it is necessary to secure oscillation settling time after the system is released from the STOP mode.

When the system enters the STOP mode, all programs are stopped, and the contents of all registers are retained. The built-in peripheral functions also stop operating.

A bus hold request is not accepted during the STOP mode. A bus hold request issued during the halt acknowledge cycle before the system shifts to the STOP mode is ignored.

If the HALT instruction is executed to shift the system to the STOP mode during a DMA block transfer, an actual shift to the STOP mode occurs only after the block transfer ends. If the HALT instruction is executed to shift the system to the STOP mode during a DMA single or single-step transfer, the DMAC opens the bus to the CPU at the end of each bus cycle. At this point, a halt acknowledge cycle is started, thus shifting the system to the STOP mode.

Table 14-4 lists the state in which each piece of the hardware is during the STOP mode.

| Function                                                             | Operation state                                                                                                          |
|----------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------|
| Clock generator                                                      | Stop                                                                                                                     |
| Internal system clock                                                | Stop                                                                                                                     |
| CPU                                                                  | Stop                                                                                                                     |
| I/O line                                                             | Retained                                                                                                                 |
| Peripheral function                                                  | Stop                                                                                                                     |
| Internal data                                                        | All internal data such as CPU register contents retains the state in which it is before the system enters the STOP mode. |
| A0-A23, UBE                                                          | PC output                                                                                                                |
| D0-D15                                                               | High impedance                                                                                                           |
| $\overline{CS0}$ - $\overline{CS3}$                                  | 1                                                                                                                        |
| IORD, IOWR                                                           |                                                                                                                          |
| WE/IMWR, UMWR                                                        |                                                                                                                          |
| $\overline{REFRQ}, \overline{RAS}, \overline{LCAS}, \overline{UCAS}$ | CBR self-refresh                                                                                                         |
| HLDRQ                                                                | Stop                                                                                                                     |
| CLKOUT                                                               | 1                                                                                                                        |

### Table 14-4. Operations during the STOP Mode

## 14.6.2 Releasing the System from the STOP Mode

The system is released from the STOP mode by a nonmaskable interrupt request or a RESET pin input. To release the system from the STOP mode when the oscillator is being used (during the PLL mode (TCLR pin = 0 during a reset) in the resonator-based mode (CESEL of the CGC register = 0), it is necessary to secure oscillation settling time for the oscillator.

Phase-out/Discontinue

### (1) Release by a nonmaskable interrupt request (NMI input)

When the active level of the  $\overline{\text{NMI}}$  pin is detected, clock generation is resumed. After the oscillation settling time specified in the WT bit of the standby control register (STBC) elapses, internal system clock supply begins. Because the  $\overline{\text{NMI}}$  input is a level input, it must be retained until the system is released from the STOP mode and a branch occurs to the NMI handler (at this point, it is insured that the interrupt has been accepted).

Interrupt handling started when the system is released from the STOP mode by an NMI input is treated in the same way as the ordinary NMI processing performed at an emergency (because the address of the NMI handler is unique). If it is necessary to identify the two types of processing by program, a software status flag should be prepared and set before the execution of the HALT instruction. The NMI interrupt handler can check this flag to distinguish itself from the ordinary NMI processing.

For the system to enter the STOP mode during execution of the NMI handler, it is necessary to reset PSW.NP to 0 before the HALT instruction is executed so that an NMI request becomes acceptable.

### (2) Release by the RESET pin input

Same as the ordinary reset operation

### 14.7 SECURING OSCILLATION SETTLING TIME

There are two methods to secure oscillation settling time for the oscillator after the system is released from the STOP mode.

### (1) Oscillation settling time secured using a timer (NMI input)

Supplying an effective edge to the  $\overline{\rm NMI}$  pin releases the system from the STOP mode. The oscillation settling time timer is used to determine the time required for the oscillator to become stable. After the specified time elapses, the output of the system clock begins, causing a branch to the NMI handler address.



## **Phase-out/Discontinued**

### (2) Oscillation settling time secured using a signal level width (RESET pin input)

Supplying a falling edge to the RESET pin releases the system from the STOP mode.

The width of a low level supplied to the pin is used to provide the time required for the clock output of the oscillator to become stable.

After a rising edge occurs at the RESET pin, internal system clock supply begins, causing a branch to the handler address related to a system reset.



### Oscillation settling time timer

The oscillation settling time timer is used to secure oscillation settling time for the oscillator when the system is released from the STOP mode. This timer is used also as a watchdog timer. It is cleared to 00H when the system is put in the STOP mode.

The WT bit of the STBC register is used to select a count clock for the oscillation settling time timer as listed below:

| N | /T | Count clock              | Time            |            |                 |
|---|----|--------------------------|-----------------|------------|-----------------|
|   |    |                          | $\phi = 16$ MHz | φ = 20 MHz | $\phi$ = 25 MHz |
| 0 | 0  | 2 <sup>19</sup> / $\phi$ | 32.8 ms         | 26.2 ms    | 21.0 ms         |
| 0 | 1  | 2 <sup>18</sup> / $\phi$ | 16.4 ms         | 13.1 ms    | 10.5 ms         |
| 1 | 0  | 2 <sup>17</sup> / $\phi$ | 8.2 ms          | 6.6 ms     | 5.2 ms          |
| 1 | 1  | 2 <sup>16</sup> / $\phi$ | 4.1 ms          | 3.3 ms     | 2.6 ms          |

 $\phi$ : Internal system clock frequency

### **CHAPTER 15 RESET FUNCTIONS**

Inputting a low level to the RESET pin triggers a system reset, thus initializing the on-chip hardware. When the RESET pin is driven from a low level to a high, the CPU starts program execution. The registers should be initialized in a program as required.

### **15.1 FEATURES**

• The reset pin is provided with a noise suppressor circuit based on an analog delay (60 to 300 ns).

### **15.2 PIN FUNCTIONS**

Table 15-1 lists the state of the output from each pin during a system reset. The output state is retained during the entire reset period.

After the RESET pin is kept at a low level for 30 clock cycles, if the HLDRQ signal is inactive, a memory read cycle is started to fetch an instruction.

Even during a reset period (when the RESET pin is kept at a low level), activating the HLDRQ signal can place the bus on hold. The state of each pin with the bus put on hold during a reset is basically the same as that with the bus put on hold during a non-reset period. (See **Section 2.2**.)

The HLDRQ signal should be kept inactive during a power-on reset.

It is necessary to provide a pull-up or pull-down resistor to the pins that become high impedance during a reset. If no pull-up or pull-down resistor is provided to these pins, memory may be damaged when the pins are driven to high impedance.

The CLKOUT pin supplies clock pulses even during a reset.

| Pin         | Operation state | Pin          | Operation state |
|-------------|-----------------|--------------|-----------------|
| A0-A23      | Not defined     | HLDAK        | High level      |
| D0-D15      | High impedance  | MRD          |                 |
| P00/TCLR    |                 | LMWR/WE      |                 |
| P01/DREQ0   |                 | UMWR         |                 |
| P02/DACK0   |                 | IORD         |                 |
| P03/DREQ1   |                 | IOWR         |                 |
| P04/DACK1   |                 | CS1-CS3      |                 |
| P05/SI      |                 | RAS          |                 |
| P06/SO      |                 | LCAS         |                 |
| P07/SCLK    |                 | UCAS         |                 |
| P08/TXD/UBE |                 | CS0/REFRQ    |                 |
| P09/RXD/TC  |                 | BLOCK/WDTOUT | Low level       |

## **Phase-out/Discontinued**

### (1) Accepting a reset signal



**Note** The internal system reset signal remains active for at least four system clock cycles, after a reset triggered by the RESET pin ends.

### (2) Power-on reset

When a power-on reset is used, it is necessary to provide an oscillation settling time of at least 10 ms between the power-on time and acceptance of a reset because of a low level at the  $\overrightarrow{\text{RESET}}$  pin.



### **15.3 INITIALIZATION**

Table 15-2 lists the values to which each register is initialized at a reset.

The registers should be initialized in a program as required. The following register especially should be set as required, because it is related to system setting.

• Clock control register (CGC): X1 and X2 pin function, CLKOUT pin operation, etc.

|                   | Register                                                                        |         | Initial value<br>after a reset |
|-------------------|---------------------------------------------------------------------------------|---------|--------------------------------|
| Program counter   | PC                                                                              |         | FFFFFFF0H                      |
| General-purpose   | rO                                                                              |         | 00000000H                      |
| register          | r1-r31                                                                          |         | Not defined                    |
| System register   | Register for saving the state upon the occurrence of an exception or interrupt  | (EIPC)  | Not defined                    |
|                   |                                                                                 | (EIPSW) | Not defined                    |
|                   | Register for saving the state upon the occurrence of an NMI or double exception | (FEPC)  | Not defined                    |
|                   |                                                                                 | (FEPSW) | Not defined                    |
|                   | Exception source register (FECC)                                                |         | 0000H                          |
|                   | (EICC)                                                                          |         | FFF0H                          |
|                   | Program status word (PSW)                                                       |         | 00008000H                      |
|                   | Processor ID register (PIR)                                                     |         | 0000810xH                      |
|                   | Task control word (TKCW)                                                        |         | 000000E0H                      |
|                   | Cache control word (CHCW)                                                       |         | 00000000Н                      |
|                   | Address trap register (ADTRE)                                                   |         | Not defined                    |
| Port              | Port register 0 (P0)                                                            |         | Not defined                    |
|                   | Port mode register 0 (PM0)                                                      |         | 03FFH                          |
|                   | Port mode control register 0 (PMC0)                                             |         | 0000H                          |
| Memory management | Bus cycle type control register (BCTC)                                          |         | 01H                            |
| function          | Programmable wait control register 0 (PWC0)                                     |         | 77H                            |
|                   | Programmable wait control register 1 (PWC1)                                     |         | 77H                            |
|                   | Programmable wait control register 2 (PWC2)                                     |         | 77H                            |
|                   | DRAM configuration register (DRC)                                               |         | 81H                            |
|                   | Refresh control register (RFC)                                                  |         | 80H                            |
|                   | Page-ROM configuration register (PRC)                                           |         | 80H                            |

### Table 15-2. Initial Value in Each Register after a Reset (1/3)



|                      | Register                                             | Initial value<br>after a reset |
|----------------------|------------------------------------------------------|--------------------------------|
| DMA function         | DMA source address register 0H (DSA0H)               | Not defined                    |
|                      | DMA source address register 0L (DSA0L)               | Not defined                    |
|                      | DMA destination address register 0H (DDA0H)          | Not defined                    |
|                      | DMA destination address register 0L (DDA0L)          | Not defined                    |
|                      | DMA source address register 1H (DSA1H)               | Not defined                    |
|                      | DMA source address register 1L (DSA1L)               | Not defined                    |
|                      | DMA destination address register 1H (DDA1H)          | Not defined                    |
|                      | DMA destination address register 1L (DDA1L)          | Not defined                    |
|                      | DMA byte count register 0 (DBC0)                     | Not defined                    |
|                      | DMA byte count register 1 (DBC1)                     | Not defined                    |
|                      | DMA channel control register 0 (DCHC0)               | 0000H                          |
|                      | DMA channel control register 1 (DCHC1)               | 0000H                          |
| Real-time pulse unit | Timer unit mode register 0 (TUM0)                    | 0A00H                          |
|                      | Timer control register 0 (TMC0)                      | 00H                            |
|                      | Timer control register 1 (TMC1)                      | 00H                            |
|                      | Timer output control register 0 (TOC0)               | 03H                            |
|                      | Timer time-out status register (TOVS)                | 00H                            |
|                      | Timer register 0 (TM0)                               | 00H                            |
|                      | Timer register 1 (TM1)                               | 00H                            |
|                      | Capture/compare registers 00 to 03 (CC00 to CC03)    | Not defined                    |
|                      | Compare register 1 (CM1)                             | Not defined                    |
| Serial interface     | Asynchronous serial interface mode register (ASIM)   | 00H                            |
|                      | Asynchronous serial interface status register (ASIS) | 00H                            |
|                      | Reception buffer (RXB, RXBL)                         | Not defined                    |
|                      | Transmission shift register (TXS, TXSL)              | Not defined                    |
|                      | Synchronous serial interface mode register (CSIM)    | 00H                            |
|                      | Serial I/O shift register (SIO)                      | Not defined                    |
|                      | Baud rate generator register (BRG)                   | Not defined                    |
|                      | Baud rate generator prescaler mode register (BPRM)   | 00H                            |

### Table 15-2. Initial Value in Each Register after a Reset (2/3)

| Table 15-2. | Initial Value in Each Register after a Reset (3/3) |
|-------------|----------------------------------------------------|
|-------------|----------------------------------------------------|

| Register                |                                         | Initial value<br>after a reset |
|-------------------------|-----------------------------------------|--------------------------------|
| Interrupt/exception     | Interrupt group priority register (IGP) | E4H                            |
| handling function       | Interrupt clear register (ICR)          | 0000H                          |
|                         | Interrupt request register (IRR)        | 0000H                          |
|                         | Interrupt request mask register (IMR)   | FFFFH                          |
|                         | ICU mode register (IMOD)                | ААААН                          |
| Watchdog timer function | WDT mode register (WDTM)                | 00H                            |
| Clock generator         | Clock control register (CGC)            | 03H                            |
| Standby function        | Standby control register (STBC)         | 00H                            |

Caution The "not defined" state mentioned in the above table occurs at a power-on reset or when data collapses due to coincidence of the falling edge of RESET with the data write timing. The previous state is retained on a falling edge of RESET if a data write is not taking place.



## APPENDIX A REGISTER INDEX

### A.1 REGISTER NAMES

## [A]

| Asynchronous serial interface mode register (ASIM)158   | 8 |
|---------------------------------------------------------|---|
| Asynchronous serial interface status register (ASIS)161 | 1 |

### [B]

| Baud rate generator prescaler mode register (BPRM)181 |  |
|-------------------------------------------------------|--|
| Baud rate generator register (BRG)181                 |  |
| Bus cycle type control register (BCTC) 114            |  |

## [C]

| Capture/compare register 00 (CC00) |  |
|------------------------------------|--|
| Capture/compare register 01 (CC01) |  |
| Capture/compare register 02 (CC02) |  |
| Capture/compare register 03 (CC03) |  |
| Clock control register (CGC)       |  |
| Compare register 1 (CM1)           |  |

## [D]

| DMA byte count register 0 (DBC0)            | 143 |
|---------------------------------------------|-----|
| DMA byte count register 1 (DBC1)            | 143 |
| DMA channel control register 0 (DCHC0)      | 144 |
| DMA channel control register 1 (DCHC1)      | 144 |
| DMA destination address register 0H (DDA0H) | 142 |
| DMA destination address register 0L (DDA0L) | 142 |
| DMA destination address register 1H (DDA1H) | 142 |
| DMA destination address register 1L (DDA1L) | 142 |
| DMA source address register 0H (DSA0H)      | 141 |
| DMA source address register 0L (DSA0L)      | 141 |
| DMA source address register 1H (DSA1H)      | 141 |
| DMA source address register 1L (DSA1L)      |     |
| DRAM configuration register (DRC)           |     |

## [I]

| ICU mode register (IMOD)                | 68 |
|-----------------------------------------|----|
| Interrupt clear register (ICR)          | 66 |
| Interrupt group priority register (IGP) | 64 |
| Interrupt request mask register (IMR)   | 67 |
| Interrupt request register (IRR)        | 66 |

### [P]

| Page-ROM configuration register (PRC)       | .137  |
|---------------------------------------------|-------|
| Port mode control register 0 (PMC0)         | .219  |
| Port mode register 0 (PM0)                  | .219  |
| Port register 0 (P0)                        | 218   |
| Programmable wait control register 0 (PWC0) | . 115 |
| Programmable wait control register 1 (PWC1) | . 116 |
| Programmable wait control register 2 (PWC2) | . 117 |

### [R]

| Reception buffer (RXB, RXBL)   | 162 |
|--------------------------------|-----|
| Refresh control register (RFC) | 129 |

## [S]

| Serial I/O shift register (SIO)                     | '2 |
|-----------------------------------------------------|----|
| Standby control register (STBC)                     | 28 |
| Synchronous serial interface mode register (CSIM)17 | '1 |

## [T]

| 6 |
|---|
| В |
| 1 |
| 2 |
| 3 |
| 4 |
| 9 |
| 3 |
|   |

## [W]

| WDT mode register (WDTM | )2 | 215 |
|-------------------------|----|-----|
|-------------------------|----|-----|

# **Phase-out/Discontinued**

### A.2 REGISTER SYMBOLS

## [A]

| ASIM (asynchronous serial interface mode register)   | 158 |
|------------------------------------------------------|-----|
| ASIS (asynchronous serial interface status register) | 161 |

## [B]

| BCTC (bus cycle type control register)             | 114 |
|----------------------------------------------------|-----|
| BPRM (baud rate generator prescaler mode register) | 181 |
| BRG (baud rate generator register)                 | 181 |

## [C]

| CC00 (capture/compare register 00)                | 187 |
|---------------------------------------------------|-----|
| CC01 (capture/compare register 01)                | 187 |
| CC02 (capture/compare register 02)                | 187 |
| CC03 (capture/compare register 03)                | 187 |
| CGC (clock control register)                      |     |
| CM1 (compare register 1)                          | 188 |
| CSIM (synchronous serial interface mode register) |     |
|                                                   |     |

## [I]

| ICR (interrupt clear register)          | 66 |
|-----------------------------------------|----|
| IGP (interrupt group priority register) |    |
| IMR (interrupt request mask register)   |    |
| IRR (interrupt request register)        | 66 |

## [P]

| P0 (port register 0)                        | 218 |
|---------------------------------------------|-----|
| PM0 (port mode register 0)                  | 219 |
| PMC0 (port mode control register 0)         | 219 |
| PWC0 (programmable wait control register 0) | 115 |
| PWC1 (programmable wait control register 1) | 116 |
| PWC2 (programmable wait control register 2) | 117 |

## [R]

| RFC (refresh control register) | 129 |
|--------------------------------|-----|
| RXB, RXBL (reception buffer)   | 162 |

## [S]

| SIO (serial I/O shift register)172 |  |
|------------------------------------|--|
| STBC (standby control register)    |  |

## [T]

| TM0 (timer 0) |  |
|---------------|--|



| TM1 (timer 1)                           | 188 |
|-----------------------------------------|-----|
| TMC0 (timer control register 0)         | 191 |
| TMC1 (timer control register 1)         | 192 |
| TOC0 (timer output control register 0)  | 193 |
| TOVS (timer overflow status register)   | 194 |
| TUM0 (timer unit mode register 0)       | 189 |
| TXS, TXSL (transmission shift register) |     |
|                                         |     |



## APPENDIX B GENERAL INDEX

## [A]

| A0-A23                               |          |
|--------------------------------------|----------|
| ADC                                  | 122      |
| address bus                          | 35       |
| address multiplexing function        | 121      |
| address space                        | 45       |
| address trap                         | 69       |
| address trap register                | 51       |
| ADTRE                                | 51       |
| ALV01, ALV00                         | 193      |
| ASIM                                 | 158      |
| ASIS                                 | 161      |
| assembler-reserved register          | 50       |
| asynchronous serial interface        | 155      |
| asynchronous serial interface mode   |          |
| register                             | 156, 158 |
| asynchronous serial interface status |          |
| register                             | 156, 161 |
|                                      |          |

## [B]

| back-up mode                                 | 223     |
|----------------------------------------------|---------|
| BAU                                          |         |
| baud rate generator                          | 178     |
| baud rate generator prescaler mode register. | 181     |
| baud rate generator register                 | 181     |
| BC                                           | 143     |
| BCTC                                         | 114     |
| BIU                                          |         |
| BLOCK                                        |         |
| block transfer mode                          | 147     |
| BPR                                          | 181     |
| BPRM                                         | 181     |
| BRCE                                         | 181     |
| BRG 1                                        | 78, 181 |
| BU                                           | 224     |
| built-in peripheral I/O register             | 52      |
| built-in peripheral I/O registers            | 52      |
| bus arbitration unit                         |         |
| bus control function                         |         |
| bus control signal                           |         |

| bus cycle during fly-by transfer100         | ) |
|---------------------------------------------|---|
| bus cycle during which the wait function is |   |
| effective 111                               | 1 |
| bus cycle type control register 114         | 4 |
| bus hold 106                                | 6 |
| bus interface unit28                        | 3 |
| bus lock 108                                | 3 |
| bus priority80                              | ) |
| BWOS                                        | 5 |

## [C]

| [-]                                                                  |
|----------------------------------------------------------------------|
| cache control word51                                                 |
| cancellation with $\overline{\text{HLDRQ}}$ input (in IDLE mode) 133 |
| cancellation with $\overline{\text{NMI}}$ input                      |
| capture/compare registers 00 to 03 187                               |
| capturing (timer 0) 198                                              |
| caution (timer/counter function) 211                                 |
| CBR refresh cycle                                                    |
| CC00-CC03                                                            |
| CE0 191                                                              |
| CE1                                                                  |
| CES0 190                                                             |
| CESEL                                                                |
| CG                                                                   |
| CGC                                                                  |
| CHCW                                                                 |
| CL                                                                   |
| CL/OV                                                                |
| CLKOUT                                                               |
| clock control register 224                                           |
| clock generation function                                            |
| clock generator                                                      |
| clock output control                                                 |
| CLR14-CLR0                                                           |
| CLS                                                                  |
| CM1                                                                  |
| CMS00-CMS03                                                          |
| COE                                                                  |
| compare register 1                                                   |
| comparison (timer 0)199                                              |
|                                                                      |

| comparison (timer 1)            |     |
|---------------------------------|-----|
| connecting DRAM                 |     |
| control register                |     |
| control signal timing           |     |
| count clock selection (timer 0) |     |
| counting (timer 0)              |     |
| counting (timer 1)              |     |
| CPU bus state                   | 75  |
| CPU function                    |     |
| CPU register set                |     |
| CRXE                            |     |
| <u>CS0-CS3</u>                  |     |
| CSI                             |     |
| CSI control register            |     |
| CSIM                            |     |
| СТО                             | 114 |
| CT1                             | 114 |
| СТ2                             | 114 |
| СТ3                             | 114 |
| CTXE                            |     |
| CWS                             |     |
|                                 |     |

## [D]

| D0-D15                                         |
|------------------------------------------------|
| DA15-DA0 142                                   |
| DA23-DA16                                      |
| DACK0, DACK1                                   |
| DAD144                                         |
| data bus                                       |
| data flow during DMA transfer 152              |
| DAW 122                                        |
| DBC0, DBC1 143                                 |
| DBN142                                         |
| DBT 142                                        |
| DCHC0, DCHC1 144                               |
| DDA0, DDA1 141                                 |
| DDA0H, DDA1H 142                               |
| DDA0L, DDA1L 142                               |
| differences between the memory and I/O maps 48 |
| direct mode 222, 226                           |
| division by zero69                             |
| DMA byte count registers 0 and 1 143           |
| DMA channel control registers 0 and 1 144      |
| DMA channel priority150                        |
|                                                |

| DMA control register 140                        |
|-------------------------------------------------|
| DMA control signal 39                           |
| DMA controller28                                |
| DMA destination address registers 0 and 1 141   |
| DMA destination address registers 0H and 1H 142 |
| DMA destination address registers 0L and 1L 142 |
| DMA function (DMA controller) 139               |
| DMA source address registers 0 and 1 140        |
| DMA source address registers 0H and 1H 141      |
| DMA source address registers 0L and 1L 141      |
| DMA transfer end interrupt150                   |
| DMA transfer end output 151                     |
| DMA transfer request150                         |
| DMA transfer type and transfer object148        |
| DMAC                                            |
| DMAC bus state77                                |
| double exception69                              |
| DRAM access                                     |
| DRAM configuration register 122                 |
| DRAM control signal                             |
| DRAM controller 28, 119                         |
| DRAM read cycle93                               |
| DRAM read/write cycle 123                       |
| DRAM write cycle                                |
| DRAMC 28, 119                                   |
| DRC122                                          |
| DREQ0, DREQ1                                    |
| DS145                                           |
| DSA0, DSA1140                                   |
| DSA0H, DSA1H141                                 |
| DSA0L, DSA1L 141                                |
| during fly-by DMA transfer 111                  |
| during two-cycle DMA transfer 111               |
| DWS0 117                                        |
| DWS1 117                                        |

**Phase-out/Discontinued** 

## [E]

| EBS          |          |
|--------------|----------|
| ECLR0        |          |
| ECR          | 51       |
| edge trigger |          |
| EIPC         | 51       |
| EIPSW        | 51       |
| EN           | 145, 215 |

# **Phase-out/Discontinued**

| ENTO01, ENTO00                             |       |
|--------------------------------------------|-------|
| exception handling (software exception and |       |
| exception trap)                            | 69    |
| exception handling cycle                   | . 104 |
| exception source register                  | 51    |
| external I/O access                        | 86    |
| external I/O read cycle                    | 86    |
| external I/O write cycle                   | 87    |
|                                            |       |

## [F]

| FE                                | 161 |
|-----------------------------------|-----|
| FEPC                              | 51  |
| FEPSW                             | 51  |
| floating-point degraded precision | 69  |
| floating-point division by zero   | 69  |
| floating-point overflow           | 69  |
| floating-point reserved operand   | 69  |
| floating-point underflow          | 69  |
| fly-by read cycle                 | 100 |
| fly-by transfer                   | 149 |
| fly-by write cycle                | 102 |
| forcible interruption             | 152 |
| functional block configuration    |     |

## [G]

| general-purpose register | 50 |
|--------------------------|----|
| global pointer           | 50 |

## [H]

| halt acknowledge cycle | 105      |
|------------------------|----------|
| HALT mode              | 225, 229 |
| handler stack pointer  | 50       |
| HLDAK                  |          |
| HLDRQ                  | 35       |

## [I]

| I/O map           |          |
|-------------------|----------|
| ICR               | 66       |
| ICU mode register | 68       |
| IDLE mode         | 225, 231 |
| IGP               | 64       |
| image             |          |
| IMOD              |          |
|                   |          |

| IMR                                         |        | 67    |
|---------------------------------------------|--------|-------|
| IMS00-IMS03                                 |        | . 190 |
| initialization                              |        | . 239 |
| input clock selection                       | . 201, | 222   |
| internal block diagram                      |        | 27    |
| internal I/O access                         |        | 88    |
| internal I/O read cycle                     |        | 88    |
| internal I/O write cycle                    |        | 89    |
| internal unit                               |        | 28    |
| interrupt clear register                    |        | 66    |
| interrupt control signal                    |        | 38    |
| interrupt controller                        |        | 28    |
| interrupt group priority register           |        | 64    |
| interrupt request                           |        | . 164 |
| interrupt request mask register             |        | 67    |
| interrupt request register                  |        | 66    |
| interrupt signal generation control circuit |        | . 169 |
| interrupts                                  |        | 56    |
| INTPO0-INTP03                               |        | 38    |
| INTP10-INTP13                               |        | 38    |
| INTSER                                      |        | . 164 |
| INTSR                                       |        | . 164 |
| INTST                                       |        | . 164 |
| invalid floating-point operation            |        | 69    |
| invalid instruction code                    |        | 69    |
| IORD                                        |        | 36    |
| IOWR                                        |        | 36    |
| IRR                                         |        | 66    |
| ITM00-03, ITM10-13                          |        | 68    |

## [K]

| KEY | <br>224. | 228 |
|-----|----------|-----|
|     | <br>,    |     |

## [L]

| LCAS          |    |
|---------------|----|
| level trigger |    |
| link pointer  | 50 |
| LMWR          |    |
| lock-up time  |    |

## [M]

| MA5-MA3             | 137 |
|---------------------|-----|
| machine fault cycle | 104 |
| maskable interrupt  | 60  |

| maskable interrupt (block diagram)       60         memory access control function       119         memory map       46         MOD       171         MRD       36         MS9-MS0       219         MSK14-MSK0       67 | maskable interrupt priority        | 63  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------|-----|
| memory map         46           MOD         171           MRD         36           MS9-MS0         219                                                                                                                    | maskable interrupt (block diagram) | 60  |
| MOD         171           MRD         36           MS9-MS0         219                                                                                                                                                    | memory access control function     | 119 |
| MRD                                                                                                                                                                                                                       | memory map                         | 46  |
| MS9-MS0                                                                                                                                                                                                                   | MOD                                | 171 |
|                                                                                                                                                                                                                           | MRD                                |     |
| MSK14-MSK067                                                                                                                                                                                                              | MS9-MS0                            | 219 |
|                                                                                                                                                                                                                           | MSK14-MSK0                         | 67  |

## [N]

| NMI                   | 38 |
|-----------------------|----|
| nonmaskable interrupt | 58 |

## [0]

| off-page                            |
|-------------------------------------|
| on-page                             |
| on-page/off-page decision 134       |
| operand read83                      |
| operand write84                     |
| operation of timer 0 195            |
| operation of timer 1 20'            |
| operations during the HALT mode 229 |
| operations during the IDLE mode232  |
| operations during the STOP mode 234 |
| ordering information24              |
| OST                                 |
| OVE                                 |
| overflow (timer 0) 196              |
| overflow (timer 1) 20'              |
| OVFn                                |

## [P]

| P00-P09                                           |
|---------------------------------------------------|
| PAE122                                            |
| page-ROM access                                   |
| page-ROM configuration register 137               |
| page-ROM read cycle92                             |
| PE161                                             |
| pin configuration25                               |
| pin function 31, 237                              |
| pin function of port 0218                         |
| pin functions                                     |
| pin I/O circuit                                   |
| pin I/O circuits and processing of unused pins 42 |

# **Phase-out/Discontinued**

| pin state                               | 34       |
|-----------------------------------------|----------|
| PIR                                     | 51       |
| placing the system in the HALT mode and |          |
| operation                               | 229      |
| placing the system in the IDLE mode and |          |
| operation                               |          |
| placing the system in the STOP mode and |          |
| operation                               |          |
| PLL mode                                | 222, 226 |
| РМ0                                     |          |
| РМ9-РМ0                                 |          |
| PMC0                                    |          |
| port control signal                     | 41       |
| port function                           |          |
| port mode control register 0            | 219      |
| port mode register 0                    |          |
| PR3-PR0                                 | 64       |
| PRC                                     | 137      |
| priority                                | 73       |
| priority of floating-point exception    | 74       |
| priority of interrupt and exception     | 73       |
| PRM0                                    | 191      |
| PRM1                                    | 192      |
| processor ID register                   | 51       |
| program counter                         | 50       |
| program register set                    | 50       |
| program status word                     | 51       |
| programmable wait control register 0    | 115      |
| programmable wait control register 1    | 116      |
| programmable wait control register 2    | 117      |
| programmable wait function              | 110      |
| PRS0                                    | 191      |
| PRS1                                    | 192      |
| PS                                      | 159      |
| PSW                                     | 51       |
| PWC0                                    | 115      |
| PWC1                                    | 116      |
| PWC2                                    | 117      |

## [R]

| r0-r31 |  |
|--------|--|
| RAS    |  |
| RCC    |  |
| READY  |  |

| real-time pulse control signal40                |
|-------------------------------------------------|
| real-time pulse unit                            |
| reception buffer 156, 162                       |
| reception completion interrupt 164              |
| reception control parity check 156              |
| reception error interrupt164                    |
| reception shift register 156                    |
| refresh control register 129                    |
| refresh function                                |
| REFRQ                                           |
| register for saving the current status upon the |
| occurrence of an exception or interrupt         |
| register for saving the current status upon the |
| occurrence of an NMI or double exception 51     |
| relationship between external access and byte   |
| enable signal                                   |
| relationship between external access and the    |
| data bus                                        |
|                                                 |
| release by a maskable interrupt request         |
| release by a nonmaskable interrupt request      |
| (NMI)                                           |
| release by the RESET pin input 230, 233, 235    |
| releasing the system from the HALT mode         |
| releasing the system from the IDLE mode         |
| releasing the system from the STOP mode         |
| REN129                                          |
| REQ14-REQ066                                    |
| request issued by software150                   |
| request received from built-in peripheral       |
| hardware150                                     |
| request received from the DREQ pin 150          |
| RESET                                           |
| reset function                                  |
| return from an exception or interrupt72         |
| RFC 129                                         |
| RI                                              |
| ROM controller                                  |
| ROMC                                            |
| RPU                                             |
| RXB, RXBL                                       |
| RXBn (n = 7-0)                                  |
| RXD                                             |
| RXE                                             |
| RXEB                                            |
|                                                 |

| ເວງ |
|-----|
|-----|

| [-]                                       |      |       |
|-------------------------------------------|------|-------|
| SA15-SA0                                  |      | .141  |
| SA23-SA16                                 |      | 141   |
| SAD                                       |      | . 144 |
| SBN                                       |      | .141  |
| SBT                                       |      | .141  |
| SCLK                                      |      |       |
| SCLS                                      |      | . 160 |
| securing oscillation settling time        |      | 235   |
| selector                                  |      | 157   |
| self-refresh cycle                        |      | 99    |
| self-refresh function                     |      | 132   |
| serial clock control circuit              |      | 169   |
| serial clock counter                      |      | 169   |
| serial clock selector                     |      | 169   |
| serial control signal                     |      | 40    |
| serial I/O shift register                 |      | . 172 |
| serial interface                          |      | 28    |
| serial interface function                 |      | 155   |
| shift register                            |      | 169   |
| SI                                        |      |       |
| single transfer mode                      |      | 146   |
| single-step transfer mode                 |      | 146   |
| SIO                                       |      |       |
| SIOn (n = 7-0)                            |      |       |
| SL                                        |      | 160   |
| SMD                                       |      | 228   |
| SO                                        |      | 40    |
| SOT                                       |      |       |
| SRAM (ROM) access                         |      | 90    |
| SRAM (ROM) read cycle                     |      | 90    |
| SRAM write cycle                          |      |       |
| stack pointer                             |      |       |
| standby control register                  |      | 228   |
| standby function                          |      |       |
| standby mode                              |      | 225   |
| STBC                                      |      |       |
| STOP mode                                 | 225, | 234   |
| string destination start address register |      | 50    |
| string destination start bit offset       |      | 50    |
| string length register                    |      | 50    |
| string source start bit offset            |      | 50    |
| string start address register             |      |       |
| synchronous serial interface              |      | 169   |
|                                           |      |       |



synchronous serial interface mode

| register              | 169, | 171 |
|-----------------------|------|-----|
| system control signal |      | 37  |
| system register set   |      | 51  |

## [T]

| T0 state77                                        |
|---------------------------------------------------|
| T1 and T1S states75                               |
| T1F state                                         |
| T1R state                                         |
| T1W state                                         |
| T2 and T2S states75                               |
| T2F state                                         |
| T2R state                                         |
| T2W state                                         |
| T3 state                                          |
| task control word51                               |
| TC                                                |
| TC                                                |
| TCLR                                              |
| TDIR                                              |
| TES0                                              |
| text pointer                                      |
| TH and THS states75                               |
| TH state                                          |
| TI                                                |
| TI and TIS states75                               |
| TI state                                          |
| timer 0                                           |
| timer 1                                           |
| timer control register 0 191                      |
| timer control register 1 192                      |
| timer output control register 0 193               |
| timer overflow status register 194                |
| timer unit mode register 0                        |
| timer/counter function (real-time pulse unit) 183 |
| TKCW                                              |
| TM                                                |
| TM0                                               |
| TM1                                               |
| TMC0                                              |
| TMC1                                              |
| TO00, TO01                                        |
| TOC0                                              |

| TOPC01, TOPC00                           | 193      |
|------------------------------------------|----------|
| TOVS                                     | 194      |
| transfer mode                            | 146      |
| transfer object                          | 149      |
| transmission completion interrupt        | 164      |
| transmission control parity bit addition | 157      |
| transmission shift register              | 156, 163 |
| TTYP                                     | 145      |
| TUM0                                     | 189      |
| two-cycle transfer                       | 148      |
| TXD                                      |          |
| TXED                                     | 163      |
| TXS, TXSL                                | 156, 163 |
| TXSn (n = 7-0)                           | 163      |
|                                          |          |

### [U]

| UART                  | 28, 155 |
|-----------------------|---------|
| UART control register | 158     |
| UBE                   |         |
|                       |         |
| UL                    |         |
|                       |         |

### [W]

| WA                                                   | 137 |
|------------------------------------------------------|-----|
| wait control during DMA transfer                     | 111 |
| wait control for DRAM cycle                          | 127 |
| wait control function                                | 109 |
| wait control unit                                    |     |
| wait control using the $\overline{\text{READY}}$ pin | 110 |
| watchdog timer                                       |     |
| watchdog timer control signal                        | 41  |
| watchdog timer function                              |     |
| WCU                                                  |     |
| WDT                                                  |     |
| WDT mode register                                    | 215 |
| WDTI                                                 | 216 |
| WDTM                                                 | 215 |
| WDTOUT                                               | 41  |
| WE                                                   |     |
| WS0                                                  | 115 |
| WS1                                                  |     |
| WS2                                                  | 116 |
| WS3                                                  | 116 |

# **Phase-out/Discontinued**

| WT2                          | 228 |
|------------------------------|-----|
| [ <b>X]</b><br>X1, X2        | .37 |
| [ <b>Z]</b><br>zero register | 50  |
| [Others]                     |     |

| 100-011 010500 LVFF | 100-pin plastic LQFP |  |
|---------------------|----------------------|--|
|---------------------|----------------------|--|



[MEMO]



## **Facsimile** Message

FAX

Although NEC has taken all possible steps to ensure that the documentation supplied to our customers is complete, bug free and up-to-date, we readily accept that errors may occur. Despite all the care and precautions we've taken, you may encounter problems in the documentation. Please complete this form whenever you'd like to report errors or suggest improvements to us.

Address

Tel.

From:

Name

Company

Thank you for your kind support.

| North America<br>NEC Electronics Inc.<br>Corporate Communications Dept.<br>Fax: 1-800-729-9288<br>1-408-588-6130 | Hong Kong, Philippines, Oceania<br>NEC Electronics Hong Kong Ltd.<br>Fax: +852-2886-9022/9044 | Asian Nations except Philippines<br>NEC Electronics Singapore Pte. Ltd.<br>Fax: +65-250-3583 |
|------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|
| Europe<br>NEC Electronics (Europe) GmbH<br>Technical Documentation Dept.<br>Fax: +49-211-6503-274                | <b>Korea</b><br>NEC Electronics Hong Kong Ltd.<br>Seoul Branch<br>Fax: 02-528-4411            | Japan<br>NEC Semiconductor Technical Hotline<br>Fax: 044-548-7900                            |
| <b>South America</b><br>NEC do Brasil S.A.<br>Fax: +55-11-6465-6829                                              | <b>Taiwan</b><br>NEC Electronics Taiwan Ltd.<br>Fax: 02-2719-5951                             |                                                                                              |

I would like to report the following error/make the following suggestion:

Document title: \_\_

| Document | number: |
|----------|---------|
|----------|---------|

\_\_\_\_\_ Page number: \_\_\_

If possible, please fax the referenced page or drawing.

| <b>Document Rating</b> | Excellent | Good | Acceptable | Poor |
|------------------------|-----------|------|------------|------|
| Clarity                |           |      |            |      |
| Technical Accuracy     |           |      |            |      |
| Organization           |           |      |            |      |

Phase-out/Discontinue

## NEC