## 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: <a href="http://www.renesas.com">http://www.renesas.com</a>

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

Issued by: Renesas Electronics Corporation (<a href="http://www.renesas.com">http://www.renesas.com</a>)

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 product for any application for which it is not intended without the prior written consent of 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; anti-crime 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 majority-owned subsidiaries.
- (Note 2) "Renesas Electronics product(s)" means any product developed or manufactured by or for Renesas Electronics.

# Regarding the change of names mentioned in the document, such as Mitsubishi Electric and Mitsubishi XX, to Renesas Technology Corp.

The semiconductor operations of Hitachi and Mitsubishi Electric were transferred to Renesas Technology Corporation on April 1st 2003. These operations include microcomputer, logic, analog and discrete devices, and memory chips other than DRAMs (flash memory, SRAMs etc.) Accordingly, although Mitsubishi Electric, Mitsubishi Electric Corporation, Mitsubishi Semiconductors, and other Mitsubishi brand names are mentioned in the document, these names have in fact all been changed to Renesas Technology Corp. Thank you for your understanding. Except for our corporate trademark, logo and corporate statement, no changes whatsoever have been made to the contents of the document, and these changes do not constitute any alteration to the contents of the document itself.

Note: Mitsubishi Electric will continue the business operations of high frequency & optical devices and power devices.

Renesas Technology Corp. Customer Support Dept. April 1, 2003





# 3807 Group

User's Manual
MITSUBISHI 8-BIT SINGLE-CHIP
MICROCOMPUTER
740 FAMILY / 38000 SERIES

| keep safety first in your circuit design | keep | safety | first | in | vour | circuit | designs | ! |
|------------------------------------------|------|--------|-------|----|------|---------|---------|---|
|------------------------------------------|------|--------|-------|----|------|---------|---------|---|

• Mitsubishi Electric Corporation puts the maximum effort into making semiconductor products better and more reliable, but there is always the possibility that trouble may occur with them. Trouble with semiconductors may lead to personal injury, fire or property damage. Remember to give due consideration to safety when making your circuit designs, with appropriate measures such as (i) placement of substitutive, auxiliary circuits, (ii) use of non-flammable material or (iii) prevention against any malfunction or mishap.

| Not | es | regar | ding | these | mat | eria | IS |
|-----|----|-------|------|-------|-----|------|----|
|-----|----|-------|------|-------|-----|------|----|

- These materials are intended as a reference to assist our customers in the selection of the Mitsubishi semiconductor product best suited to the customer's application; they do not convey any license under any intellectual property rights, or any other rights, belonging to Mitsubishi Electric Corporation or a third party.
- Mitsubishi Electric Corporation assumes no responsibility for any damage, or infringement of any third-party's rights, originating in the use of any product data, diagrams, charts or circuit application examples contained in these materials.
- All information contained in these materials, including product data, diagrams and charts, represent information on products at the time of publication of these materials, and are subject to change by Mitsubishi Electric Corporation without notice due to product improvements or other reasons. It is therefore recommended that customers contact Mitsubishi Electric Corporation or an authorized Mitsubishi Semiconductor product distributor for the latest product information before purchasing a product listed herein.
- Mitsubishi Electric Corporation semiconductors are not designed or manufactured for use in a device or system that is used under circumstances in which human life is potentially at stake. Please contact Mitsubishi Electric Corporation or an authorized Mitsubishi Semiconductor product distributor when considering the use of a product contained herein for any specific purposes, such as apparatus or systems for transportation, vehicular, medical, aerospace, nuclear, or undersea repeater use.
- The prior written approval of Mitsubishi Electric Corporation is necessary to reprint or reproduce in whole or in part these materials.
- If these products or technologies are subject to the Japanese export control restrictions, they must be exported under a license from the Japanese government and cannot be imported into a country other than the approved destination. Any diversion or reexport contrary to the export control laws and regulations of JAPAN and/or the country of destination is prohibited.
- Please contact Mitsubishi Electric Corporation or an authorized Mitsubishi Semiconductor product distributor for further details on these materials or the products contained therein.

## **Preface**

This user's manual describes Mitsubishi's CMOS 8-bit microcomputers 3807 Group.

After reading this manual, the user should have a through knowledge of the functions and features of the 3807 Group, and should be able to fully utilize the product. The manual starts with specifications and ends with application examples.

For details of software, refer to the "SERIES MELPS 740 <SOFTWARE> USER'S MANUAL."

For details of development support tools, refer to the "DEVELOPMENT SUPPORT TOOLS FOR MICRO-COMPUTERS" data book.

#### **BEFORE USING THIS USER'S MANUAL**

This user's manual consists of the following three chapters. Refer to the chapter appropriate to your conditions, such as hardware design or software development. Chapter 3 also includes necessary information for systems denelopment. Be sure to refer to this chapter.

#### 1. Organization

#### CHAPTER 1 HARDWARE

This chapter describes features of the microcomputer and operation of each peripheral function.

#### CHAPTER 2 APPLICATION

This chapter describes usage and application examples of peripheral functions, based mainly on setting examples of related registers.

#### CHAPTER 3 APPENDIX

This chapter includes necessary information for systems development using the microcomputer, electric characteristics, a list of registers, the masking confirmation (mask ROM version), and mark specifications which are to be submitted when ordering.

#### 2. Structure of register

The figure of each register structure describes its functions, contents at reset, and attributes as follows:



## LIST OF GROUPS HAVING THE SIMILAR FUNCTIONS

3807 group, one of the CMOS 8-bit microcomputer 38000 series presented in this user's manual is provided with standard functions.

The basic functions of the 3800, 3802, 3806 and 3807 groups having the same functions are shown below. For the detailed functions of each group, refer to the related data book and user's manual.

## List of groups having the same functions

As of September 1996

| Group<br>Function |                                             |                                  | 380                             | 0 gr  | oup                            |                                  | 3802 group     |                                               |                                  |                 | 3806 group      |                     |                                                                    |                 |                 | 3807 group                                                   |
|-------------------|---------------------------------------------|----------------------------------|---------------------------------|-------|--------------------------------|----------------------------------|----------------|-----------------------------------------------|----------------------------------|-----------------|-----------------|---------------------|--------------------------------------------------------------------|-----------------|-----------------|--------------------------------------------------------------|
| P<br>(Packaç      | 64 pin<br>• 64P4B<br>• 64P6N-A<br>• 64P6D-A |                                  |                                 |       | 64 pin<br>• 64P4B<br>• 64P6N-A |                                  |                | 80 pin<br>• 80P6N-A<br>• 80P6S-A<br>• 80P6D-A |                                  |                 |                 | 80 pin<br>• 80P6N-A |                                                                    |                 |                 |                                                              |
| Clock gener       | rating circuit                              |                                  | 1                               | circu | uit                            |                                  |                | 1 ci                                          | rcuit                            |                 |                 | 1                   | circu                                                              | uit             |                 | 2 circuits                                                   |
| Timer             |                                             |                                  | <8-bit> Prescaler : 3 Timer : 4 |       |                                | <8-bit> Prescaler : 3 Timer : 4  |                |                                               | <8-bit> Prescaler : 3 Timer : 4  |                 |                 |                     | <8-bit>     Timer : 3 <16-bit>     Timer X/Y : 2     Timer A/B : 2 |                 |                 |                                                              |
| Serial I/O        |                                             | UART or<br>Clock synchronous X 1 |                                 |       |                                | UART or<br>Clock synchronous X 1 |                |                                               | UART or<br>Clock synchronous X 1 |                 |                 | nous                | UART or<br>Clock synchronous X 1                                   |                 |                 |                                                              |
|                   |                                             | _                                |                                 |       |                                | Clock synchronous X 1            |                |                                               | Clock synchronous X 1            |                 |                 | nous                | Clock synchronous X 1                                              |                 |                 |                                                              |
| A-D converter     |                                             | _                                |                                 |       | 8-bit X 8-channel              |                                  |                | 8-bit X 8-channel                             |                                  |                 |                 | el                  | 8-bit X 13-channel                                                 |                 |                 |                                                              |
| D-A co            | nverter                                     | _                                |                                 |       |                                | 8-bit X 2-channel                |                |                                               | 8-bit X 2-channel                |                 |                 |                     | 8-bit X 4-channel                                                  |                 |                 |                                                              |
|                   | Mask<br>ROM                                 | 8K<br>(Note 1)                   | 16K<br>(Note 1)                 | 24K   | 32K<br>(Note 1)                | *                                | 8K<br>(Note 1) | 16K<br>(Note 1)                               | 24K                              | 32K<br>(Note 1) | 12K<br>(Note 1) | 16K<br>(Note 1)     | 24K<br>(Note 3)                                                    | 32K<br>(Note 3) | 48K<br>(Note 3) | 16K                                                          |
| Memory            | One Time<br>PROM                            | 8K                               | 16K                             | _     | 32K                            |                                  | _              | <del></del>                                   |                                  | 32K<br>(Note 1) | _               |                     | 24K<br>(Note 2)                                                    | <u> </u>        | 48K<br>(Note 3) | 16K                                                          |
| type              | EPROM                                       | _                                | 16K                             | _     | 32<br>K                        | _                                | _              | _                                             | _                                | 32K             | _               |                     | 24<br>K                                                            | _               | 48K<br>(Note 2) | 16K                                                          |
|                   | RAM                                         | 384                              | 384                             | 512   | 640                            | 384                              | 384            | 384                                           | 64<br>0                          | 1024            | 384             | 384                 | 512                                                                | 1024            | 1024            | 512                                                          |
| Remarks           |                                             |                                  |                                 |       |                                |                                  | PWM            | output                                        | t                                |                 |                 |                     |                                                                    |                 |                 | Real time port output<br>Analog comparator<br>Watchdog timer |

Notes 1: Extended operating temperature version available

- 2: High-speed version available
- 3: Extended operating temperature version and High-speed version available
- \*. ROM expansion

## **Table of contents**

| CHAPTER 1. HARDWARE                      |       |
|------------------------------------------|-------|
| DESCRIPTION                              | 1-2   |
| FEATURES                                 | 1-2   |
| APPLICATION                              | 1-2   |
| PIN CONFIGURATION                        | 1-2   |
| FUNCTIONAL BLOCK                         | 1-3   |
| PIN DESCRIPTION                          | 1-4   |
| PART NUMBERING                           | 1-6   |
| GROUP EXPANSION                          | 1-7   |
| FUNCTIONAL DESCRIPTION                   | 1-8   |
| Central Processing Unit (CPU)            | 1-8   |
| Memory                                   | 1-12  |
| I/O Ports                                | 1-14  |
| Interrupts                               | 1-20  |
| Timers                                   | 1-23  |
| Serial I/O                               | 1-41  |
| A-D Converter                            | 1-47  |
| D-A Converter                            | 1-48  |
| Analog Comparator                        | 1-49  |
| Watchdog Timer                           | 1-50  |
| Clock output function                    | 1-51  |
| Reset Circuit                            | 1-52  |
| Clock Generating Circuit                 | 1-54  |
| Processor Mode                           | 1-57  |
| NOTES ON PROGRAMMING                     |       |
| Processor Status Register                |       |
| Interrupts                               |       |
| Decimal Calculations                     |       |
| Timers                                   |       |
| Multiplication and Division Instructions |       |
| Ports                                    |       |
| Serial I/O                               |       |
| A-D Converter                            |       |
| D-A Converter                            |       |
| Instruction Execution Time               | 1-59  |
| NOTES ON USAGE                           |       |
| Handling of Source Pins                  | 1-6() |

## Table of contents

|      | P34 clock output function                        | 1-60 |
|------|--------------------------------------------------|------|
|      | Timer X and timer Y                              | 1-60 |
|      | EPROM version/One Time PROM version              | 1-60 |
|      | DATA REQUIRED FOR MASK ORDERS                    | 1-61 |
|      | ROM PROGRAMMING METHOD                           | 1-61 |
|      | FUNCTIONAL DESCRIPTION SUPPLEMENT                | 1-62 |
|      | Interrupt                                        | 1-62 |
|      | Timing After Interrupt                           | 1-63 |
|      | A-D Converter                                    | 1-64 |
| CHAI | PTER 2. APPLICATION                              |      |
|      | 2.1 I/O port                                     | 2-2  |
|      | 2.1.1 Memory map of I/O port                     |      |
|      | 2.1.2 Related registers                          |      |
|      | 2.1.3 Handling of unused pins                    |      |
|      | 2.2 Timer                                        | 2-6  |
|      | 2.2.1 Memory map of timer                        | 2-6  |
|      | 2.2.2 Related registers                          | 2-7  |
|      | 2.2.3 Timer application examples                 | 2-14 |
|      | 2.3 Serial I/O                                   |      |
|      | 2.3.1 Memory map of serial I/O                   |      |
|      | 2.3.2 Related registers                          |      |
|      | 2.3.3 Serial I/O connection examples             | 2-37 |
|      | 2.3.4 Setting of serial I/O transfer data format | 2-39 |
|      | 2.3.5 Serial I/O application examples            | 2-40 |
|      | 2.4 Real time output port                        |      |
|      | 2.4.1 Memory map of real time output port        |      |
|      | 2.4.2 Related registers                          |      |
|      | 2.4.3 Real time output port application examples | 2-67 |
|      | 2.5 A-D converter                                |      |
|      | 2.5.1 Memory map of A-D conversion               |      |
|      | 2.5.2 Related registers                          |      |
|      | 2.5.3 A-D conversion application example         | 2-83 |
|      | 2.6 Reset                                        |      |
|      | 2.6.1 Connection example of reset IC             | 2-87 |
|      | 2.7 Application circuit example                  | 2-88 |

## CHAPTER 3. APPENDIX

| 3.1 | Electrical characteristics                                                   |      |
|-----|------------------------------------------------------------------------------|------|
|     | 3.1.1 Absolute maximum ratings                                               |      |
|     | 3.1.2 Recommended operating conditions                                       |      |
|     | 3.1.3 Electrical characteristics                                             |      |
|     | 3.1.4 A-D converter characteristics                                          |      |
|     | 3.1.5 D-A converter characteristics                                          |      |
|     | 3.1.6 Analog comparator characteristics                                      |      |
|     | 3.1.7 Timing requirements                                                    |      |
|     | 3.1.8 Switching characteristics                                              |      |
|     | 3.1.9 Timing requirements in memory expansion and microprocessor mode        |      |
|     | 3.1.10 Switching characteristics in memory expansion and microprocessor mode | 3-10 |
| 3.2 | Standard characteristics                                                     | 3-17 |
|     | 3.2.1 Power source current characteristic examples                           |      |
|     | 3.2.2 Port standard characteristic examples                                  |      |
|     | 3.2.3 Input current standard characteristic examples                         |      |
|     | 3.2.4 A-D conversion standard characteristics                                |      |
|     | 3.2.5 D-A conversion standard characteristics                                |      |
|     |                                                                              |      |
| 3.3 | Notes on use                                                                 |      |
|     | 3.3.1 Notes on interrupts                                                    |      |
|     | 3.3.2 Notes on the serial I/O1                                               |      |
|     | 3.3.3 Notes on the A-D converter                                             |      |
|     | 3.3.4 Notes on the RESET pin                                                 |      |
|     | 3.3.5 Notes on input and output pins                                         |      |
|     | 3.3.6 Notes on memory expansion mode and microprocessor mode                 |      |
|     | 3.3.7 Notes on built-in PROM                                                 | 3-28 |
| 3.4 | Countermeasures against noise                                                | 3-29 |
|     | 3.4.1 Shortest wiring length                                                 |      |
|     | 3.4.2 Connection of a bypass capacitor across the Vss line and the Vcc line  | 3-30 |
|     | 3.4.3 Wiring to analog input pins                                            |      |
|     | 3.4.4 Consideration for oscillator                                           | 3-31 |
|     | 3.4.5 Setup for I/O ports                                                    | 3-32 |
|     | 3.4.6 Providing of watchdog timer function by software                       |      |
|     |                                                                              |      |
| 3.5 | List of registers                                                            | 3-34 |
| 3.6 | Mask ROM ordering method                                                     | 3-56 |
| 2 7 | Mark analisation form                                                        | 2 50 |
| 3.7 | Mark specification form                                                      | 3-38 |
| 3.8 | Package outline                                                              | 3-59 |
| 3.9 | Machine Instructions                                                         | 3-60 |
|     |                                                                              |      |
| 3.1 | 0 List of instruction codes                                                  | 3-70 |
| 3.1 | 1 SFR memory map                                                             | 3-71 |
| 3.1 | 2 Pin configuration                                                          | 3-72 |

i

# List of figures

### **CHAPTER 1 HARDWARE**

| Fig. | 1 Pin configuration of M38073M4-XXXFP                                                       | 1-2  |
|------|---------------------------------------------------------------------------------------------|------|
| Fig. | 2 Functional block diagram                                                                  | 1-3  |
| Fig. | 3 Part numbering                                                                            | 1-6  |
| Fig. | 4 Memory expansion plan                                                                     | 1-7  |
|      | 5 740 Family CPU register structure                                                         |      |
| Fig. | 6 Register push and pop at interrupt generation and subroutine call                         | 1-9  |
| Fig. | 7 Structure of CPU mode register                                                            | 1-11 |
|      | 8 Memory map diagram                                                                        |      |
| _    | 9 Memory map of special function register (SFR)                                             |      |
| _    | 10 Structure of Port P2P3 control register                                                  |      |
| _    | 11 Structure of Pull-up control register                                                    |      |
| _    | 12 Port block diagram (1)                                                                   |      |
| _    | 13 Port block diagram (2)                                                                   |      |
| _    | 14 Port block diagram (3)                                                                   |      |
|      | 15 Interrupt control                                                                        |      |
|      | 16 Structure of interrupt-related registers                                                 |      |
|      | 17 Block diagram of Timer X and Timer Y                                                     |      |
|      | 18 Structure of Timer X mode register, Timer Y mode register, and Timer XY control register |      |
|      | 19 Timing chart of Timer • Event counter mode                                               |      |
|      | 20 Timing chart of Pulse output mode                                                        |      |
|      | 21 Timing chart of Pulse period measurement mode                                            |      |
|      | 22 Timing chart of Pulse width measurement mode                                             |      |
| _    | 23 Timing chart of Programmable waveform generating mode                                    |      |
| _    | 24 Timing chart of Programmable one-shot generating mode                                    |      |
|      | 25 Timing chart of PWM mode                                                                 |      |
|      | 26 Structure of Timer 123 mode register                                                     |      |
| _    | 27 Block diagram of Timer                                                                   |      |
| _    | 28 Block diagram of Real time output port                                                   |      |
| _    | 29 Structure of Real time output port related register (1)                                  |      |
|      | 30 Structure of Real time output port related register (2)                                  |      |
|      | 31 8 repeated load mode operation                                                           |      |
|      | 32 6 repeated load mode operation                                                           |      |
| _    | 34 One-shot pulse generating mode operation                                                 |      |
| _    | 35 Block diagram of clock synchronous serial I/O1                                           |      |
|      | 36 Operation of clock synchronous serial I/O1 function                                      |      |
| _    | 37 Block diagram of UART serial I/O1                                                        |      |
|      | 38 Operation of UART serial I/O1 function                                                   |      |
|      | 39 Structure of Serial I/O1 related register                                                |      |
| _    | 40 Structure of Serial I/O2 control register 1, 2                                           |      |
|      | 41 Block diagram of Serial I/O2                                                             |      |
|      | 42 Timing of Serial I/O2                                                                    |      |
| _    | 43 Scmp2 output operation                                                                   |      |
| _    | 44 Structure of A-D control register                                                        |      |
| _    | 45 Block diagram of A-D converter                                                           |      |

## List of figures

|        | Fig. 46 Structure of D-A control register                                                             | 1-48   |
|--------|-------------------------------------------------------------------------------------------------------|--------|
|        | Fig. 47 Block diagram of D-A converter                                                                | 1-48   |
|        | Fig. 48 Equivalent connection circuit of D-A converter                                                | . 1-48 |
|        | Fig. 49 Block diagram of Analog comparator                                                            | 1-49   |
|        | Fig. 50 Block diagram of Watchdog timer                                                               | 1-50   |
|        | Fig. 51 Structure of Watchdog timer control register                                                  | . 1-50 |
|        | Fig. 52 Structure of Port P2P3 control register                                                       | . 1-51 |
|        | Fig. 53 Block diagram of Clock output function                                                        | . 1-51 |
|        | Fig. 54 Reset circuit example                                                                         | .1-52  |
|        | Fig. 55 Reset sequence                                                                                | . 1-52 |
|        | Fig. 56 Internal status at reset                                                                      | . 1-53 |
|        | Fig. 57 Ceramic resonator circuit                                                                     | . 1-54 |
|        | Fig. 58 External clock input circuit                                                                  | 1-54   |
|        | Fig. 59 System clock generating circuit block diagram (Single-chip mode)                              | . 1-55 |
|        | Fig. 60 State transitions of system clock                                                             | . 1-56 |
|        | Fig. 61 Memory maps in various processor modes                                                        | . 1-57 |
|        | Fig. 62 Structure of CPU mode register                                                                | 1-57   |
|        | Fig. 63 ONW function timing                                                                           | . 1-58 |
|        | Fig. 64 Programming and testing of One Time PROM version                                              |        |
|        | Fig. 65 Timing chart after an interrupt occurs                                                        |        |
|        | Fig. 66 Time up to execution of the interrupt processing routine                                      | . 1-63 |
|        | Fig. 67 A-D conversion equivalent circuit                                                             | 1-65   |
|        | Fig. 68 A-D conversion timing chart                                                                   | . 1-65 |
|        |                                                                                                       |        |
| CHAPTE | R 2 APPLICATION                                                                                       |        |
|        | Fig. 2.1.1 Memory map of I/O port related registers                                                   | 2.2    |
|        |                                                                                                       |        |
|        | Fig. 2.1.2 Structure of Port Pi (i=0, 1, 2, 3, 4, 5, 7, 8)                                            |        |
|        | · · · · · · · · · · · · · · · · · · ·                                                                 |        |
|        | Fig. 2.1.4 Structure of Port P6Fig. 2.1.5 Structure of Port P6 direction register                     |        |
|        | rig. 2.1.5 Structure of Port Po direction register                                                    | 2-4    |
|        | Fig. 2.2.1 Memory map of timer related registers                                                      | 2-6    |
|        | Fig. 2.2.2 Structure of Timer XY control register                                                     | 2-7    |
|        | Fig. 2.2.3 Structure of Timer X Low-order, Timer X High-order, Timer Y Low-order, Timer Y High-order. | 2-7    |
|        | Fig. 2.2.4 Structure of Timer 1, Timer 3                                                              | 2-8    |
|        | Fig. 2.2.5 Structure of Timer 2                                                                       | 2-8    |
|        | Fig. 2.2.6 Structure of Timer X mode register                                                         | 2-9    |
|        | Fig. 2.2.7 Structure of Timer Y mode register                                                         | 2-9    |
|        | Fig. 2.2.8 Structure of Timer 123 mode register                                                       |        |
|        | Fig. 2.2.9 Structure of Interrupt edge selection register                                             | . 2-11 |
|        | Fig. 2.2.10 Structure of Interrupt request register 1                                                 | . 2-12 |
|        | Fig. 2.2.11 Structure of Interrupt request register 2                                                 | . 2-12 |
|        | Fig. 2.2.12 Structure of Interrupt control register 1                                                 |        |
|        | Fig. 2.2.13 Structure of Interrupt control register 2                                                 |        |
|        | Fig. 2.2.14 Connection of timers and setting of division ratios [Clock function]                      |        |
|        | Fig. 2.2.15 Setting of related registers [Clock function]                                             |        |
|        | Fig. 2.2.16 Control procedure [Clock function]                                                        |        |
|        |                                                                                                       |        |
|        | Fig. 2.2.17 Example of a peripheral circuit                                                           | 2-18   |
|        | Fig. 2.2.17 Example of a peripheral circuit                                                           |        |

| Fig.  | 2.2.19 Setting of related registers [Piezoelectric buzzer output]                             | 2-19   |
|-------|-----------------------------------------------------------------------------------------------|--------|
| Fig.  | 2.2.20 Control procedure [Piezoelectric buzzer output]                                        | 2-20   |
| Fig.  | 2.2.21 A method for judging if input pulse exists                                             | 2-21   |
|       | 2.2.22 Setting of related registers (1) [Measurement of frequency]                            |        |
|       | 2.2.23 Setting of related registers (2) [Measurement of frequency]                            |        |
|       | 2.2.24 Control procedure [Measurement of frequency]                                           |        |
| _     | 2.2.25 Connection of the timer and setting of the division ratio [Measurement of pulse width] |        |
| _     | 2.2.26 Setting of related registers [Measurement of pulse width]                              |        |
| _     | 2.2.27 Control procedure (1) [Measurement of pulse width]                                     |        |
| _     | 2.2.28 Control procedure (2) [Measurement of pulse width]                                     |        |
|       |                                                                                               |        |
| _     | 2.3.1 Memory map of serial I/O related registers                                              |        |
| _     | 2.3.2 Structure of Transmit/Receive buffer register                                           |        |
| Fig.  | 2.3.3 Structure of Serial I/O1 status register                                                | 2-30   |
|       | 2.3.4 Structure of Serial I/O1 control register                                               |        |
| Fig.  | 2.3.5 Structure of UART control register                                                      | .2-31  |
| Fig.  | 2.3.6 Structure of Baud rate generator                                                        | .2-32  |
| Fig.  | 2.3.7 Structure of Serial I/O2 control register 1                                             | 2-32   |
| Fig.  | 2.3.8 Structure of Serial I/O2 control register 2                                             | 2-33   |
| Fig.  | 2.3.9 Structure of Serial I/O2 register                                                       | .2-33  |
| Fig.  | 2.3.10 Structure of Interrupt edge selection register                                         | 2-34   |
|       | 2.3.11 Structure of Interrupt request register 1                                              |        |
| _     | 2.3.12 Structure of Interrupt request register 2                                              |        |
| _     | 2.3.13 Structure of Interrupt control register 1                                              |        |
| _     | 2.3.14 Structure of Interrupt control register 2                                              |        |
| _     | 2.3.15 Serial I/O connection examples (1)                                                     |        |
| _     | 2.3.16 Serial I/O connection examples (2)                                                     |        |
| _     | 2.3.17 Setting of Serial I/O transfer data format                                             |        |
|       | 2.3.18 Connection diagram [Communication using a clock synchronous serial I/O]                |        |
|       | 2.3.19 Timing chart [Communication using a clock synchronous serial I/O]                      |        |
| _     | 2.3.20 Setting of related registers at a transmitting side                                    | 0      |
| · ·g· | [Communication using a clock synchronous serial I/O]                                          | 2-41   |
| Fig   | 2.3.21 Setting of related registers at a receiving side                                       | 2 71   |
| ı ıg. | [Communication using a clock synchronous serial I/O]                                          | 2-42   |
| Eia   | 2.3.22 Control procedure at a transmitting side                                               |        |
| rig.  | [Communication using a clock synchronous serial I/O]                                          |        |
| ⊏i~   |                                                                                               | 2-43   |
| rig.  | 2.3.23 Control procedure at a receiving side                                                  | 2 44   |
|       | [Communication using a clock synchronous serial I/O]                                          |        |
| _     | 2.3.24 Connection diagram [Output of serial data]                                             |        |
| _     | 2.3.25 Timing chart [Output of serial data]                                                   |        |
|       | 2.3.26 Setting of serial I/O1 related registers [Output of serial data]                       |        |
| _     | 2.3.27 Setting of serial I/O1 transmission data [Output of serial data]                       |        |
| _     | 2.3.28 Control procedure of serial I/O1 [Output of serial data]                               |        |
| _     | 2.3.29 Setting of serial I/O2 related registers [Output of serial data]                       |        |
|       | 2.3.30 Setting of serial I/O2 transmission data [Output of serial data]                       |        |
| _     | 2.3.31 Control procedure of serial I/O2 [Output of serial data]                               | 2-51   |
| Fig.  | 2.3.32 Connection diagram                                                                     |        |
|       | [Cyclic transmission or reception of block data between microcomputers]                       | . 2-52 |
| Fig.  | 2.3.33 Timing chart                                                                           |        |
|       | [Cyclic transmission or recention of block data between microcomputers]                       | 2-53   |

| Fig. | 2.3.34 Setting of related registers                                                              |        |
|------|--------------------------------------------------------------------------------------------------|--------|
| Ū    | [Cyclic transmission or reception of block data between microcomputers].                         | . 2-53 |
| Fig. | 2.3.35 Control in the master unit                                                                | .2-54  |
| Fig. | 2.3.36 Control in the slave unit                                                                 | . 2-55 |
| Fig. | 2.3.37 Connection diagram [Communication using UART]                                             | 2-56   |
| Fig. | 2.3.38 Timing chart [Communication using UART]                                                   | 2-56   |
| Fig. | 2.3.39 Setting of related registers at a transmitting side [Communication using UART]            | . 2-58 |
| Fig. | 2.3.40 Setting of related registers at a receiving side [Communication using UART]               | . 2-59 |
| _    | 2.3.41 Control procedure at a transmitting side [Communication using UART]                       |        |
| Fig. | 2.3.42 Control procedure at a receiving side [Communication using UART]                          | . 2-61 |
| _    | 2.4.1 Memory map of real time output port related registers                                      |        |
| _    | 2.4.2 Structure of Real time port register                                                       |        |
| _    | 2.4.3 Structure of Real time port control register 0                                             |        |
| _    | 2.4.4 Structure of Real time port control register 1                                             |        |
| _    | 2.4.5 Structure of Real time port control register 2                                             |        |
| _    | 2.4.6 Structure of Real time port control register 3                                             |        |
| Fig. | 2.4.7 Structure of Timer A Low-order, Timer A High-order, Timer B Low-order, Timer B High-order. | . 2-66 |
| Fig. | 2.4.8 Connection diagram                                                                         | . 2-67 |
| Fig. | 2.4.9 Operation patterns of motor                                                                | .2-67  |
|      | 2.4.10 Example of timer table for acceleration and deceleration                                  |        |
| Fig. | 2.4.11 Example of operation pattern table                                                        | 2-69   |
| _    | 2.4.12 Example of output data table                                                              |        |
| _    | 2.4.13 Timing of Real time output                                                                |        |
| Fig. | 2.4.14 Setting method and output timing                                                          | .2-71  |
| Fig. | 2.4.15 Setting of related registers (1)                                                          | .2-72  |
| _    | 2.4.16 Setting of related registers (2)                                                          |        |
| _    | 2.4.17 Setting of related registers (3)                                                          |        |
| _    | 2.4.18 Setting of related registers (4)                                                          |        |
| _    | 2.4.19 Control procedure (1)                                                                     |        |
| _    | 2.4.20 Control procedure (2)                                                                     |        |
| _    | 2.4.21 Control procedure (3)                                                                     |        |
| Fig. | 2.4.22 Control procedure (4)                                                                     | . 2-79 |
| _    | 2.5.1 Memory map of A-D conversion related registers                                             |        |
| _    | 2.5.2 Structure of A-D control register                                                          |        |
| _    | 2.5.3 Structure of A-D conversion register                                                       |        |
| _    | 2.5.4 Structure of Interrupt request register 2                                                  |        |
|      | 2.5.5 Structure of Interrupt control register 2                                                  |        |
|      | 2.5.6 Connection diagram [Read for analog signal using an internal trigger]                      |        |
| _    | 2.5.7 Setting of related registers [Read for analog signal using an internal trigger]            |        |
| _    | 2.5.8 Control procedure [Read for analog signal using an internal trigger]                       |        |
| _    | 2.5.9 Connection diagram [Read for analog signal using an external trigger]                      |        |
| _    | 2.5.10 Setting of related registers [Read for analog signal using an external trigger]           |        |
| Fig. | 2.5.11 Control procedure [Read for analog signal using an external trigger]                      | . 2-86 |
|      | 2.6.1 Example of Poweron reset circuit                                                           |        |
| Fig. | 2.6.2 RAM back-up system                                                                         | . 2-87 |
| _    | 2.7.1 Hot water supply system application example                                                |        |
| _    | 2.7.2 CD changer (car audio) application example                                                 |        |
| Fia. | 2.7.3 Hot water washing toilet seat application example                                          | . 2-91 |

## **CHAPTER 3 APPENDIX** ■

| Fia.  | 3.1.1 Circuit for measuring output switching characteristics (1)                                 | . 3-11 |
|-------|--------------------------------------------------------------------------------------------------|--------|
| _     | 3.1.2 Circuit for measuring output switching characteristics (2)                                 |        |
|       | 3.1.3 Timing diagram (1) (in single-chip mode)                                                   |        |
| _     | 3.1.4 Timing diagram (2) (in memory expansion mode and microprocessor mode).                     |        |
| _     | 3.1.5 Timing diagram (3) (in memory expansion mode and microprocessor mode).                     |        |
| _     | 3.1.6 Timing diagram (4) (in memory expansion mode and microprocessor mode).                     |        |
| _     | 3.1.7 Timing diagram (5) (in memory expansion mode and microprocessor mode).                     |        |
| · ·g· | o                                                                                                |        |
| Fia   | 3.2.1 Power source current characteristic example                                                | 3-17   |
|       | 3.2.2 Power source current characteristic example (in wait mode)                                 |        |
| _     | 3.2.3 Standard characteristic example of CMOS output port at P-channel drive(1).                 |        |
| _     | 3.2.4 Standard characteristic example of CMOS output port at P-channel drive(2).                 |        |
| _     | 3.2.5 Standard characteristic example of CMOS output port at N-channel drive(1).                 |        |
| _     | 3.2.6 Standard characteristic example of CMOS output port at N-channel drive(2).                 |        |
| _     | 3.2.7 Standard characteristic example of CMOS output port at N-channel drive(3).                 |        |
| _     | 3.2.8 Standard characteristic example of CMOS output port at N-channel drive(4).                 |        |
| _     | 3.2.9 Standard characteristic example of input current at connecting pull-up transistor (1)      |        |
| _     | 3.2.10 Standard characteristic example of input current at connecting pull-up transistor (2)     |        |
| _     | 3.2.11 A-D conversion standard characteristics                                                   |        |
| _     | 3.2.12 D-A conversion standard characteristics                                                   |        |
| 9.    |                                                                                                  | . 0 20 |
| Fig.  | 3.3.1 Structure of interrupt control register 2                                                  | . 3-24 |
| Ū     |                                                                                                  |        |
| Fig.  | 3.4.1 Wiring for the RESET pin                                                                   | 3-29   |
| _     | 3.4.2 Wiring for clock I/O pins                                                                  |        |
| Fig.  | 3.4.3 Wiring for the VPP pin of the One Time PROM and the EPROM version                          | . 3-30 |
| Fig.  | 3.4.4 Bypass capacitor across the Vss line and the Vcc line                                      | . 3-30 |
|       | 3.4.5 Analog signal line and a resistor and a capacitor                                          |        |
|       | 3.4.6 Wiring for a large current signal line                                                     |        |
| Fig.  | 3.4.7 Wiring to a signal line where potential levels change frequently                           | . 3-31 |
| Fig.  | 3.4.8 Setup for I/O ports                                                                        | . 3-32 |
| Fig.  | 3.4.9 Watchdog timer by software                                                                 | 3-32   |
|       |                                                                                                  |        |
| Fig.  | 3.5.1 Structure of Port Pi (i=0, 1, 2, 3, 4, 5, 7, 8)                                            | . 3-34 |
|       | 3.5.2 Structure of Port Pi direction register (i=0, 1, 2, 3, 4, 5, 7, 8)                         |        |
| _     | 3.5.3 Structure of Port P6                                                                       |        |
| -     | 3.5.4 Structure of Port P6 direction register                                                    |        |
| _     | 3.5.5 Structure of Timer XY control register                                                     |        |
| _     | 3.5.6 Structure of Port P2P3 control register                                                    |        |
| _     | 3.5.7 Structure of Pull-up control register                                                      |        |
| _     | 3.5.8 Structure of Watchdog timer control register                                               |        |
| _     | 3.5.9 Structure of Transmit/Receive buffer register                                              |        |
| _     | 3.5.10 Structure of Serial I/O1 status register                                                  |        |
| _     | 3.5.11 Structure of Serial I/O1 control register                                                 |        |
| _     | 3.5.12 Structure of UART control register                                                        |        |
| _     | 3.5.13 Structure of Baud rate generator                                                          |        |
| _     | 3.5.14 Structure of Serial I/O2 control register 1                                               |        |
| _     | 3.5.15 Structure of Serial I/O2 control register 2                                               |        |
|       | 3.5.16 Structure of Serial I/O2 register                                                         |        |
| Fin   | 3.5.17 Structure of Timer X Low-order, Timer X High-order, Timer V Low-order, Timer V High-order | r 3-42 |

## List of figures

| Fig. | 3.5.18 | Structure of Timer 1, Timer 3                                                             | 3-42 |
|------|--------|-------------------------------------------------------------------------------------------|------|
| Fig. | 3.5.19 | Structure of Timer 2                                                                      | 3-43 |
| Fig. | 3.5.20 | Structure of Timer X mode register                                                        | 3-44 |
| Fig. | 3.5.21 | Structure of Timer Y mode register                                                        | 3-44 |
| Fig. | 3.5.22 | Structure of Timer 123 mode register                                                      | 3-46 |
| Fig. | 3.5.23 | Structure of Real time port register                                                      | 3-46 |
| Fig. | 3.5.24 | Structure of Real time port control register 0                                            | 3-47 |
| Fig. | 3.5.25 | Structure of Real time port control register 1                                            | 3-48 |
| Fig. | 3.5.26 | Structure of Real time port control register 2                                            | 3-49 |
| Fig. | 3.5.27 | Structure of Real time port control register 3                                            | 3-50 |
| Fig. | 3.5.28 | Structure of Timer A Low-order, Timer A High-order, Timer B Low-order, Timer B High-order | 3-50 |
| Fig. | 3.5.29 | Structure of D-A control register                                                         | 3-51 |
| Fig. | 3.5.30 | Structure of A-D control register                                                         | 3-51 |
| Fig. | 3.5.31 | Structure of A-D conversion register                                                      | 3-52 |
| Fig. | 3.5.32 | Structure of D-Ai conversion register (i = 1,2,3,4)                                       | 3-52 |
| Fig. | 3.5.33 | Structure of Interrupt edge selection register                                            | 3-53 |
| Fig. | 3.5.34 | Structure of CPU mode register                                                            | 3-53 |
| Fig. | 3.5.35 | Structure of Interrupt request register 1                                                 | 3-54 |
| Fig. | 3.5.35 | Structure of Interrupt request register 2                                                 | 3-54 |
| Fig. | 3.5.36 | Structure of Interrupt control register 1                                                 | 3-55 |
| Fig. | 3.5.36 | Structure of Interrupt control register 2                                                 | 3-55 |

i

## List of tables

| CHAP | TER T HARDWARE                                                                          |      |
|------|-----------------------------------------------------------------------------------------|------|
|      | Table 1 Pin description (1)                                                             | 1-4  |
|      | Table 2 Pin description (2)                                                             |      |
|      | Table 3 List of supported products                                                      |      |
|      | Table 4 Push and pop instructions of accumulator or processor status register           |      |
|      | Table 5 Set and clear instructions of each bit of processor status register             |      |
|      | Table 6 List of I/O port functions (1)                                                  |      |
|      | Table 7 List of I/O port functions (2)                                                  |      |
|      | Table 8 Interrupt vector addresses and priority                                         | 1-21 |
|      | Table 9 Port functions in memory expansion mode and microprocessor mode                 | 1-57 |
|      | Table 10 Special programming adapter                                                    |      |
|      | Table 11 Interrupt sources, vector addresses and interrupt priority                     |      |
|      | Table 12 Change of A-D conversion register during A-D conversion                        | 1-64 |
| СНАР | TER 2 APPLICATION                                                                       |      |
|      |                                                                                         |      |
|      | Table 2.1.1 Handling of unused pins (in single-chip mode)                               |      |
|      | Table 2.1.2 Handling of unused pins (in memory expansion mode and microprocessor mode)  | 2-5  |
|      | Table 2.2.1 Function of CNTR <sub>0</sub> /CNTR <sub>1</sub> edge switch bit            | 2-10 |
|      | Table 2.3.1 Setting examples of Baud rate generator values and transfer bit rate values | 2-57 |
| СНАР | TER 3 APPENDIX                                                                          |      |
|      | Table 3.1.1 Absolute maximum ratings                                                    | 3-2  |
|      | Table 3.1.2 Recommended operating conditions (1)                                        |      |
|      | Table 3.1.3 Recommended operating conditions (2)                                        |      |
|      | Table 3.1.4 Recommended operating conditions (3)                                        |      |
|      | Table 3.1.5 Electrical characteristics (1)                                              |      |
|      | Table 3.1.6 Electrical characteristics (2)                                              |      |
|      | Table 3.1.7 A-D converter characteristics                                               |      |
|      | Table 3.1.8 D-A converter characteristics                                               | 3-7  |
|      | Table 3.1.9 Analog comparator characteristics                                           | 3-7  |
|      | Table 3.1.10 Timing requirements (1)                                                    | 3-8  |
|      | Table 3.1.11 Timing requirements (2)                                                    | 3-8  |
|      | Table 3.1.12 Switching characteristics (1)                                              | 3-9  |
|      | Table 3.1.13 Switching characteristics (2)                                              |      |
|      | Table 3.1.14 Timing requirements in memory expansion mode and microprocessor mode       | 3-10 |
|      | Table 3.1.15 Switching characteristics in memory expansion mode and microprocessor mode |      |
|      | Table 3.3.1 Programming adapter                                                         | 3-28 |
|      | Table 3.3.2 Setting of programming adapter switch                                       |      |
|      | Table 3.3.3 Setting of PROM programmer address                                          | 3-28 |
|      | Table 3.5.1 Function of CNTR0/CNTR1 edge switch bit                                     | 3-45 |



DESCRIPTION
FEATURES
APPLICATIONS
PIN CONFIGURATION
FUNCTIONAL BLOCK
PIN DESCRIPTION
PART NUMBERING
GROUP EXPANSION
FUNCTIONAL DESCRIPTION
NOTES ON PROGRAMMING
DATA REQUIRED FOR MASK
ORDERS
ROM PROGRAMMING METHOD
FUNCTIONAL DESCRIPTION
SUPPLEMENT

#### DESCRIPTION/FEATURES/APPLICATIONS/PIN CONFIGURATION

#### **DESCRIPTION**

The 3807 group is a 8-bit microcomputer based on the 740 family core technology.

The 3807 group has two serial I/Os, an A-D converter, a D-A converter, a real time output port function, a watchdog timer, and an analog comparator, which are available for a system controller which controls motors of office equipment and household appliances.

The various microcomputers in the 3807 group include variations of internal memory size and packaging. For details, refer to the section on part numbering.

For details on availability of microcomputers in the 3807 group, refer to the section on group expansion.

#### **FEATURES**

| . 2/1101120                                                   |
|---------------------------------------------------------------|
| Basic machine-language instructions                           |
| $ullet$ The minimum instruction execution time 0.5 $\mu s$    |
| (at 8 MHz oscillation frequency)                              |
| Memory size                                                   |
| ROM8 to 60 K bytes                                            |
| RAM                                                           |
| • Programmable input/output ports                             |
| • Software pull-up resistors (Ports P0 to P2)                 |
| • Input ports (Ports P63 and P64)2                            |
| • Interrupts                                                  |
| • Timers X, Y                                                 |
| • Timers A, B (for real time output port function) 16-bit X 2 |
| • Timers 1–3                                                  |
|                                                               |

| <ul> <li>Serial I/O2 (Clock-synchronized)</li></ul>                                                                                                                     | • Serial I/O1 (UART or Clock-synchronized) 8-bit X 1                 |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------|
| <ul> <li>A-D converter</li></ul>                                                                                                                                        |                                                                      |
| <ul> <li>Watchdog timer</li></ul>                                                                                                                                       | • A-D converter 8-bit X 13 channels                                  |
| <ul> <li>Analog comparator</li></ul>                                                                                                                                    | D-A converter 8-bit X 4 channels                                     |
| <ul> <li>2 Clock generating circuit         Main clock (XIN-XOUT)</li></ul>                                                                                             | Watchdog timer                                                       |
| Main clock (XIN—XOUT)                                                                                                                                                   | Analog comparator 1 channel                                          |
| Sub-clock (XCIN—XCOUT) Without internal feedback resistor (connect to external ceramic resonator or quartz-crystal oscillator)  Power source voltage In high-speed mode | 2 Clock generating circuit                                           |
| (connect to external ceramic resonator or quartz-crystal oscillator)  Power source voltage In high-speed mode                                                           | Main clock (XIN-XOUT) Internal feedback resistor                     |
| Power source voltage In high-speed mode                                                                                                                                 | Sub-clock (XCIN-XCOUT) Without internal feedback resistor            |
| In high-speed mode                                                                                                                                                      | (connect to external ceramic resonator or quartz-crystal oscillator) |
| (at 8 MHz oscillation frequency and high-speed selected) In middle-speed mode                                                                                           | Power source voltage                                                 |
| In middle-speed mode                                                                                                                                                    | In high-speed mode                                                   |
| (at 8 MHz oscillation frequency and middle-speed selected) In low-speed mode                                                                                            | (at 8 MHz oscillation frequency and high-speed selected)             |
| In low-speed mode                                                                                                                                                       | In middle-speed mode                                                 |
| <ul><li>(at 32 kHz oscillation frequency and low-speed selected)</li><li>Power dissipation</li></ul>                                                                    | (at 8 MHz oscillation frequency and middle-speed selected)           |
| Power dissipation                                                                                                                                                       | In low-speed mode                                                    |
| ·                                                                                                                                                                       | (at 32 kHz oscillation frequency and low-speed selected)             |
| In high-speed mode                                                                                                                                                      | Power dissipation                                                    |
| ÷ .                                                                                                                                                                     | In high-speed mode                                                   |
| (at 8 MHz oscillation frequency, at 5 V power source voltage)                                                                                                           | (at 8 MHz oscillation frequency, at 5 V power source voltage)        |
|                                                                                                                                                                         |                                                                      |

#### **APPLICATION**

LBP engine control, PPC, FAX, office equipment, household appliances, consumer electronics, etc.

In low-speed mode ...... 60  $\mu W$ 

Memory expansion ...... possible

Operating temperature range ......–20 to 85 °C

(at 32 kHz oscillation frequency, at 3 V power source voltage)



Fig. 1. Pin configuration of M38073M4-XXXFP

#### **FUNCTIONAL BLOCK**



Fig. 2. Functional block diagram

## **PIN DESCRIPTION**

#### **PIN DESCRIPTION**

Table. 1. Pin description (1)

| Pin                     | Name                           | Function                                                                                          | Function except a port function                                    |  |  |  |  |
|-------------------------|--------------------------------|---------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|--|--|--|--|
| Vcc, Vss                | Power source                   | Apply voltage of 2.7–5.5 V to Vcc, and 0 V to Vss.                                                | •                                                                  |  |  |  |  |
| CMPVcc                  | Analog comparator power source | Power source input pin for an analog comparator                                                   |                                                                    |  |  |  |  |
| CNVss                   | CNVss                          | This pin controls the operation mode of the chip.                                                 |                                                                    |  |  |  |  |
|                         |                                | Normally connected to Vss.                                                                        |                                                                    |  |  |  |  |
|                         |                                | • If this pin is connected to Vcc, the internal ROM is inhibited and external men                 | mory is accessed.                                                  |  |  |  |  |
| ADVREF                  | Analog reference               | Reference voltage input pin for A-D converter.                                                    |                                                                    |  |  |  |  |
|                         | voltage                        |                                                                                                   |                                                                    |  |  |  |  |
| AVss                    | Analog power                   | Analog power source input pin for A-D and D-A converter and an analog con                         | nparator                                                           |  |  |  |  |
|                         | source                         | Connect to Vss.                                                                                   |                                                                    |  |  |  |  |
| СМРоит                  | Analog comparator              | Output pin for an analog comparator                                                               |                                                                    |  |  |  |  |
|                         | output                         |                                                                                                   |                                                                    |  |  |  |  |
| RESET                   | Reset input                    | Reset input pin for active "L"                                                                    |                                                                    |  |  |  |  |
| XIN                     | Clock input                    | Input and output signals for the internal clock generating circuit.                               |                                                                    |  |  |  |  |
|                         |                                | • Connect a ceramic resonator or quartz-crystal oscillator between the XIN and XOUT pins to set   | the oscillation frequency.                                         |  |  |  |  |
| Xout                    | Clock output                   | • If an external clock is used, connect the clock source to the XIN pin and leave                 | e the Xout pin open.                                               |  |  |  |  |
|                         |                                | The clock is used as the oscillating source of system clock.                                      |                                                                    |  |  |  |  |
| P00-P07                 | I/O port P0                    | • 8-bit CMOS I/O port                                                                             |                                                                    |  |  |  |  |
| P10-P17                 | I/O port P1                    | I/O direction register allows each pin to be individually programmed as either                    | input or output.                                                   |  |  |  |  |
| P20-P27                 | I/O port P2                    | At reset this port is set to input mode.                                                          |                                                                    |  |  |  |  |
|                         |                                | • In modes other than single-chip, these pins are used as address, data bus I/                    | O pins.                                                            |  |  |  |  |
|                         |                                | CMOS compatible input level                                                                       |                                                                    |  |  |  |  |
|                         |                                | CMOS 3-state output structure                                                                     |                                                                    |  |  |  |  |
|                         |                                | Port P2 can be switched CMOS or TTL input level.                                                  |                                                                    |  |  |  |  |
| P30/RTP6,               | I/O port P3                    | 8-bit CMOS I/O port                                                                               | Real time port function                                            |  |  |  |  |
| P31/RTP7                |                                | • I/O direction register allows each pin to be individually programmed as either input or output. | pins                                                               |  |  |  |  |
| P34/CKout,              |                                | At reset this port is set to input mode.                                                          | Clock output function pin                                          |  |  |  |  |
| P32, P33,               |                                | • In modes other than single-chip, these pins are used as control bus I/O pins.                   |                                                                    |  |  |  |  |
| P35–P37                 |                                | CMOS compatible input level                                                                       |                                                                    |  |  |  |  |
|                         |                                | CMOS 3-state output structure                                                                     |                                                                    |  |  |  |  |
| D4 0/                   | 1/0                            | Port P32 can be switched CMOS or TTL input level.                                                 |                                                                    |  |  |  |  |
| P40/XCOUT,              | I/O port P4                    | 8-bit CMOS I/O port with the same function as port P0                                             | Sub-clock generating I/C                                           |  |  |  |  |
| P41/Xcin                |                                | CMOS compatible input level                                                                       | pins(connect a resonator)                                          |  |  |  |  |
| P42/INTo,               |                                | CMOS 3-state output structures                                                                    | Interrupt input pins                                               |  |  |  |  |
| P43/INT <sub>1</sub>    |                                |                                                                                                   | • Timer X, Timer Y function pins                                   |  |  |  |  |
| P44/RxD,                |                                |                                                                                                   | (INT <sub>0</sub> , INT <sub>1</sub> ) • Serial I/O1 function pins |  |  |  |  |
| P44/RXD,<br>P45/TxD,    |                                |                                                                                                   | Serial I/O1 function pins                                          |  |  |  |  |
| P45/TXD,<br>P46/SCLK1,  |                                |                                                                                                   |                                                                    |  |  |  |  |
| P46/SCLK1,<br>P47/SRDY1 |                                |                                                                                                   |                                                                    |  |  |  |  |
| P50/Tout                | I/O port P5                    | 8-bit CMOS I/O port with the same function as port P0                                             | Timer 2 output pin                                                 |  |  |  |  |
| P51/SCMP2/              | 1/O port 1 3                   | CMOS compatible input level                                                                       | Interrupt input pin                                                |  |  |  |  |
| INT <sub>2</sub>        |                                | CMOS 3-state output structure                                                                     | Serial I/O2 function pin                                           |  |  |  |  |
| P52/INT3,               |                                | omoo o didio odipat diradiaro                                                                     | Interrupt input pin                                                |  |  |  |  |
| P53/INT4                |                                |                                                                                                   | Real time port function pin(INT <sub>4</sub> )                     |  |  |  |  |
| P54/CNTR <sub>0</sub> , |                                |                                                                                                   | Timer X, Timer Y function pins                                     |  |  |  |  |
| P55/CNTR <sub>1</sub>   |                                |                                                                                                   | Tanior A, Tanior T runduoir pink                                   |  |  |  |  |
| P56/DA1,                |                                |                                                                                                   | D-A conversion output                                              |  |  |  |  |
| P57/DA2                 |                                |                                                                                                   | pins                                                               |  |  |  |  |

## **PIN DESCRIPTION**

#### Table. 2. Pin description (2)

| Pin                 | Name          | Function                                              | Function except a port function |
|---------------------|---------------|-------------------------------------------------------|---------------------------------|
| P60/AN5-            | I/O port P6   | 3-bit CMOS I/O port with the same function as port P0 | A-D conversion output           |
| P62/AN7             |               | CMOS compatible input level                           | pins                            |
|                     |               | CMOS 3-state output structure                         |                                 |
| P63/CMPIN/          | Input port P6 | 2-bit CMOS input port                                 | Analog comparator input pin     |
| AN <sub>8</sub>     |               | CMOS compatible input level                           | A-D conversion input pin        |
| P64/CMPREF/         |               |                                                       | Reference voltage input pin     |
| AN <sub>9</sub>     |               |                                                       | for analog comparator           |
|                     |               |                                                       | A-D conversion input pin        |
| P65/DAVREF/         | I/O port P6   | 1-bit CMOS I/O port with the same function as port P0 | D-A conversion power            |
| AN <sub>10</sub>    |               | CMOS compatible input level                           | source input pin                |
|                     |               | CMOS 3-state output structure                         | A-D conversion input pin        |
| P70/SIN2,           | I/O port P7   | 8-bit CMOS I/O port with the same function as port P0 | Serial I/O2 function pins       |
| P71/Sout2,          |               | CMOS compatible input level                           |                                 |
| P72/SCLK2           |               | CMOS 3-state output structures                        |                                 |
| P73/SRDY2/          |               |                                                       | Serial I/O2 function pin        |
| ADT/AN <sub>0</sub> |               |                                                       | A-D conversion input pin        |
|                     |               |                                                       | A-D trigger input pin           |
| P74/AN1-            |               |                                                       | A-D conversion input pin        |
| P77/AN4             |               |                                                       |                                 |
| P80/DA3/            | I/O port P8   | 8-bit CMOS I/O port with the same function as port P0 | D-A conversion output           |
| AN11,               |               | CMOS compatible input level                           | pin                             |
| P81/DA4/            |               | CMOS 3-state output structures                        | A-D conversion input pin        |
| AN12,               |               |                                                       |                                 |
| P82/RTP0-           |               |                                                       | Realtime port function          |
| P87/RTP5            |               |                                                       | pins                            |

#### **PART NUMBERING**

#### **PART NUMBERING**



Fig. 3. Part numbering

#### **GROUP EXPANSION**

Mitsubishi plans to expand the 3807 group as follows:

#### **Memory Type**

Support for Mask ROM, One Time PROM and EPROM versions.

#### **Memory Size**

#### **Package**



Fig. 4. Memory expansion plan

Currently supported products are listed below.

Table 3. List of supported products

As of May 1996

| Product        | (P) ROM size (bytes)<br>ROM size for User () | RAM size (bytes) | Package | Remarks                       |
|----------------|----------------------------------------------|------------------|---------|-------------------------------|
| M38073M4-XXXFP |                                              |                  |         | Mask ROM version              |
| M38073E4-XXXFP | 16384                                        | 512              | 80P6N-A | One Time PROM version         |
| M38073E4FP     | (16254)                                      |                  |         | One Time PROM version (blank) |
| M38073E4FS     |                                              |                  | 80D0    | EPROM version                 |

#### **FUNCTIONAL DESCRIPTION**

#### FUNCTIONAL DESCRIPTION Central Processing Unit (CPU)

The 3807 group uses the standard 740 family instruction set. Refer to the table of 740 family addressing modes and machine instructions or the SERIES 740 <Software> User's Manual for details on the instruction set.

Machine-resident 740 family instructions are as follows:

The FST and SLW instructions cannot be used.

The MUL, DIV, WIT and STP instruction can be used.

The central processing unit (CPU) has the six registers.

#### Accumulator (A)

The accumulator is an 8-bit register. Data operations such as data transfer, etc., are executed mainly through the accumulator.

#### Index register X (X), Index register Y (Y)

Both index register X and index register Y are 8-bit registers. In the index addressing modes, the value of the OPERAND is added to the contents of register X or register Y and specifies the real address. When the T flag in the processor status register is set to "1", the value contained in index register X becomes the address for the second OPERAND.

#### Stack pointer (S)

The stack pointer is an 8-bit register used during sub-routine calls and interrupts. The stack is used to store the current address data and processor status when branching to subroutines or interrupt routines.

The lower eight bits of the stack address are determined by the contents of the stack pointer. The upper eight bits of the stack address are determined by the Stack Page Selection Bit. If the Stack Page Selection Bit is "0", then the RAM in the zero page is used as the stack area. If the Stack Page Selection Bit is "1", then RAM in page 1 is used as the stack area.

The Stack Page Selection Bit is located in the SFR area in the zero page. Note that the initial value of the Stack Page Selection Bit varies with each microcomputer type. Also some microcomputer types have no Stack Page Selection Bit and the upper eight bits of the stack address are fixed. The operations of pushing register contents onto the stack and popping them from the stack are shown in Fig.6.

#### **Program counter (PC)**

The program counter is a 16-bit counter consisting of two 8-bit registers PCH and PCL. It is used to indicate the address of the next instruction to be executed.



Fig. 5. 740 Family CPU register structure



Fig. 6. Register push and pop at interrupt generation and subroutine call

Table. 4. Push and pop instructions of accumulator or processor status register

|                           | Push instruction to stack | Pop instruction from stack |
|---------------------------|---------------------------|----------------------------|
| Accumulator               | PHA                       | PLA                        |
| Processor status register | PHP                       | PLP                        |

#### **FUNCTIONAL DESCRIPTION**

#### Processor status register (PS)

The processor status register is an 8-bit register consisting of flags which indicate the status of the processor after an arithmetic operation. Branch operations can be performed by testing the Carry (C) flag, Zero (Z) flag, Overflow (V) flag, or the Negative (N) flag. In decimal mode, the Z, V, N flags are not valid.

After reset, the Interrupt disable (I) flag is set to "1", but all other flags are undefined. Since the Index X mode (T) and Decimal mode (D) flags directly affect arithmetic operations, they should be initialized in the beginning of a program.

#### (1) Carry flag (C)

The C flag contains a carry or borrow generated by the arithmetic logic unit (ALU) immediately after an arithmetic operation. It can also be changed by a shift or rotate instruction.

#### (2) Zero flag (Z)

The Z flag is set if the result of an immediate arithmetic operation or a data transfer is "0", and cleared if the result is anything other than "0".

#### (3) Interrupt disable flag (I)

The I flag disables all interrupts except for the interrupt generated by the BRK instruction.

Interrupts are disabled when the I flag is "1".

When an interrupt occurs, this flag is automatically set to "1" to prevent other interrupts from interfering until the current interrupt is serviced.

#### (4) Decimal mode flag (D)

The D flag determines whether additions and subtractions are executed in binary or decimal. Binary arithmetic is executed when this flag is "0"; decimal arithmetic is executed when it is "1". Decimal correction is automatic in decimal mode. Only the ADC and SBC instructions can be used for decimal arithmetic.

#### (5) Break flag (B)

The B flag is used to indicate that the current interrupt was generated by the BRK instruction. The BRK flag in the processor status register is always "0". When the BRK instruction is used to generate an interrupt, the processor status register is pushed onto the stack with the break flag set to "1". The saved processor status is the only place where the break flag is ever set.

#### (6) Index X mode flag (T)

When the T flag is "0", arithmetic operations are performed between accumulator and memory, e.g. the results of an operation between two memory locations is stored in the accumulator. When the T flag is "1", direct arithmetic operations and direct data transfers are enabled between memory locations, i.e. between memory and memory, memory and I/O, and I/O and I/O. In this case, the result of an arithmetic operation performed on data in memory location 1 and memory location 2 is stored in memory location 1. The address of memory location 1 is specified by index register X, and the address of memory location 2 is specified by normal addressing modes.

#### (7) Overflow flag (V)

The V flag is used during the addition or subtraction of one byte of signed data. It is set if the result exceeds +127 to -128. When the BIT instruction is executed, bit 6 of the memory location operated on by the BIT instruction is stored in the overflow flag.

#### (8) Negative flag (N)

The N flag is set if the result of an arithmetic operation or data transfer is negative. When the BIT instruction is executed, bit 7 of the memory location operated on by the BIT instruction is stored in the negative flag.

Table. 5. Set and clear instructions of each bit of processor status register

|                   | C flag | Z flag | I flag | D flag | B flag | T flag | V flag | N flag |
|-------------------|--------|--------|--------|--------|--------|--------|--------|--------|
| Set instruction   | SEC    | -      | SEI    | SED    | _      | SET    | -      | _      |
| Clear instruction | CLC    | -      | CLI    | CLD    | _      | CLT    | CLV    | _      |

#### **CPU Mode Register**

The CPU mode register contains the stack page selection bit and processor mode bits. The CPU mode register is allocated at address 003B16.



Fig. 7. Structure of CPU mode register

#### **FUNCTIONAL DESCRIPTION**

#### Memory Special function register (SFR) area

The special function register (SFR) area in the zero page contains control registers such as I/O ports and timers.

#### **RAM**

RAM is used for data storage and for stack area of subroutine calls and interrupts.

#### **ROM**

The first 128 bytes and the last 2 bytes of ROM are reserved for device testing and the reset is user area for storing programs.

#### Interrupt vector area

The interrupt vector area contains reset and interrupt vectors.

#### Zero page

The 256 bytes from addresses 000016 to 00FF16 are called the zero page area. The internal RAM and the special function registers (SFR) are allocated to this area.

The zero page addressing mode can be used to specify memory and register addresses in the zero page area. Access to this area with only 2 bytes is possible in the zero page addressing mode.

#### Special page

The 256 bytes from addresses FF0016 to FFFF16 are called the special page area. The special page addressing mode can be used to specify memory addresses in the special page area. Access to this area with only 2 bytes is possible in the special page addressing mode.



Fig. 8. Memory map diagram

## **FUNCTIONAL DESCRIPTION**

| 000016             | Port P0 (P0)                              | 002016 | Timer X (low-order) (TXL)                   |
|--------------------|-------------------------------------------|--------|---------------------------------------------|
| 000116             | Port P0 direction register (P0D)          | 002116 | Timer X (high-order) (TXH)                  |
| 000216             | Port P1 (P1)                              | 002216 | Timer Y (low-order) (TYL)                   |
| 000316             | Port P1 direction register (P1D)          | 002316 | Timer Y (high-order) (TYH)                  |
| 000416             | Port P2 (P2)                              | 002416 | Timer 1 (T1)                                |
| 000516             | Port P2 direction register (P2D)          | 002516 | Timer 2 (T2)                                |
| 000616             | Port P3 (P3)                              | 002616 | Timer 3 (T3)                                |
| 000716             | Port P3 direction register (P3D)          | 002716 | Timer X mode register (TXM)                 |
| 000816             | Port P4 (P4)                              | 002816 | Timer Y mode register (TYM)                 |
| 000916             | Port P4 direction register (P4D)          | 002916 | Timer 123 mode register (T123M)             |
| 000A16             | Port P5 (P5)                              | 002A16 | Real time port register (RTP)               |
| 000B16             | Port P5 direction register (P5D)          | 002B16 | Real time port control register 0 (RTPCON0) |
| 000C16             | Port P6 (P6)                              | 002C16 | Real time port control register 1 (RTPCON1) |
| 000D16             | Port P6 direction register (P6D)          | 002D16 | Real time port control register 2 (RTPCON2) |
| 000E16             | Port P7 (P7)                              | 002E16 | Real time port control register 3 (RTPCON3) |
| 000F16             | Port P7 direction register (P7D)          | 002F16 | Timer A (low-order) (TAL)                   |
| 001016             | Port P8 (P8)                              | 003016 | Timer A (high-order) (TAH)                  |
| 001116             | Port P8 direction register (P8D)          | 003116 | Timer B (low-order) (TBL)                   |
| 001216             |                                           | 003216 | Timer B (high-order) (TBH)                  |
| 001316             |                                           | 003316 | D-A control register (DACON)                |
| 001416             | Timer XY control register (TXYCON)        | 003416 | A-D control register (ADCON)                |
| 001516             | Port P2P3 control register (P2P3C)        | 003516 | A-D conversion register (AD)                |
| 001616             | Pull-up control register (PULL)           | 003616 | D-A1 conversion register (DA1)              |
| 001716             | Watchdog timer control register (WDTCON)  | 003716 | D-A2 conversion register (DA2)              |
| 001816             | Transmit/Receive buffer register (TB/RB)  | 003816 | D-A3 conversion register (DA3)              |
| 001916             | Serial I/O1 status register (SIO1STS)     | 003916 | D-A4 conversion register (DA4)              |
| 001A <sub>16</sub> | Serial I/O1 control register (SIO1CON)    | 003A16 | Interrupt edge selection register (INTEDGE) |
| 001B <sub>16</sub> | UART control register (UARTCON)           | 003B16 | CPU mode register (CPUM)                    |
| 001C <sub>16</sub> | Baud rate generator (BRG)                 | 003C16 | Interrupt request register 1(IREQ1)         |
| 001D <sub>16</sub> | Serial I/O2 control register 1 (SIO2CON1) | 003D16 | Interrupt request register 2(IREQ2)         |
| 001E <sub>16</sub> | Serial I/O2 control register 2 (SIO2CON2) | 003E16 | Interrupt control register 1(ICON1)         |
| 001F <sub>16</sub> | Serial I/O2 register (SIO2)               | 003F16 | Interrupt control register 2(ICON2)         |
|                    |                                           | ]      |                                             |

Fig. 9. Memory map of special function register (SFR)

#### **FUNCTIONAL DESCRIPTION**

#### I/O Ports

#### [Direction Registers] PiD

The 3807 group has 68 programmable I/O pins arranged in nine individual I/O ports (P0—P5, P60—P62, P65 and P7—P8). The I/O ports have direction registers which determine the input/output direction of each individual pin. Each bit in a direction register corresponds to one pin, each pin can be set to be input port or output port. When "0" is written to the bit corresponding to a pin, that pin becomes an input pin. When "1" is written to that pin, that pin becomes an output pin. If data is read from a pin set to output, the value of the port output latch is read, not the value of the pin itself. Pins set to input (the bit corresponding to that pin must be set to "0") are floating and the value of that pin can be written to. If a pin set to input is written to, only the port output latch is written to and the pin remains floating.

#### [Pull-up Control Register] PULL

Ports P0, P1 and P2 have built-in programmable pull-up resistors. The pull-up resistors are valid only in the case that the each control bit is set to "1" and the corresponding port direction registers are set to input mode.

#### (1) CMOS/TTL input level selection

Either CMOS input level or TTL input level can be selected as an input level for ports P20 to P27 and P32. The input level is selected by P2·P32 input level selection bit (b7) of the port P2P3 control register (address 001516). When the bit is set to "0", CMOS input level is selected. When the bit is set to "1", the TTL input level is selected. After this bit is re-set, its initial value depends on the state of the CNVss pin. When the CNVss pin is connected to Vss, the initial value becomes "0". When the CNVss pin is connected to Vcc, the initial value becomes "1".

#### (2) Notes on STP instruction execution

Make sure that the input level at each pin is either 0V or to Vcc during execution of the STP instruction. When an input level is at an intermediate potential, a current will flow from Vcc to Vss through the input-stage gate.



Fig. 10. Structure of Port P2P3 control register



Fig. 11. Structure of Pull-up control register

## **FUNCTIONAL DESCRIPTION**

Table. 6. List of I/O port functions (1)

| Pin                 | Name    | Input/Output    | I/O Format                                      | Non-Port Function                   | Related SFRs                                 | Ref.No. |
|---------------------|---------|-----------------|-------------------------------------------------|-------------------------------------|----------------------------------------------|---------|
| P00-P07             | Port P0 | Input/output,   | CMOS compatible input level                     | Address low-order byte output       | CPU mode register                            | (1)     |
| P10-P17             | Port P1 | individual bits | CMOS 3-state output                             | Address high-order byte output      | Pull-up control register                     |         |
| P20-P27             | Port P2 |                 | CMOS/TTL input level                            | Data bus I/O                        | CPU mode register                            |         |
|                     |         |                 | CMOS 3-state output                             |                                     | Pull-up control register                     |         |
|                     |         |                 |                                                 |                                     | Port P2P3 control register                   |         |
| P30/RTP6,           | Port P3 |                 | CMOS compatible input level                     | Real time port output               | CPU mode register                            | (2)     |
| P31/RTP7            |         |                 | CMOS 3-state output                             |                                     | Real time port control register              |         |
| P32                 |         |                 | CMOS/TTL input level                            | Control signal input                | CPU mode register                            | (3)     |
|                     |         |                 | CMOS 3-state output                             |                                     | Port P2P3 control register                   |         |
| P3 <sub>3</sub>     |         |                 | CMOS compatible input level CMOS 3-state output | Control signal output               | CPU mode register                            |         |
| Р34/СКоит           |         |                 |                                                 | Clock output, $\phi$ output         | CPU mode register Port P2P3 control register | (4)     |
| P35-P37             |         |                 |                                                 | Control signal I/O                  | CPU mode register                            | (3)     |
| P40/Xcout,          | Port P4 | 1               |                                                 | Sub-clock generating circuit        | CPU mode register                            | (5)     |
| P41/Xcin            |         |                 |                                                 |                                     |                                              | (6)     |
| P42/INTo,           | 1       |                 |                                                 | External interrupt input            | Interrupt edge selection register            | (7)     |
| P43/INT1            |         |                 |                                                 | Timer X, Timer Y function input     |                                              |         |
| P44/RxD,            | 1       |                 |                                                 | Serial I/O1 function I/O            | Serial I/O1 control register                 | (8)     |
| P45/TxD,            |         |                 |                                                 |                                     | UART control register                        | (9)     |
| P46/Sclk1,          |         |                 |                                                 |                                     |                                              | (10)    |
| P47/SRDY1           |         |                 |                                                 |                                     |                                              | (11)    |
| Р50/Тоит            | Port P5 | 1               |                                                 | Timer 2 output                      | Timer 123 mode register                      | (12)    |
| P51/Scmp2/          | 1       |                 |                                                 | External interrupt input            | Interrupt edge selection register            | (22)    |
| INT <sub>2</sub>    |         |                 |                                                 | Serial I/O2 function I/O            | Serial I/O2 control register                 |         |
| P52/INT3,           | 1       |                 |                                                 | External interrupt input            | Interrupt edge selection register            | (7)     |
| P53/INT4            |         |                 |                                                 | Real time port trigger input (INT4) |                                              | . ,     |
| P54/CNTR0           | ]       |                 |                                                 | Timer X, Timer Y function I/O       | Timer X mode register                        | (13)    |
| P55/CNTR1           | 1       |                 |                                                 |                                     | Timer Y mode register                        |         |
| P56/DA1,            | 1       |                 |                                                 | D-A conversion output               | D-A control register                         | (14)    |
| P57/DA2             |         |                 |                                                 |                                     |                                              |         |
| P60/AN5—            | Port P6 | 1               |                                                 | A-D conversion input                | A-D control register                         | (15)    |
| P62/AN7             |         |                 |                                                 |                                     |                                              |         |
| P63/CMPIN/          | 1       | Input           | CMOS compatible input level                     | Analog comparator input pin         | A-D control register                         | (16)    |
| AN <sub>8</sub>     |         |                 |                                                 | A-D conversion input                |                                              |         |
| P64/CMPref/         |         |                 |                                                 | Analog comparator reference         |                                              |         |
| AN <sub>9</sub>     |         |                 |                                                 | voltage input pin                   |                                              |         |
|                     |         |                 |                                                 | A-D conversion input                |                                              |         |
| P65/DAVREF/         |         | Input/output,   | CMOS compatible input level                     | D-A converter power source          | A-D control register                         | (17)    |
| AN <sub>10</sub>    |         | individual bits | CMOS 3-state output                             | input                               |                                              |         |
|                     |         |                 |                                                 | A-D conversion input                |                                              |         |
| P70/SIN2,           | Port P7 | 1               |                                                 | Serial I/O2 function I/O            | Serial I/O2 control register                 | (18)    |
| P71/SOUT2,          |         |                 |                                                 |                                     |                                              | (19)    |
| P72/SCLK2           |         |                 |                                                 |                                     |                                              | (20)    |
| P73/SRDY2/          | 1       |                 |                                                 | Serial I/O2 function I/O            | Serial I/O2 control register                 | (21)    |
| ADT/AN <sub>0</sub> |         |                 |                                                 | A-D trigger input                   | A-D control register                         | . ,     |
|                     |         |                 |                                                 | A-D conversion input                |                                              |         |
| P74/AN1—            | 1       |                 |                                                 | A-D conversion input                | A-D control register                         | (15)    |
| P77/AN4             |         |                 |                                                 | '                                   |                                              | ` '     |

#### **FUNCTIONAL DESCRIPTION**

Table. 7. List of I/O port functions (2)

| Pin              | Name    | Input/Output    | I/O Format                  | Non-Port Function     | Related SFRs           | Ref.No. |
|------------------|---------|-----------------|-----------------------------|-----------------------|------------------------|---------|
| P80/DA3/         | Port P8 | Input/output,   | CMOS compatible input level | D-A conversion output | D-A control register   | (14)    |
| AN <sub>11</sub> |         | individual bits | CMOS 3-state output         | A-D conversion input  | A-D control register   |         |
| P81/DA4/         |         |                 |                             |                       |                        |         |
| AN <sub>12</sub> |         |                 |                             |                       |                        |         |
| P82/RTP0—        |         |                 |                             | Real time port output | Real time port control | (23)    |
| P87/RTP5         |         |                 |                             |                       | register               |         |

**Note1 :** For details of the functions of ports P0 to P3 in modes other than single-chip mode, and how to use double-function ports as function I/O ports, refer to the applicable sections.

<sup>2:</sup> Make sure that the input level at each pin is either 0 V or Vcc during execution of the STP instruction.

When an input level is at an intermediate potential, a current will flow from Vcc to Vss through the input-stage gate.



Fig. 12. Port block diagram (1)

#### **FUNCTIONAL DESCRIPTION**



Fig. 13. Port block diagram (2)



Fig. 14. Port block diagram (3)

## **FUNCTIONAL DESCRIPTION**

## Interrupts

Interrupts occur by twenty sources: eight external, eleven internal, and one software.

# (1) Interrupt Control

Each interrupt except the BRK instruction interrupt have both an interrupt request bit and an interrupt enable bit, and is controlled by the interrupt disable flag. An interrupt occurs if the corresponding interrupt request and enable bits are "1" and the interrupt disable flag is "0". Interrupt enable bits can be set or cleared by software. Interrupt request bits can be cleared by software, but cannot be set by software. The BRK instruction interrupt and reset cannot be disabled with any flag or bit. The I flag disables all interrupts except the BRK instruction interrupt and reset. If several interrupts requests occurs at the same time the interrupt with highest priority is accepted first.

### (2) Interrupt Operation

Upon acceptance of an interrupt the following operations are automatically performed:

- 1. The processing being executed is stopped.
- The contents of the program counter and processor status register are automatically pushed onto the stack
- Concurrently with the push operation, the interrupt jump destination address is read from the vector table into the program counter.
- 4. The interrupt disable flag is set and the corresponding interrupt request bit is cleared.

#### **■**Notes on Use

When the active edge of an external interrupt (INT0—INT4, CNTR0 or CNTR1) is set or the timer /INT interrupt source and the ADT/ A-D conversion interrupt source are changed, the corresponding interrupt request bit may also be set. Therefore, please take following sequence:

- (1) Disable the external interrupt which is selected.
- (2) Change the active edge in interrupt edge selection register (in case of CNTR<sub>0</sub>: Timer X mode register; in case of CNTR<sub>1</sub>: Timer Y mode register).
- (3) Clear the set interrupt request bit to "0."
- (4) Enable the external interrupt which is selected.

# **FUNCTIONAL DESCRIPTION**

Table. 8. Interrupt vector addresses and priority

| Interrupt Source  | Priority | Vector Addresses (Note 1) |                    | Interrupt Request                                | Remarks                                  |
|-------------------|----------|---------------------------|--------------------|--------------------------------------------------|------------------------------------------|
| interrupt course  | litionty | High                      | Low                | Generating Conditions                            | Komano                                   |
| Reset (Note 2)    | 1        | FFFD16                    | FFFC16             | At reset                                         | Non-maskable                             |
| INT <sub>0</sub>  | 2        | FFFB <sub>16</sub>        | FFFA <sub>16</sub> | At detection of either rising or falling edge of | External interrupt                       |
|                   |          |                           |                    | INTo input                                       | (active edge selectable)                 |
| INT <sub>1</sub>  | 3        | FFF9 <sub>16</sub>        | FFF816             | At detection of either rising or falling edge of | External interrupt                       |
|                   |          |                           |                    | INT <sub>1</sub> input                           | (active edge selectable)                 |
| Serial I/O1       | 4        | FFF716                    | FFF616             | At completion of serial I/O1 data receive        | Valid when serial I/O1 is selected       |
| receive           |          |                           |                    |                                                  |                                          |
| Serial I/O1       | 5        | FFF516                    | FFF416             | At completion of serial I/O1 data transmit       | Valid when serial I/O1 is selected       |
| transmit          |          |                           |                    | shift or when transmit buffer is empty           |                                          |
| Timer X           | 6        | FFF316                    | FFF216             | At timer X underflow                             |                                          |
| Timer Y           | 7        | FFF1 <sub>16</sub>        | FFF016             | At timer Y underflow                             |                                          |
| INT3              | 8        | FFEF16                    | FFEE16             | At detection of either rising or falling edge of | External interrupt                       |
|                   |          |                           |                    | INT3 input                                       | (active edge selectable)                 |
|                   |          |                           |                    |                                                  | Valid when INT3 interrupt is selected    |
| Timer 2           |          |                           |                    | At timer 2 underflow                             | Valid when timer 2 interrupt is selected |
| INT4              | 9        | FFED <sub>16</sub>        | FFEC <sub>16</sub> | At detection of either rising or falling edge of | External interrupt                       |
|                   |          |                           |                    | INT4 input                                       | (active edge selectable)                 |
|                   |          |                           |                    | L                                                | Valid when INT4 interrupt is selected    |
| Timer 3           |          |                           |                    | At timer 3 underflow                             | Valid when timer 3 interrupt is selected |
| CNTR <sub>0</sub> | 10       | FFEB16                    | FFEA <sub>16</sub> | At detection of either rising or falling edge of | External interrupt                       |
|                   |          |                           |                    | CNTRo input                                      | (active edge selectable)                 |
| CNTR <sub>1</sub> | 11       | FFE916                    | FFE816             | At detection of either rising or falling edge of | External interrupt                       |
|                   |          |                           |                    | CNTR1 input                                      | (active edge selectable)                 |
| Serial I/O2       | 12       | FFE716                    | FFE616             | At completion of serial I/O2 data transmit       | Valid when serial I/O2 is selected       |
|                   |          |                           |                    | and receive                                      |                                          |
| INT <sub>2</sub>  | 13       | FFE516                    | FFE416             | At detection of either rising or falling edge of | External interrupt                       |
|                   |          |                           |                    | INT2 input                                       | (active edge selectable)                 |
|                   |          |                           |                    |                                                  | Valid when INT2 interrupt is selected    |
| Timer 1           |          |                           |                    | At timer 1 underflow                             | Valid when timer 1 interrupt is selected |
| Timer A           | 14       | FFE316                    | FFE216             | At timer A underflow                             |                                          |
| Timer B           | 15       | FFE116                    | FFE016             | At timer B underflow                             |                                          |
| A-D conversion    | 16       | FFDF16                    | FFDE <sub>16</sub> | At completion of A-D conversion                  | Valid when A-D interrupt is selected     |
| ADT               |          |                           |                    | At falling edge of ADT input                     | External interrupt(valid at falling)     |
|                   |          |                           |                    |                                                  | Valid when ADT interrupt is selected and |
|                   |          |                           |                    |                                                  | when A-D external trigger is selected.   |
| BRK instruction   | 17       | FFDD16                    | FFDC16             | At BRK instruction execution                     | Non-maskable software interrupt          |

Note1 : Vector addresses contain interrupt jump destination addresses.

 ${\bf 2}$  : Reset function in the same way as an interrupt with the highest priority.



Fig. 15. Interrupt control



Fig. 16. Structure of Interrupt-related registers

## **Timers**

The 3807 group has seven timers: four 16-bit timers (Timer X, Timer Y, Timer A, and Timer B) and three 8-bit timers (Timer 1, Timer 2, and Timer 3).

All timers are down-counters. When the timer reaches either "0016" or "000016", an underflow occurs with the next count pulse. Then the contents of the timer latch is reloaded into the timer and the timer continues down-counting. When a timer underflows, the interrupt request bit corresponding to that timer is set to "1."

Read and write operation on 16-bit timer must be performed for both high- and low-order bytes. When reading a 16-bit timer, read from the high-order byte first. When writing to 16-bit timer, write to the low-order byte first. The 16-bit timer cannot perform the correct operation when reading during write operation, or when writing during read operation.

Timers A and B are real time output port timers. For details, refer to the section "Real time output port".

#### ●Timer X, Timer Y

Timer X and Y are independent 16-bit timers which can select enable seven different operation modes each by the setting of their mode registers. The related registers of timer X and Y are listed below. The following register abbreviations are used:

- Timer XY control register (TXYCON: address 001416)
- Port P4 direction register (P4D: address 000916)
- Port P5 direction register (P5D: address 000B16)
- Timer X (low-order) (TXL: address 002016)
- Timer X (high-order) (TXH: address 002116)
- Timer Y (low-order) (TYL: address 002216)
- Timer Y (high-order) (TYH: address 002316)
- Timer X mode register (TXM: address 0027<sub>16</sub>)
- Timer Y mode register (TYM: address 002816)
- Interrupt edge selection register (INTEDGE: address 003A<sub>16</sub>)
- Interrupt request register 1 (IREQ1: address 003C16)
- Interrupt request register 2 (IREQ2: address 003D16)
  Interrupt control register 1 (ICON1: address 003E16)
- Interrupt control register 2 (ICON2: address 003F16)

For details, refer to the structures of each register.

The following is an explanation of the seven modes:

## (1) Timer • event counter mode

## **①Timer mode**

Mode selection

This mode can be selected by setting "000" to the following bits. Timer X operating mode bit (bits 2 to 0) of TXM

Timer Y operating mode bit (bits 2 to 0) of TYM

• Count source selection

In high- or middle-speed mode,  $f(X_{IN})/2$ ,  $f(X_{IN})/16$ , or  $f(X_{CIN})$  can be selected as the count source.

In low-speed mode the count source is f(Xcin).

A count source is selected by the following bit.

Timer X count source selection bit (bits 7 and 6) of TXM Timer Y count source selection bit (bits 7 and 6) of TYM

Interrupt

When an underflow is generated, the corresponding timer X interrupt request bit (b4) or timer Y interrupt request bit (b5) of IREQ1

is set to "1".

· Explanation of operation

After reset release, timer X stop control bit (b0) and timer Y stop control bit (b1) of TXYCON are set to "1"and the timer stops. During timer stop, a timer value written to the timer X or timer Y is set by writing data to the corresponding timer latch and timer at the same time. The timer operation is started by setting the bits 0 or 1 of TXYCON to "0". When the timer reaches "000016", an underflow occurs with the next count pulse. Then the contents of the timer latch is reloaded into the timer and the timer continues down-counting. For changing a timer value during count operation, a latch value must be changed by writing data only to the corresponding latch first. Then the timer is reloaded with the new latch value at the next underflow.

#### 2Event counter mode

Mode selection

This mode can be selected by the following sequence.

- Set "000" to the timer X operating mode bit (bits 2 to 0) of TXM, or to the timer Y operating mode bit (bits 2 to 0) of TYM.
- Select an input signal from the CNTR<sub>0</sub> pin (in case of timer X; set "11" to bits 7 and 6 of TXM), or from the CNTR<sub>1</sub> pin (in case of timer Y; set "11" to bits 7 and 6 of TYM) as a count source.

The valid edge for the count operation is selected by the CNTR<sub>0</sub>/CNTR<sub>1</sub> active edge switch bit (b5) of TXM or TYM: if set to "0", counting starts with the rising edge or if set to "1", counting starts with the falling edge.

Interrupt

The interrupt generation at underflow is the same as already explained for the timer mode.

• Explanation of operation

The operation is the same as already explained for the timer mode. In this mode, the double-function port of CNTR<sub>0</sub>/CNTR<sub>1</sub> pin must be set to input.

Figure 19 shows the timing chart for the timer • event counter mode.

## (2) Pulse output mode

Mode selection

This mode can be selected by setting "001" to the following bits.

Timer X operating mode bit (bits 2 to 0) of TXM

Timer Y operating mode bit (bits 2 to 0) of TYM

Count source selection

In high- or middle-speed mode, f(XIN)/2, f(XIN)/16, or f(XCIN) can be selected as the count source.

In low-speed mode the count source is f(XCIN).

Interrupt

The interrupt generation at underflow is the same as already explained for the timer mode.

• Explanation of operation

Counting operation is the same as in timer mode. Moreover the pulse which is inverted each time the timer underflows is output from CNTRo/CNTR1 pin. When the CNTRo/CNTR1 active edge switch bit (b5) of TXM or TYM is "0", output starts with "H" level. When set to "1", output starts with "L" level.

## **FUNCTIONAL DESCRIPTION**

#### ■Precautions

Set the double-function port of CNTR<sub>0</sub>/CNTR<sub>1</sub> pin to output in this mode.

[During timer operation stop]

The output from CNTR<sub>0</sub>/CNTR<sub>1</sub> pin is initialized to the level set through CNTR<sub>0</sub>/CNTR<sub>1</sub> active edge switch bit.

[During timer operation enabled]

When the value of the CNTR<sub>0</sub>/CNTR<sub>1</sub> active edge switch bit is written over, the output level of CNTR<sub>0</sub>/CNTR<sub>1</sub> pin is inverted.

Figure 20 shows the timing chart of the pulse output mode.

#### (3) Pulse period measurement mode

Mode selection

This mode can be selected by setting "010" to the following bits.

Timer X operating mode bit (bits 2 to 0) of TXM

Timer Y operating mode bit (bits 2 to 0) of TYM

· Count source selection

In high- or middle-speed mode, f(XIN)/2 or f(XIN)/16 can be selected as the count source.

In low-speed mode the count source is f(XcIN).

Interrupt

The interrupt generation at underflow is the same as already explained for the timer mode. Bits 0 or 1 of IREQ2 is set to "1" synchronously to pulse period measurement completion.

• Explanation of operation

[During timer operation stop]

Select the count source. Next, select the interval of the pulse periods to be measured. When bit 5 of the TXM or TYM is set to "0", the timer counts during the interval of one falling edge of CNTRo/CNTR<sub>1</sub> pin input until the next falling edge of input. If bits 5 are set to "1", the timer counts during the interval of one rising edge until the next rising edge.

[During timer operation enabled]

The pulse period measurement starts by setting bit 0 or 1 of TXYCON to "0" and the timer counts down from the value that was set to the timer before the start of measurement. When a valid edge of measurement start/stop is detected, the 1's complement of the timer value is written to the timer latch and "FFFF16" is set to the timer. Furthermore when the timer underflows, a timer X/Y interrupt request occurs and "FFFF16" is set to the timer. The measured value is held until the next measurement completion.

## ■Precautions

Set the double-function port of CNTR<sub>0</sub>/CNTR<sub>1</sub> pin to input in this mode.

A read-out of timer value is impossible in this mode. The timer is written to only during timer stop (no measurement of pulse periods). Since the timer latch in this mode is specialized for the read-out of measured values, do not perform any write operations during measurement.

The timer is set to "FFFF16" when the timer either underflows or a valid edge of pulse period measurement is detected. Due to that, the timer value at the start of measurement depends on the timer value before the start of measurement.

Figure 21 shows the timing chart of the pulse period measurement mode.

### (4) Pulse width measurement mode

• Mode selection

This mode can be selected by setting "011" to the following bits.

Timer X operating mode bit (bits 2 to 0) of TXM

Timer Y operating mode bit (bits 2 to 0) of TYM

• Count source selection

In high- or middle-speed mode, f(XIN)/2 or f(XIN)/16 can be selected as the count source.

In low-speed mode the count source is f(XCIN).

Interrupt

The interrupt generation at underflow is the same as already explained for the timer mode. Bit 0 or 1 of IREQ2 is set to "1" synchronously to pulse width measurement completion.

Explanation of operation

[During timer operation stop]

Select the count source. Next, select the interval of the pulse widths to be measured. When bit 5 of TXM or TYM is set to "1", the timer counts during the interval of one falling edge of CNTR<sub>0</sub>/CNTR<sub>1</sub> pin input until the next rising edge of input ("L" interval). If bit 5 is set to "0", the timer counts during the interval of one rising edge until the next falling edge ("H" interval).

[During timer operation enabled]

The pulse width measurement starts by setting bit 0 or 1 of TXYCON to "0" and the timer counts down from the value that was set to the timer before the start of measurement. When a valid edge of measurement completion is detected, the 1's complement of the timer value is written to the timer latch and "FFFF16" is set to the timer. Furthermore when the timer underflows, a timer X/Y interrupt request occurs and "FFFF16" is set to the timer. The measured value is held until the next measurement completion.

### ■Precautions

Set the double-function port of CNTR<sub>0</sub>/CNTR<sub>1</sub> pin to input in this mode.

A read-out of timer value is impossible in this mode. The timer is written to only during timer stop (no measurement of pulse widths). Since the timer latch in this mode is specialized for the read-out of measured values, do not perform any write operations during measurement.

The timer value is set to "FFFF16" when the timer either underflows or a valid edge of pulse widths measurement is detected. Due to that, the timer value at the start of measurement depends on the timer value before the start of measurement.

Figure 22 shows the timing chart of the pulse width measurement mode.

## (5) Programmable waveform generation mode

Mode selection

This mode can be selected by setting "100" to the following bits.

Timer X operating mode bit (bits 2 to 0) of TXM

Timer Y operating mode bit (bits 2 to 0) of TYM

Count source selection

In high- or middle-speed mode, f(XIN)/2, f(XIN)/16, or f(XCIN) can be selected as the count source.

In low-speed mode the count source is f(XcIN).

Interrupt

The interrupt generation at underflow is the same as already

explained for the timer mode.

· Explanation of operation

Counting operation is the same as in timer mode. Moreover the timer outputs the data set in the corresponding output level latch (bit 4 of TXM or TYM) to CNTR<sub>0</sub>/CNTR<sub>1</sub> pin each time the timer underflows. After the timer underflows, the generation of optional waveform from CNTR<sub>0</sub>/CNTR<sub>1</sub> pin is possible through a change of values in the output level latch and timer latch.

#### ■Precautions

Set the double-function port of CNTR<sub>0</sub>/CNTR<sub>1</sub> pin to output in this mode

Figure 23 shows the timing chart of the programmable waveform generation mode.

## (6) Programmable one-shot generating mode

• Mode selection

This mode can be selected by setting "101" to the following bits.

Timer X operating mode bit (bits 2 to 0) of TXM

Timer Y operating mode bit (bits 2 to 0) of TYM

· Count source selection

In high- or middle-speed mode, f(XIN)/2 or f(XIN)/16 can be selected as the count source.

Interrupt

The interrupt generation at underflow is the same as already explained for the timer mode. The one-shot generating trigger condition must be set to the INTo interrupt edge selection bit (b0) and INT1 interrupt edge selection bit (b1) of INTEDGE. Setting these bits to "0" causes the interrupt request being triggered by a falling edge, setting them to "1" causes the interrupt request being triggered by a rising edge. The INTo interrupt request bit (b0) and INT1 interrupt request bit (b1) of IREQ1 are set to "1" by detecting the active edge of the INT pin.

• Explanation of operation

For a "H" one-shot pulse, set bit 5 of TXM, TYM to "0". [During timer operation stop]

The output level of CNTR0/CNTR1 pin is initialized to "L" at mode selection. Set the one-shot pulse width to TXH, TXL, TYH, TYL. A trigger generation during timer stop (input signal to INT0/INT1 pin) is invalid.

[During timer operation enabled]

When a trigger generation is detected, "H" is output, and at underflow "L" is output from CNTR<sub>0</sub>/CNTR<sub>1</sub> pin.

For a "L" one-shot pulse set bit 5 of TXM, TYM to "1".

[During timer operation stop]

The output level of CNTR0/CNTR1 pin is initialized to "H" at mode selection. Set the one-shot pulse width to TXH, TXL, TYH, TYL. A trigger generation during timer stop (input signal to INT0/INT1 pin) is invalid.

[During timer operation enabled]

When a trigger generation is detected, "L" is output, and at underflow "H" is output from CNTR<sub>0</sub>/CNTR<sub>1</sub> pin.

## ■ Precautions

- Set the double-function port of CNTR<sub>0</sub>/CNTR<sub>1</sub> pin to output and the double-function port of INT<sub>0</sub>/INT<sub>1</sub> pin to input in this mode.
- This mode is unused in low-speed mode.

 During one-shot generation permission or one-shot generation the output level from CNTR<sub>0</sub>/CNTR<sub>1</sub> pin changes if the value of the CNTR<sub>0</sub>/CNTR<sub>1</sub> active edge switch bit is inverted.

Figure 24 shows the timing chart of the programmable one-shot generating mode.

## (7) PWM mode

Mode selection

This mode can be selected by setting "110" to the following bits.

Timer X operating mode bit (bits 2 to 0) of TXM

Timer Y operating mode bit (bits 2 to 0) of TYM

• Count source selection

In high- or middle-speed mode,  $f(X_{IN})/2$  or  $f(X_{IN})/16$  can be selected as the count source.

Interrupt

With a rising edge of CNTR<sub>0</sub>/CNTR<sub>1</sub> output, the timer X interrupt request bit (b4) and timer Y interrupt request bit (b5) of IREQ1 are set to "1".

• Explanation of operation

PWM waveform is output from CNTR<sub>0</sub> pin (in case of timer X) or from CNTR<sub>1</sub> pin (in case of timer Y).

The "H" interval of PWM waveform is determined by the setting value m (m=0 to 255) of TXH and TYH and the "L" interval of PWM waveform is determined by the setting value n (n=0 to 255) of TXL and TYL.

The PWM cycles are:

PWM cycle time = (m+n)-ts PWM duty = m/(m+n)

where: ts: period of timer X/timer Y count source

[During count operation stop]

When a timer value is set to TXL, TXH, TYL, TYH by writing data to timer and timer latch at the same time. When setting this value, the output of CNTR<sub>0</sub>/CNTR<sub>1</sub> pin is initialized to the "H" level.

[During count operation enabled]

By setting the bit 0 or 1 of TXYCON to "0", an "H" interval of TXH or TYH is output first, and after that a "L" level interval of TXL or TYL are output next. These operations are repeated continuously. The PWM output is changed after the underflow by setting a timer value, which is set by writing data to the timer latch only, to TXL, TXH, TYL, TYH.

## ■Precautions

- Set the double-function port of CNTR<sub>0</sub>/CNTR<sub>1</sub> pin to output in this mode.
- This mode is unused in low-speed mode.
- $\bullet$  When the PWM "H" interval is set to "0016", PWM output is "L".
- When the PWM "L" interval is set to "0016", PWM output is "H".
- When the PWM "H" interval and "L" interval are set to "0016", PWM output is "I."
- When a PWM "H" interval or "L" interval is set to "0016" at least for a short time, timer X/timer Y interrupt request does not occur.
- When the value set to the timer latch is "0016", the value is undefined since the timer counts down by dummy count operation.

Figure 25 shows the timing chart of the PWM mode.

# **FUNCTIONAL DESCRIPTION**

- ■Precautions regarding all modes
- Timer X, timer Y writing control

One of the following operation is selected by bit 3 of TXM or TYM for timer  $\boldsymbol{X}$  or timer  $\boldsymbol{Y}$ .

Writing data to the corresponding latch and timer at the same time

Writing data to only corresponding latch

When the operation "writing data to only corresponding latch" is selected, the value is set to the timer latch by writing a value to timer X/Y address and a timer is renewed at the next underflow. After releasing a reset, "writing the corresponding latch and timer at the same time" is selected. When a value is written to timer X/Y address, a value is set to a timer and a timer latch at the same time. When "writing data to only corresponding latch" is selected, if writing to a reload latch and an underflow are performed at the same timing, the timer value is undefined.

- Timer X, timer Y read control
   In pulse period measurement mode and pulse width measurement mode the timer value cannot be read-out. In all other modes readout operations without effect to count operations/stops are possible.
   However, the timer latch value cannot be read-out.
- Precautions regarding the CNTR<sub>0</sub>/CNTR<sub>1</sub> active edge switch bit and the INT<sub>0</sub>/INT<sub>1</sub> interrupt edge selection bit: The CNTR<sub>0</sub>/CNTR<sub>1</sub> active edge switch bit and the INT<sub>0</sub>/INT<sub>1</sub> interrupt edge selection bit settings have an effect also on each interrupt active edge.



Fig. 17. Block diagram of Timer X and Timer Y



Fig. 18. Structure of Timer X mode register, Timer Y mode register, and Timer XY control register



Fig. 19. Timing chart of Timer•Event counter mode



Fig. 20. Timing chart of Pulse output mode



Fig. 21. Timing chart of Pulse period measurement mode



Fig. 22. Timing chart of Pulse width measurement mode



Fig. 23. Timing chart of Programmable waveform generating mode



Fig. 24. Timing chart of Programmable one-shot generating mode



Fig. 25. Timing chart of PWM mode

# ●Timer 1, Timer 2, Timer 3

Timer 1 to 3 are 8-bit timers for which the count source can be selected through timer 123 mode register.

### (1) Timer 2 write control

Timer 2 write control bit (b2) of timer 123 mode register allows to select whether a value written to timer 2 is written to timer latch and timer synchronously or to the timer latch only.

If only the timer latch is written to, the value is set only to the reloadlatch by writing a value to the timer address at that time. The content of timer is reloaded with the next underflow. Usually writing operation to the timer latch and timer synchronously is selected. And a value is written to the timer latch and timer synchronously when a value is written to the timer address.

If only the timer latch is written to, it may occur that the value set to the counter is not constant, when the timing with which the reloadlatch is written to and the underflow timing is nearly the same.

#### (2) Timer 2 output control

When timer 2 output (Tout) is enabled, inverted signals are output from Tout pin each time timer 2 has underflow. For this reason, set the double-function port of Tout pin to output mode.

### ■Precautions on timers 1 to 3

When the count source for timer 1 to 3 is switched, it may occur that short pulses are generated in count signals and that the timer count value shows big changes. When timer 1 output is selected as timer 2 or timer 3 count source, short pulses are generated to signals output from timer 1 through writing timer 1. Due to that, the count values for timer 2 and 3 may change very often.

Therefore, when the count sources for timer 1 to 3 are set, set the values in order starting from timer 1.



Fig. 26. Structure of Timer 123 mode register



Fig. 27. Block diagram of Timer

## **FUNCTIONAL DESCRIPTION**

## Real time output port

The 3807 group has two on-chip sets of real time output ports (RTP). The two sets of real time output ports consist of two 16-bit timers A and B and eight 8-bit real time port registers. Synchronous to the reloading of timers A and B, the real time port register values are output from ports P82 to P87, P30 and P31. The real time port registers consist of 8-bit register 0 to 7. Each port with its corresponding bits is shown in figure 26.

Timer A and timer B have each two 16-bit timer latches. Figure 28 shows the real time port block diagram and figure 29 and 30 show the structure of the real time port control registers 0 to 3.

There are four operating modes for real time ports which are: 8 repeated load mode, 6 repeated load mode, 5 repeated load mode and one-shot pulse generating mode. Each operating mode can be set for timer A and timer B separately. However, switch modes during timer count stop.

### (1) 8 repeated load mode

The output operation for each value of the real time port registers 7 to 0 is performed repeatedly in association with an alternate underflow of the corresponding timer latch 1 or 0. The real time port output pointer changes in sequence as a cycle of 8 repeated load operations as "7, 6, 5, 4, 3, 2, 1, 0, 7, 6, 5, 4, 3, 2, 1, 0, 7, 6, 5, ...."

The initial value at the generation of a start trigger can be specified by setting a value in the output pointer. Figure 31 shows a timing chart of 8 repeated load mode.

#### (2) 6 repeated load mode

The output operation for each value of real time port registers 5 to 0 is performed repeatedly in association with an alternate underflow of the corresponding timer latch 1 to 0. The real time port output pointer changes in sequence as a cycle of 6 repeated load operations as "5, 4, 3, 2, 1, 0, 5, 4, 3, 2, 1, 0, 5, 4, ...."

The initial value at the generation of a start trigger can be specified by setting a value in the output pointer. Figure 32 shows a timing chart of the 6 repeated load mode.

## (3) 5 repeated load mode

The output operation for each value of real time port registers 4 to 0 is performed repeatedly in association with an alternate underflow of the corresponding timer latch 1 or 0. The real time port output pointer changes in sequence as a cycle of 5 repeated load operations as "4, 3, 2, 1, 0, 4, 3, 2, 1, 0, 4, 3, 2, 1, ...." The initial value at the generation of a start trigger can be specified by setting a value in the output pointer. Figure 33 shows a timing chart of the 5 repeated load mode.

## (4) One-shot pulse generation mode

The output operation for each value of real time port registers 2 to 0 is performed only once in association with trigger generation and an underflow of timer latch 1 or 0. After a trigger is generated, the value of real time port register 1 is output from the real time output port and the output pointer value becomes "0002". At each underflow of the timer, the each value of real time port registers 0 and 2 is output in ascending sequence, then the operation is completed.

After completion of the operation, the value of real time port register 2 is continuously output from the real time output port and the output pointer value continues to be "0012" until the next start trigger is

generated. In this condition, the real time port function is in the wait status

When this mode is selected, the pointer value is not changed by writing a value into the output pointer. If external trigger is specified as trigger selection when this mode is selected, a rising and falling double edge trigger is generated regardless of the contents of the INT4 interrupt source bit (b7) of the interrupt edge selection register.

Figure 34 shows a timing chart of the one-shot pulse generation mode.

## (5) Selection of timer interrupt mode

The timer is a count-down system. The contents of the timer latch are reloaded by the count pulse subsequent to the moment when the contents of the counter becomes "000016". At the same time, the interrupt request bit corresponding to each timer is set to "1." The interrupt request corresponding to the value of the real time port output pointer can also be controlled. For controlling the interrupt request bit, refer to the item pertaining to the timer interrupt mode selection bit of the real time port control register 1,2 shown in figure 29 and 30.

#### (6) Switch of timer count source

The timer A and the timer B can select the system clock  $\phi$  divided by 2 or 16 as a count source with the timer A, B count source selection bit (b0) of real time port control register 0.

#### [Timer latches]

Each of the timer A and the timer B has two 16-bit timer latches. Data is written into the 8 low-order bits and the 8 high-order bits in this order. When the high-order side has been written, the next latch is automatically specified. The writing pointer changes in sequence as "1, 0, 1, 0, 1, ...." The timer latch to be written first can be specified by setting the timer writing pointer. Data is not written directly into the timer A and the timer B. When reading the contents of the timer, the count value at that point of time is read. Read the high-order side first and then the low-order side. The low-order side value is read with the same timing as that for the high-order side value and held at the timer read latch. The data held state is released by reading the low-order side. At a reload operation of the timer A or the timer B. Timer latch 1 is reloaded as the initial value after a trigger is generated. After that, the timer latch is reloaded in sequence as "0, 1, 0, 1, ...."

## [Start trigger]

The operation of the real time port is started by a start trigger. When a start trigger is generated, the value of the real time port register specified by the output pointer (the value of real time port register 1 in the one-shot pulse generation mode) is output from the real time output port.

The value of timer latch 1 is reloaded into the timer A or the timer B and the timer count A, B source stop bit is released, so that the timer count is started.

After that, when the timer underflows, data is transferred from the real port register to the real time output port.

As a start trigger, either internal trigger or external trigger can be selected by the timer A start trigger selection bit (b2) or timer B start trigger selection bit (b5) of real time port control register 0.

When the internal trigger is selected, a start trigger is generated by an input signal of the INT4 pin. The start trigger becomes a falling edge when the INT4 interrupt edge selection bit is "0" and a rising edge when this bit is "1".

When the external trigger is selected in the one-shot pulse generation mode, the start trigger becomes a rising/falling double edge trigger regardless of the contents of the INT4 interrupt edge selection bit.

### [Real time port registers] RTP

The data to be output to real time ports is written into 8 real time port registers 0 to 7. The correspondence between each bit of real time port registers and each port output is as follows:

P31: bit 7 of real time port registers 7 to 0

P30: bit 6 of real time port registers 7 to 0

P87: bit 5 of real time port registers 7 to 0

P86: bit 4 of real time port registers 7 to 0

P85: bit 3 of real time port registers 7 to 0

P84: bit 2 of real time port registers 7 to 0

P83: bit 1 of real time port registers 7 to 0

P82: bit 0 of real time port registers 7 to 0

It can be selected for each bit by real time port control register 3 whether the output of each port is to be used as an ordinary I/O port or a real time port output.

### [Real time port data pointer]

It can be optionally specified by the real time port data pointers A or B and the real time port data pointer A or B switching bit in which real time port register the output data is to be set or form which real time port register the data output is to be started.

When writing output data into the real time port register, set the real time port data pointer A, B switch bit to "0" (select the R/W pointer) and also write a value into the 3 bits of the real time port data pointers A, B. With this, the real time port register for writing will be specified. After that, when a value is written into the real time port register (address 002A16), the data is written into the specified real time port register and also the R/W pointer value is automatically decreased by 1. Then writing data is enabled into the next real time port register.

A value of "0002" to "1112" can be set int the R/W pointer regardless of the operating mode specified by the timer A, B operating mode selection bit, and the R/W pointer value is automatically decreased by 1 by writing data into the real time port register. However, when a value becomes "0002", the R/W pointer value is decreased by 1 in the numeral range of stages to be used in each operating mode unless the R/W pointer is set again at the subsequent write operation to the real time port register. When "1112 (=7)" is set in the R/W pointer, the R/W pointer operation in each selected mode is as follows:

- •During 8 repeated load mode  $7 \rightarrow 6 \rightarrow 5 \rightarrow 4 \rightarrow 3 \rightarrow 2 \rightarrow 1 \rightarrow 0 \rightarrow 7 \rightarrow 6 \rightarrow 5...$
- •During 6 repeated load mode  $7 \rightarrow 6 \rightarrow 5 \rightarrow 4 \rightarrow 3 \rightarrow 2 \rightarrow 1 \rightarrow 0 \rightarrow 5 \rightarrow 4 \rightarrow 3...$
- •During 5 repeated load mode  $7\rightarrow6\rightarrow5\rightarrow4\rightarrow3\rightarrow2\rightarrow1\rightarrow0\rightarrow4\rightarrow3\rightarrow2...$
- •During one-shot pulse generation mode

$$7 \rightarrow 6 \rightarrow 5 \rightarrow 4 \rightarrow 3 \rightarrow 2 \rightarrow 1 \rightarrow 0 \rightarrow 2 \rightarrow 1 \rightarrow 0 \dots$$

When reading the real time port register, set the real time port data pointer A, B switch bit to "0" (select the R/W pointer) and also writing a value into the 3 bits of the real time port data pointer A, B to specify the real time port register for reading. After that, the value of the

specified real time port register can be read by reading the real time port register (address 002A<sub>16</sub>). In this care, however, the R/W pointer value is not counted down automatically. Accordingly, to read another real time port register, rewrite the R/W pointer beforehand.

To specify a read port register to be output to the real time output port, set the real time port data pointer A, B switch bit to "1" (select an output pointer) and also set a value in the 3 bits of the real time port data pointer A or B.

When a start trigger is generated, data is output beginning with the real time port register set in the output pointer and the output pointer value is automatically decreased by 1.

At each underflow of the timer A or timer B, the output pointer value is automatically decreased by 1. Regarding the case of the one-shot pulse generation mode, however, refer to the item pertaining to the one-shot pulse generation mode.

When the real time port data pointer A to B has been read, only the output pointer can be read.

#### ■Notes regarding all modes

- •When the trigger is generated again during timer count operation, the operation is started from the beginning. In this case, put an interval of 3 cycles or more between the generation of a trigger and the generation of the next trigger, If the generation of the next trigger occurs almost concurrently with the underflow timing of the timer, the next real time output may not be performed normally.
- •To stop the timer count after generation of a start trigger, write "1" in the timer A, B count source stop bit of real time port control register 0 at an interval of 3 cycles or more of the timer count source.
- •To change the contents of the real time port data pointer A, B switch bit, the real time port data pointer must be specified simultaneously. Therefore, use the LDM/STA instruction instead of the SEB/CLB instruction.
- •If the timer A, B count source stop bit is changed ("1"→"0") by a start trigger between the read operation and the write operation of a read-modify-write instruction such as the SEB instruction which is used in real time port control register 0, the timer count will stop, having an effect on the real time output.

An maximum interval of 2 cycles of the count source is required before the timer A, B count source stop bit is cleared to "0" which indicates the count operation state after a start trigger is generated regardless of whether the start trigger is an internal trigger or an external trigger.

Accordingly, do not use the read-modify-write instruction for real time port control register 0 in this period. If a write operation for real time port control register 0 with any purpose other than stopping the timer count is performed concurrently with the generation of a start trigger, be sure to use such an instruction for writing "0" into the timer A, B count source stop bit as the LDM/STA instruction.

Even if "0" is written into the timer A, B count source stop bit, the timer count remains in the stop state without change.

- •When the timing for writing to the high-order side reload latch is almost equal to the underflow timing, an undesirable value may be set in the timer A or timer B.
- If the real time output port is selected by real time port control register 3 after resetting, "L" is output from this pin until a start trigger is generated.



Fig. 28. Block diagram of Real time output port



Fig. 29. Structure of Real time output port related register (1)



Fig. 30. Structure of Real time output port related register (2)

1-38



Fig. 31. 8 repeated load mode operation



Fig. 32. 6 repeated load mode operation



Fig. 33. 5 repeated load mode operation



Fig. 34. One-shot pulse generating mode operation

## Serial I/O

# ●Serial I/O1

Serial I/O1 can be used as either clock synchronous or asynchronous (UART) serial I/O. A dedicated timer (baud rate generator) is also provided for baud rate generation during Serial I/O1 operation.

#### (1) Clock Synchronous Serial I/O Mode

Clock synchronous serial I/O1 mode can be selected by setting the serial I/O1 mode selection bit (b6) of the serial I/O1 control register to "1." For clock synchronous serial I/O, the transmitter and the receiver must use the same clock for serial I/O1 operation. If an internal clock is used, transmit/receive is started by a write signal to the Transmit/Receive buffer register (TB/RB) (address:001816).



Fig. 35. Block diagram of clock synchronous serial I/O1



Fig. 36. Operation of clock synchronous serial I/O1 function

## **FUNCTIONAL DESCRIPTION**

## (2) Asynchronous Serial I/O (UART) Mode

Asynchronous serial I/O1 mode (UART) can be selected by clearing the Serial I/O1 mode selection bit (b6) of the Serial I/O1 control register to "0." Eight serial data transfer formats can be selected and the transfer formats used by a transmitter and receiver must be identical.

The transmit and receive shift registers each have a buffer (the two buffers have the same address in memory). Since the shift register cannot be written to or read from directly, transmit data is written to the transmit buffer, and receive data is read from the receive buffer. The transmit buffer can also hold the next data to be transmitted, and the receive buffer can hold a character while the next character is being received.



Fig. 37. Block diagram of UART serial I/O1



Fig. 38. Operation of UART serial I/O1 function

### [Transmit Buffer Register/Receive Buffer Register] TB/RB (001816)

The transmit buffer and the receive buffer are located in the same address. The transmit buffer is write-only and the receive buffer is read-only. If a character bit length is 7 bits, the MSB of data stored in the receive buffer is "0".

## [Serial I/O 1 Status Register] SIO1STS (001916)

The read-only serial I/O1 status register consists of seven flags (b0 to b6) which indicate the operating status of the serial I/O1 function and various errors. Three of the flags (b4 to b6) are only valid in UART mode. The receive buffer full flag (b1) is cleared to "0" when the receive buffer is read.

The error detection is performed at the same time data is transferred from the receive shift register to the receive buffer register, and the receive buffer full flag is set. A writing to the serial I/O1 status register clears all the error flags OE, PE, FE, and SE (b3 to b6, respectively). Writing "0" to the serial I/O1 enable bit (SIOE: b7 of the serial I/O1 control register) also clears all the status flags, including the error flags.

All bits of the serial I/O1 status register are initialized to "0" at reset, but if the transmit enable bit (b4) of the serial I/O1 control register has been set to "1", the transmit shift register shift completion flag (b2) and the transmit buffer empty flag (b0) become "1."

## [Serial I/O1 Control Register] SIO1CON (001A16)

The serial I/O1 control register contains eight control bits for serial I/O1 functions.

### [UART Control Register] UARTCON (001B16)

The UART control register consists of four control bits (b0 to b3) which are valid when asynchronous serial I/O is selected and set the data format of an data transfer. One bit in this register (b4) is always valid and sets the output structure of the P45/TxD pin.

#### [Baud Rate Generator] BRG (001C<sub>16</sub>)

The baud rate generator determines the baud rate for serial transfer. With the 8-bit counter having a reload register the baud rate generator divides the frequency of the count source by 1/(n+1), where n is the value written to the baud rate generator.



Fig. 39. Structure of serial I/O1 related register

## **FUNCTIONAL DESCRIPTION**

#### Serial I/O2

The serial I/O2 can be operated only as the clock synchronous type. As a synchronous clock for serial transfer, either internal clock or external clock can be selected by the serial I/O2 synchronous clock selection bit (b6) of serial I/O2 control register 1.

The internal clock incorporates a dedicated divider and permits selecting 6 types of clock by the internal synchronous clock selection bit (b2, b1, b0) of serial I/O2 control register 1.

Regarding Sout2 and Sclk2 being output pins, either CMOS output format or N-channel open-drain output format can be selected by the P71/Sout2, P72/Sclk2 P-channel output disable bit (b7) of serial I/O2 control register 1.

When the internal clock has been selected, a transfer starts by a write signal to the serial I/O2 register (address 001F<sub>16</sub>). After completion of data transfer, the level of the Soutz pin goes to high impedance automatically but bit 7 of the serial I/O2 control register 2 is not set to "1" automatically.

When the external clock has been selected, the contents of the serial I/O2 register is continuously sifted while transfer clocks are input. Accordingly, control the clock externally. Note that the Soute pin does not go to high impedance after completion of data transfer.

To cause the Sout2 pin to go to high impedance in the case where the external clock is selected, set bit 7 of the serial I/O2 control register 2 to "1" when Sclk2 is "H" after completion of data transfer. After the next data transfer is started (the transfer clock falls), bit 7 of the serial I/O2 control register 2 is set to "0" and the Sout2 pin is put into the active state.

Regardless of the internal clock to external clock, the interrupt request bit is set after the number of bits (1 to 8 bits) selected by the optional transfer bit is transferred. In case of a fractional number of bits less than 8 bits as the last data, the received data to be stored in the serial I/O2 register becomes a fractional number of bits close to MSB if the transfer direction selection bit of serial I/O2 control register 1 is LSB first, or a fractional number of bits close to LSB if the said bit is MSB first. For the remaining bits, the previously received data is shifted.

At transmit operation using the clock synchronous serial I/O, the SCMP2 signal can be output by comparing the state of the transmit pin SOUT2 with the state of the receive pin SIN2 in synchronization with a rise of the transfer clock. If the output level of the SOUT2 pin is equal to the input level to the SIN2 pin, "L" is output from the SCMP2 pin. If not, "H" is output. At this time, an INT2 interrupt request can also be generated. Select a valid edge by bit 2 of the interrupt edge selection register (address 003A16).

## [Serial I/O2 Control Registers 1, 2] SIO2CON1 / SIO2CON2

The serial I/O2 control registers 1 and 2 are containing various selection bits for serial I/O2 control as shown in Figure 40.



Fig. 40. Structure of Serial I/O2 control registers 1, 2



Fig. 41. Block diagram of Serial I/O2



Fig. 42. Timing chart of Serial I/O2



Fig. 43. ScMP2 output operation

## **A-D Converter**

### [A-D Conversion Register] AD (address 003516)

The A-D conversion register is a read-only register that contains the result of an A-D conversion. When reading this register during an A-D conversion, the previous conversion result is read.

## [A-D Control Register] ADCON

The A-D control register controls the A-D conversion process. Bits 0 to 3 of this register select specific analog input pins. Bit 4 signals the completion of an A-D conversion. The value of this bit remains at "0" during an A-D conversion, then changes to "1" when the A-D conversion is completed. Writing "0" to this bit starts the A-D conversion. When bit 6, which is the AD external trigger valid bit, is set to "1", this bit enables A-D conversion at a falling edge of an ADT input. Set ports which is also used as ADT pins to input when using an A-D external trigger. Bit 5 is the ADVREF input switch bit. Writing "1" to this bit, this bit always causes ADVREF connection. Writing "0" to this bit causes ADVREF connection only during A-D conversion and cut off when A-D conversion is completed.

### [Comparison Voltage Generator]

The comparison voltage generator divides the voltage between AVss and ADVREF by 256, and outputs the divided voltages.

### [Channel Selector]

The channel selector selects one of the input ports  $AN_{12}$  to  $AN_{0}$  and inputs it to the comparator.

#### [Comparator and Control Circuit]

The comparator and control circuit compares an analog input voltage with the comparison voltage and stores the result in the A-D conversion register. When an A-D conversion is completed, the control circuit sets the AD conversion completion bit and the AD conversion interrupt request bit to "1."

Note that the comparator is constructed linked to a capacitor, so set

f(XIN) to at least 500kHz during A-D conversion. Use a CPU system clock dividing the main clock XIN as the internal clock  $\phi$ .

#### ■Note

When the A-D external trigger is invalidated by the AD external trigger valid bit, any interrupt request is not generated at a fall of the ADT input. When the AD external trigger valid bit is set to "1" beforehand, A-D conversion is not started by writing "0" into the AD conversion completion bit and "0" is not written into the AD conversion completion bit. Do not set "0" in the AD conversion completion bit concurrently with the timing at which the AD external trigger valid bit is rewritten. Put an interval of at least 50 cycles to more of the internal clock  $\phi$  between a start of A-D conversion and the next start of A-D conversion.



Fig. 44. Structure of A-D control register



Fig. 45. Block diagram of A-D converter

## **FUNCTIONAL DESCRIPTION**

## **D-A Converter**

The 3807 group has an on-chip D-A converter with 8-bit resolution and 4 channels (DAi (i=1—4)). The D-A converter is performed by setting the value in the D-A conversion register. The result of D-A converter is output from DAi pin by setting the DAi output enable bits to "1." When using the D-A converter, the corresponding port direction register bit (P65/DAVREF/AN10, P56/DA1, P57/DA2, P80/DA3/AN11, P81/DA4/AN12) should be set to "0" (input status).

The output analog voltage V is determined by the value n (base 10) in the D-A conversion register as follows:

V=DAVREF x n/256 (n=0 to 255) Where DAVREF is the reference voltage.

At reset, the D-A conversion registers are cleared to "0016", the DAi output enable bits are cleared to "0", and DAi pin is set to input (high impedance). The DA output is not buffered, so connect an external buffer when driving a low-impedance load.



Fig. 46. Structure of D-A control register



Fig. 47. Block diagram of D-A converter



Fig. 48. Equivalent connection circuit of D-A converter

## **Analog Comparator**

An analog comparator circuit which is independent of peripheral circuits in the microcomputer is incorporated (**Note**).

An analog comparator outputs the result of comparison with an input voltage of CMPREF pin which is specified as a reference voltage and an input voltage of CMPIN pin to CMPOUT pin. The result is "1" when the input voltage to port CMPIN is higher than the voltage applied to port CMPREF and "0" when the voltage is lower.

Because the analog comparator consists of an analog MOS circuit, set the input voltage to the CMPIN pin and the CMPREF pin within the following range:

### Vss +1.2 V to CMPVcc-0.5V

### ■Note

The analog comparator circuit is separated from the MCU internal peripheral circuit in the microcomputer. Accordingly, even if the microcomputer runs away, the analog comparator is still in operation. For this reason, the analog comparator can be used for safety circuit design.



Fig. 49. Block diagram of Analog comparator

## **FUNCTIONAL DESCRIPTION**

## **Watchdog Timer**

The watchdog timer gives a mean of returning to the reset status when a program cannot run on a normal loop (for example, because of a software run-away). The watchdog timer consists of an 8-bit watchdog timer L and a 8-bit watchdog timer H.

## Standard operation of watchdog timer

When any data is not written into the watchdog timer control register (address 001716) after resetting, the watchdog timer is in the stop state. The watchdog timer starts to count down by writing an optional value into the watchdog timer control register (address 001716) and an internal resetting takes place at an underflow of the watchdog timer H.

Accordingly, programming is usually performed so that writing to the watchdog timer control register (address 001716) may be started before an underflow. When the watchdog timer control register (address 001716) is read, the values of the 6 high-order bits of the watchdog timer H, STP instruction disable bit, and watchdog timer H count source selection bit are read.

### (1) Initial value of watchdog timer

At reset or writing to the watchdog timer control register (address 0017<sub>16</sub>), each watchdog timer H and L is set to "FF<sub>16</sub>."

## (2) Watchdog timer H count source selection bit operation

Bit 7 of the watchdog timer control register (address 0017<sub>16</sub>) permits selecting a watchdog timer H count source. When this bit is set to "0", the count source becomes the underflow signal of watchdog timer L. The detection time is set then to f(XIN)=131.072 ms at 8 MHz frequency and f(XCIN)=32.768 s at 32 kHz frequency.

When this bit is set to "1", the count source becomes the signal divided by 16 for f(XIN) (or f(XCIN)). The detection time in this case is set to f(XIN)=512  $\mu$ s at 8 MHz frequency and f(XCIN)=128 ms at 32 KHz frequency. This bit is cleared to "0" after resetting.

### (3) Operation of STP instruction disable bit

Bit 6 of the watchdog timer control register (address 0017<sub>16</sub>) permits disabling the STP instruction when the watchdog timer is in operation

When this bit is "0", the STP instruction is enabled.

When this bit is "1", the STP instruction is disabled.

Once the STP instruction is executed, an internal resetting takes place. When this bit is set to "1", it cannot be rewritten to "0" by program. This bit is cleared to "0" after resetting.



Fig. 50. Block diagram of Watchdog timer



Fig. 51. Structure of Watchdog timer control register

# **Clock output function**

The internal clock  $\phi$  can be output from I/O port P34. Control of I/O ports and clock output function can be performed by port P2P3 control register (address 001516).

## (1) I/O ports or clock output function selection

The P34 clock output control bit (b0) of port P2P3 control register selects the I/O port or clock output function. When clock output function is selected, the clock is output regardless of the port P34 direction register settings.

Directly after bit 0 is written to, the port or clock output is switched synchronous to a falling edge of clock frequency selected by the output clock frequency selection bit. When memory expansion mode or microprocessor mode is selected in CPU mode register (b1, b0), clock output is selected on regardless of P34 clock output control bit settings or port P34 direction register settings.

### (2) Selection of output clock frequency

The output clock frequency selection bits (b3, b2, b1) of port P2P3 control register select the output clock frequency.

The output waveform when f(XIN) or f(XCIN) is selected, depends on XIN or XCIN input waveform however; all other output waveform settings have a duty cycle of 50%.



Fig. 52. Structure of Port P2P3 control register



Fig. 53. Block diagram of Clock output function

# **FUNCTIONAL DESCRIPTION**

## **Reset Circuit**

To reset the microcomputer,  $\overline{RESET}$  pin should be held at an "L" level for 2  $\mu s$  or more. Then the  $\overline{RESET}$  pin is returned to an "H" level (the power source voltage should be between 2.7 V and 5.5 V, and the oscillation should be stable), reset is released. After the reset is completed, the program starts from the address contained in address FFFD16 (high-order byte) and address FFFC16 (low-order byte). Make sure that the reset input voltage is less than 0.54 V for Vcc of 2.7 V.



Fig. 54. Reset circuit example



Fig. 55. Reset sequence

|                                      | Address Register contents          |                                        | Address Register contents           |
|--------------------------------------|------------------------------------|----------------------------------------|-------------------------------------|
| (1) Port P0                          | 000016 0016                        | (34) Timer 3                           | 002616 FF16                         |
| (2) Port P0 direction register       | 000116 0016                        | (35) Timer X mode register             | 002716 0016                         |
| (3) Port P1                          | 000216 0016                        | (36) Timer Y mode register             | 002816 0016                         |
| (4) Port P1 direction register       | 000316 0016                        | (37) Timer 123 mode register           | 002916 0016                         |
| (5) Port P2                          | 000416 0016                        | (38) Real time port register 0—7       | 002A <sub>16</sub> 00 <sub>16</sub> |
| (6) Port P2 direction register       | 000516 0016                        | (39) Real time port control register 0 | 002B16 1 0 0 1 0 0 0 0              |
| (7) Port P3                          | 000616 0016                        | (40) Real time port control register 1 | 002C16 1 0 0 0 0                    |
| (8) Port P3 direction register       | 000716 0016                        | R/W pointer                            | -1111                               |
| (9) Port P4                          | 000816 0016                        | Output pointer                         | -1111                               |
| (10) Port P4 direction register      | 000916 0016                        | (41) Real time port control register 2 | 002D16 1 0 0 0 0                    |
| (11) Port P5                         | 000A16 0016                        | R/W pointer                            | -1111                               |
| (12) Port P5 direction register      | 000B16 0016                        | Output pointer                         | -1111                               |
| (13) Port P6                         | 000C16 0016                        | (42) Real time port control register 3 | 002E16 0016                         |
| (14) Port P6 direction register      | 000D16 0016                        | (43) Timer A (low-order)               | 002F16 FF16                         |
| (15) Port P7                         | 000E16 0016                        | (44) Timer A (high-order)              | 003016 FF16                         |
| (16) Port P7 direction register      | 000F16 0016                        | (45) Timer B (low-order)               | 0031 <sub>16</sub> FF <sub>16</sub> |
| (17) Port P8                         | 001016 0016                        | (46) Timer B (high-order)              | 003216 FF16                         |
| (18) Port P8 direction register      | 001116 0016                        | (47) D-A control register              | 003316 0016                         |
| (19) Timer XY control register       | 001416 0 0 0 0 0 0 1 1             | (48) A-D control register              | 003416 0 0 0 1 0 0 0                |
| (20) Port P2P3 control register      | 001516 * 0 0 0 0 0 0               | (49) D-A1 conversion register          | 003616 0016                         |
| (21) Pull-up control register        | 001616 0016                        | (50) D-A2 conversion register          | 003716 0016                         |
| (22) Watchdog timer control register | 001716 0 0 1 1 1 1 1 1             | (51) D-A3 conversion register          | 003816 0016                         |
| (23) Serial I/O1 status register     | 001916 1 0 0 0 0 0 0 0             | (52) D-A4 conversion register          | 003916 0016                         |
| (24) Serial I/O1 control register    | 001A16 0016                        | (53) Interrupt edge selection register | 003A <sub>16</sub> 00 <sub>16</sub> |
| (25) UART control register           | 001B <sub>16</sub> 1 1 1 0 0 0 0 0 | (54) CPU mode register                 | 003B <sub>16</sub> 0 1 0 0 1 0 * 0  |
| (26) Serial I/O2 control register 1  | 001D16 0016                        | (55) Interrupt request register 1      | 003C <sub>16</sub> 00 <sub>16</sub> |
| (27) Serial I/O2 control register 2  | 001E16 0 0 0 0 0 1 1 1             | (56) Interrupt request register 2      | 003D16 0016                         |
| (28) Timer X (low-order)             | 002016 FF16                        | (57) Interrupt control register 1      | 003E <sub>16</sub> 00 <sub>16</sub> |
| (29) Timer X (high-order)            | 002116 FF16                        | (58) Interrupt control register 2      | 003F16 0016                         |
| (30) Timer Y (low-order)             | 002216 FF16                        | (59) Processor status register         | (PS) x x x x x 1 x >                |
| (31) Timer Y (high-order)            | 002316 FF16                        | (60) Program counter                   | (PCH) FFFD16 contents               |
| (32) Timer 1                         | 002416 FF16                        |                                        | (PCL) FFFC16 contents               |
| (33) Timer 2                         | 002516 0116                        |                                        |                                     |

Fig. 56. Internal status at reset

## **FUNCTIONAL DESCRIPTION**

# **Clock Generating Circuit**

The 3807 group has two built-in oscillation circuits. An oscillation circuit can be formed by connecting a resonator between XIN and XOUT (XCIN and XCOUT). Use the circuit constants in accordance with the resonator manufacturer's recommended values. No external resistor is needed between XIN and XOUT since a feed-back resistor exists on-chip. However, an external feed-back resistor is needed between XCIN and XCOUT.

Immediately after poweron, only the XIN oscillation circuit starts oscillating, and XCIN and XCOUT pins function as I/O ports.

### •Frequency control

#### (1) Middle-speed mode

The internal clock  $\phi$  is the frequency of XIN divided by 8. After reset, this mode is selected.

## (2) High-speed mode

The internal clock  $\phi$  is half the frequency of X<sub>IN</sub>.

### (3) Low-speed mode

The internal clock  $\phi$  is half the frequency of Xcin.

#### ■Note

If you switch the mode between middle/high-speed and low-speed, stabilize both XIN and XCIN oscillations. The sufficient time is required for the sub clock to stabilize, especially immediately after poweron and at returning from stop mode. When switching the mode between middle/high-speed and low-speed, set the frequency on condition that f(XIN) > 3f(XCIN).

### (4) Low power consumption mode

The low power consumption operation can be realized by stopping the main clock XIN in low-speed mode. To stop the main clock, set bit 5 of the CPU mode register to "1." When the main clock XIN is restarted (by setting the main clock stop bit to "0"), set enough time for oscillation to stabilize.

By clearing furthermore the Xcout drivability selection bit (b3) of CPU mode register to "0", low power consumption operation of less than  $55~\mu\text{A}$  (Vcc=3 V, Xcin=32 kHz) can be realized by reducing the drivability between Xcin and Xcout. At reset or during STP instruction execution this bit is set to "1" and a reduced drivability that has an easy oscillation start is set. The sub-clock Xcin-Xcout oscillating circuit can not directly input clocks that are generated externally. Accordingly, make sure to cause an external resonator to oscillate.

# ●Oscillation control

## (1) Stop mode

If the STP instruction is executed, the internal clock  $\phi$  stops at an "H" level, and XIN and XCIN oscillators stop. Timer 1 is set to "FF16" and timer 2 is set to "0116."

Either XIN or XCIN divided by 16 is input to timer 1 as count source, and the output of timer 1 is connected to timer 2. The bits of the timer 123 mode register except timer 3 count source selection bit (b4) are cleared to "0". Set the timer 2/INT3 interrupt source bit to "1" and timer 1/INT2 as well as timer 2/INT3 interrupt enable bit to disabled ("0") before executing the STP instruction. Oscillator restarts when an external interrupt is received, but the internal clock  $\phi$  is not sup-

plied to the CPU (remains at "H") until timer 2 underflows. This allows time for the clock circuit oscillation to stabilize. The internal clock  $\phi$  is supplied for the first time, when timer 2 underflows. Therefore make sure not to set the timer 2/INT3 interrupt request bit to "1" before the STP instruction stops the oscillator. When the oscillator is restarted by reset apply "L" level to port  $\overline{\text{RESET}}$  until the oscillation is stable since a wait time will not be generated.

#### (2) Wait mode

If the WIT instruction is executed, the internal clock  $\phi$  stops at an "H" level. The states of XIN and XCIN are the same as the state before executing the WIT instruction. The internal clock restarts at reset or when an interrupt is received. Since the oscillator does not stop, normal operation can be started immediately after the clock is restarted.



Fig. 57. Ceramic resonator circuit



Fig. 58. External clock input circuit



Fig. 59. System clock generating circuit block diagram (Single-chip mode)

# **FUNCTIONAL DESCRIPTION**



Fig. 60. State transitions of system clock

# **FUNCTIONAL DESCRIPTION**

#### **Processor Mode**

Single-chip mode, memory expansion mode, and microprocessor mode can be selected by changing the contents of the processor mode bits (CMo and CM1: b1 and b0 of address 003B16). In memory expansion mode and microprocessor mode, memory can be expanded externally through ports P0 to P3. In these modes, ports P0 to P3 lose their I/O port functions and become bus pins.

Table. 9. Port functions in memory expansion mode and microprocessor mode

| Port Name | Function                                           |
|-----------|----------------------------------------------------|
| Port P0   | Outputs 8-bits low-order byte of address.          |
| Port P1   | Outputs 8-bits high-order byte of address.         |
| Port P2   | Operates as I/O pins for data D7 to D0             |
|           | (including instruction code)                       |
| Port P3   | P3o and P31 function only as output pins           |
|           | (except that the port latch cannot be read).       |
|           | P32 is the ONW input pin.                          |
|           | P33 is the RESTout output pin. (Note)              |
|           | P34 is the $\phi$ output pin.                      |
|           | P35 is the SYNC output pin.                        |
|           | P36 is the WR output pin, and P37 is the RD output |
|           | pin.                                               |

Note: If CNVss is connected to Vss, the microcomputer goes to single-chip mode after a reset, so this pin cannot be used as the RESETou⊤ output pin.

#### (1) Single-chip mode

Select this mode by resetting the microcomputer with CNVss connected to Vss.

#### (2) Memory expansion mode

Select this mode by setting the processor mode bits (b1, b0) to "01" in software with CNVss connected to Vss. This mode enables external memory expansion while maintaining the validity of the internal ROM. However, some I/O devices will not support the memory expansion mode. Internal ROM will take precedence over external memory if addresses conflict.

#### (3) Microprocessor mode

Select this mode by resetting the microcomputer with CNVss connected to Vcc, or by setting the processor mode bits to "10" in software with CNVss connected to Vss. In microprocessor mode, the internal ROM is no longer valid and external memory must be used.



Fig. 61. Memory maps in various processor modes



Fig. 62. Structure of CPU mode register

# **HARDWARE**

# **FUNCTIONAL DESCRIPTION**

#### Bus control at memory expansion

The 3807 group has a built-in  $\overline{\text{ONW}}$  function to facilitate access to external (expanded) memory and I/O devices in memory expansion mode or microprocessor mode.

If an "L" level signal is input to port  $P32\overline{/ONW}$  when the CPU is in a read or write state, the corresponding read or write cycle is extended by one cycle of  $\phi$ . During this extended period, the  $\overline{RD}$  or  $\overline{WR}$  signal remains at "L". This extension function is valid only for writing to and reading from addresses 000016 to 000716 and 084016 to FFFF16, and only read and write cycles are extended.



Fig. 63. ONW function timing

### **NOTES ON PROGRAMMING**

# NOTES ON PROGRAMMING Processor Status Register

The contents of the processor status register (PS) after a reset are undefined, except for the interrupt disable flag (I) which is "1." After a reset, initialize flags which affect program execution. In particular, it is essential to initialize the index X mode (T) and the decimal mode (D) flags because of their effect on calculations.

#### Interrupts

The contents of the interrupt request bits do not change immediately after they have been written. After writing to an interrupt request register, execute at least one instruction before performing a BBC or BBS instruction.

#### **Decimal Calculations**

- •To calculate in decimal notation, set the decimal mode flag (D) to "1", then execute an ADC or SBC instruction. Only the ADC and SBC instructions yield proper decimal results. After executing an ADC or SBC instruction, execute at least one instruction before executing a SEC, CLC, or CLD instruction.
- •In decimal mode, the values of the negative (N), overflow (V), and zero (Z) flags are invalid.

#### **Timers**

If a value n (between 0 and 255) is written to a timer latch, the frequency division ratio is 1/(n+1).

# **Multiplication and Division Instructions**

- •The index X mode (T) and the decimal mode (D) flags do not affect the MUL and DIV instruction.
- •The execution of these instructions does not change the contents of the processor status register.

#### **Ports**

The contents of the port direction registers cannot be read. The following cannot be used:

- •The data transfer instruction (LDA, etc.)
- •The operation instruction when the index X mode flag (T) is "1"
- The addressing mode which uses the value of a direction register as an index
- •The bit-test instruction (BBC or BBS, etc.) to a direction register
- •The read-modify-write instructions (ROR, CLB, or SEB, etc.) to a direction register.

Use instructions such as LDM and STA, etc., to set the port direction registers.

#### Serial I/O

In clock synchronous serial I/O, if the receive side is using an external clock and it is to output the SRDY1 signal, set the transmit enable bit, the receive enable bit, and the SRDY1 output enable bit to "1."

Serial I/O1 continues to output the final bit from the TxD pin after transmission is completed. Sout pin for serial I/O2 goes to high impedance after transfer is completed.

When in serial I/O1 (clock-synchronous mode) or in serial I/O2 an external clock is used as synchronous clock, write transmission data to both the transmit buffer register and serial I/O2 register, during transfer clock is "H."

#### **A-D Converter**

The comparator uses internal capacitors whose charge will be lost if the clock frequency is too low.

Therefore, make sure that f(XIN) is at least on 500 kHz during an A-D conversion. (When the  $\overline{ONW}$  pin has been set to "L", the A-D conversion will take twice as long to match the longer bus cycle, and so f(XIN) must be at least 1 MHz.)

Do not execute the STP or WIT instruction during an A-D conversion.

#### **D-A Converter**

The accuracy of the D-A converter becomes rapidly poor under the Vcc = 4.0~V or less condition; a supply voltage of Vcc  $\geq 4.0~V$  is recommended. When a D-A converter is not used, set all values of D-Ai conversion registers (i=1 to 4) to "0016."

#### **Instruction Execution Time**

The instruction execution time is obtained by multiplying the frequency of the internal clock  $\phi$  by the number of cycles needed to execute an instruction.

The number of cycles required to execute an instruction is shown in the list of machine instructions.

The frequency of the internal clock  $\phi$  is half of the XIN frequency in high-speed mode.

When the  $\overline{\text{ONW}}$  function is used in modes other than single-chip mode, the frequency of the internal clock  $\phi$  may be one fourth of the XIN frequency.

# **HARDWARE**

#### **NOTES ON USAGE**

# NOTES ON USAGE Handling of Source Pins

In order to avoid a latch-up occurrence, connect a capacitor suitable for high frequencies as bypass capacitor between power source pin (Vcc pin) and GND pin (Vss pin) and between power source pin (Vcc pin) and analog power source input pin (AVss pin). Besides, connect the capacitor to as close as possible. For bypass capacitor which should not be located too far from the pins to be connected, a ceramic capacitor of 0.01  $\mu\text{F}$ —0.1  $\mu\text{F}$  is recommended.

#### P34 clock output function

In the case of using an I/O port P34 as a clock output function, note the following: when an output clock frequency is changed during outputting a clock, the port may feed a noise having a shorter pulse width than the standard at the switch timing. Besides, it also may happen at the timing for switching the low-speed mode to the middle/high-speed mode.

#### Timer X and timer Y

In the pulse period measurement mode or the pulse width measurement mode for timers X and Y, set the "L" or "H" pulse width of input signal from CNTR<sub>0</sub>/CNTR<sub>1</sub> pin to 2 cycles or more of a timer count source.

#### **EPROM version/One Time PROM version**

The CNVss pin is connected to the internal memory circuit block by a low-ohmic resistance, since it has the multiplexed function to be a programmable power source pin (VPP pin) as well.

To improve the noise reduction, connect a track between CNVss pin and Vss pin or Vcc pin with 1 to 10 k $\Omega$  resistance.

The mask ROM version track of port CNVss has no operational interference even if it is connected via a resistor.

# DATA REQUIRED FOR MASK ORDERS/ROM PROGRAMMING METHOD

# DATA REQUIRED FOR MASK ORDERS

The following are necessary when ordering a mask ROM production:

- (1) Mask ROM Order Confirmation Form
- (2) Mark Specification Form
- (3) Data to be written to ROM, in EPROM form (three identical copies)

#### **ROM PROGRAMMING METHOD**

The built-in PROM of the blank One Time PROM version and built-in EPROM version can be read or programmed with a general purpose PROM programmer using a special programming adapter. Set the address of PROM programmer in the user ROM area.

Table. 10. Special programming adapter

| Package | Name of Programming Adapter |
|---------|-----------------------------|
| 80P6N-A | PCA4738F-80A                |
| 80D0    | PCA4738L-80A                |

The PROM of the blank One Time PROM version is not tested or screened in the assembly process and following processes. To ensure proper operation after programming, the procedure shown in Figure 64 is recommended to verify programming.



Fig. 64. Programming and testing of One Time PROM version

# **HARDWARE**

# **FUNCTIONAL DESCRIPTION SUPPLEMENT**

# FUNCTIONAL DESCRIPTION SUPPLEMENT

# Interrupt

3807 group permits interrupts on the basis of 16 sources. It is vector interrupts with a fixed priority system. Accordingly, when two or more interrupt

requests occur during the same sampling, the higherpriority interrupt is accepted first. This priority is determined by hardware, but variety of priority processing can be performed by software, using an interrupt enable bit and an interrupt disable flag. For interrupt sources, vector addresses and interrupt priority, refer to "Table 11."

Table 11. Interrupt sources, vector addresses and interrupt priority

| Deignitus | Interrupt sources              | Vector addresses |           | Domarka                                    |
|-----------|--------------------------------|------------------|-----------|--------------------------------------------|
| Priority  |                                | High-order       | Low-order | Remarks                                    |
| 1         | Reset (Note)                   | FFFD16           | FFFC16    | Non-maskable                               |
| 2         | INTo interrupt                 | FFFB16           | FFFA16    | External interrupt                         |
|           |                                |                  | !<br>!    | (active edge selectable)                   |
| 3         | INT1 interrupt                 | FFF916           | FFF816    | External interrupt                         |
|           |                                |                  | <br>      | (active edge selectable)                   |
| 4         | Serial I/O1 receive interrupt  | FFF716           | FFF616    | Valid when serial I/O1 is selected         |
| 5         | Serial I/O1 transmit interrupt | FFF516           | FFF416    | Valid when serial I/O1 is selected         |
| 6         | Timer X interrupt              | FFF316           | FFF216    |                                            |
| 7         | Timer Y interrupt              | FFF116           | FFF016    |                                            |
| 8         | INT3 interrupt                 | FFEF16           | FFEE16    | External interrupt(active edge selectable) |
|           |                                |                  | <br>      | Valid when INT3 interrupt is selected      |
|           | Timer 2 interrupt              |                  | <br>      | Valid when timer 2 interrupt is selected   |
| 9         | INT4 interrupt                 | FFED16           | FFEC16    | External interrupt(active edge selectable) |
|           |                                |                  | 1         | Valid when INT4 interrupt is selected      |
|           | Timer 3 interrupt              |                  | İ         | Valid when timer 3 interrupt is selected   |
| 10        | CNTRo interrupt                | FFEB16           | FFEA16    | External interrupt                         |
|           |                                |                  | I<br>I    | (active edge selectable)                   |
| 11        | CNTR1 interrupt                | FFE916           | FFE816    | External interrupt                         |
|           |                                |                  | <br>      | (active edge selectable)                   |
| 12        | Serial I/O2 interrupt          | FFE716           | FFE616    | Valid when serial I/O2 is selected         |
| 13        | INT2 interrupt                 | FFE516           | FFE416    | External interrupt(active edge selectable) |
|           |                                |                  | I<br>I    | Valid when INT2 interrupt is selected      |
|           | Timer 1 interrupt              |                  |           | Valid when timer 1 interrupt is selected   |
| 14        | Timer A interrupt              | FFE316           | FFE216    |                                            |
| 15        | Timer B interrupt              | FFE116           | FFE016    |                                            |
| 16        | A-D conversion interrupt       | FFDF16           | FFDE16    | Valid when A-D interrupt is selected       |
|           | ADT interrupt                  |                  | <br>      | External interrupt(only at falling edge)   |
|           |                                |                  | 1<br>1    | Valid when ADT interrupt and A-D external  |
|           |                                |                  | I<br>I    | trigger valid are selected                 |
| 17        | BRK instruction interrupt      | FFDD16           | FFDC16    | Non-maskable software interrupt            |

Note: Reset functions in the same way as an interrupt with the highest priority.

# **FUNCTIONAL DESCRIPTION SUPPLEMENT**

#### **Timing After Interrupt**

The interrupt processing routine begins with the machine cycle following the completion of the instruction that is currently in execution.

Figure 65 shows a timing chart after an interrupt occurs, and Figure 66 shows the time up to execution of the interrupt processing routine.



Fig. 65 Timing chart after an interrupt occurs



Fig. 66 Time up to execution of the interrupt processing routine

# **FUNCTIONAL DESCRIPTION SUPPLEMENT**

#### **A-D Converter**

A-D conversion is started by setting AD conversion completion bit to "0." During A-D conversion, internal operations are performed as follows.

- 1. After the start of A-D conversion, A-D conversion register goes to "0016."
- 2. The highest-order bit of A-D conversion register is set to "1," and the comparison voltage Vref is input to the comparator. Then, Vref is compared with analog input voltage VIN.
- As a result of comparison, when Vref < VIN, the highest-order bit of A-D conversion register be comes "1." When Vref > VIN, the highest-order bit becomes "0."

By repeating the above operations up to the lowestorder bit of the A-D conversion register, an analog value converts into a digital value.

A-D conversion completes at 50 clock cycles (12.5  $\mu$ s at f(XIN) = 8.0 MHz) after it is started, and the result of the conversion is stored into the A-D conversion register.

Concurrently with the completion of A-D conversion, A-D conversion interrupt request occurs, so that the AD conversion interrupt request bit is set to "1."

Relative formula for a reference voltage VREF of A-D converter and Vref

When n = 0 Vref = 0

When n = 1 to 255  $Vref = \frac{VREF}{256} \times (n - 0.5)$ 

n: the value of A-D converter (decimal numeral)

Table 12. Change of A-D conversion register during A-D conversion

|                                       | Change of A-D conversion register                                           | Value of comparison voltage (Vref)                                          |
|---------------------------------------|-----------------------------------------------------------------------------|-----------------------------------------------------------------------------|
| At start of conversion                | 0 0 0 0 0 0 0 0                                                             | 0                                                                           |
| First comparison                      | 1 0 0 0 0 0 0 0                                                             | $\frac{\text{VREF}}{2} - \frac{\text{VREF}}{512}$                           |
| Second comparison                     | * 1 1 0 0 0 0 0 0                                                           | $\frac{\text{VREF}}{2} \pm \frac{\text{VREF}}{4} - \frac{\text{VREF}}{512}$ |
| Third comparison                      | *1*2 1 0 0 0 0 0                                                            | $\frac{VREF}{2} \pm \frac{VREF}{4} \pm \frac{VREF}{8} - \frac{VREF}{512}$   |
|                                       | <del>\</del>                                                                | <b>₩</b>                                                                    |
| After completion of eighth comparison | A result of A-D conversion    * 1   * 2   * 3   * 4   * 5   * 6   * 7   * 8 |                                                                             |

\*1: A result of the first comparison

\*3: A result of the third comparison

**\*5:** A result of the fifth comparison

\*7: A result of the seventh comparison

\*2: A result of the second comparison

\*4: A result of the fourth comparison

\*6: A result of the sixth comparison

\*8: A result of the eighth comparison

Figures 67 shows A-D conversion equivalent circuit, and Figure 68 shows A-D conversion timing chart.



Fig. 67 A-D conversion equivalent circuit



Fig. 68 A-D conversion timing chart

# CHAPTER 2 APPLICATION

- 2.1 I/O port
- 2.2 Timer
- 2.3 Serial I/O
- 2.4 Real time output port
- 2.5 A-D converter
- 2.6 Reset
- 2.7 Application circuit example

# 2.1 I/O port

# 2.1 I/O port

# 2.1.1 Memory map of I/O port



Fig. 2.1.1 Memory map of I/O port related registers

# 2.1.2 Related registers



Fig. 2.1.2 Structure of Port Pi (i = 0, 1, 2, 3, 4, 5, 7, 8)



Fig. 2.1.3 Structure of Port Pi direction register (i = 0, 1, 2, 3, 4, 5, 7, 8)

# **APPLICATION**

# 2.1 I/O port



Fig. 2.1.4 Structure of Port P6



Fig. 2.1.5 Structure of Port P6 direction register

# 2.1.3 Handling of unused pins

Table 2.1.1 Handling of unused pins (in single-chip mode)

| Name of Pins/Ports                 | Handling                                                  |
|------------------------------------|-----------------------------------------------------------|
| P0, P1, P2, P3, P4, P5, P6, P7, P8 | Set to the input mode and connect to Vcc or Vss through a |
|                                    | resistor of 1 k $\Omega$ to 10 k $\Omega$ .               |
|                                    | Set to the output mode and open at "L" or "H."            |
| ADVREF                             | Connect to Vss(GND) or open.                              |
| AVss                               | Connect to Vss(GND).                                      |
| CMPVcc                             | Connect to Vss(GND).                                      |
| СМРоит                             | Open                                                      |
| Xout                               | Open (only when using external clock).                    |

Table 2.1.2 Handling of unused pins (in memory expansion mode and microprocessor mode)

| Name of Pins/Ports | Handling                                                                                                |  |
|--------------------|---------------------------------------------------------------------------------------------------------|--|
| P30, P31           | Open                                                                                                    |  |
| P4, P5, P6, P7, P8 | • Set to the input mode and connect to VCC or Vss through a resistor of 1 k $\Omega$ to 10 k $\Omega$ . |  |
|                    | Set to the output mode and open at "L" or "H."                                                          |  |
| ADVREF             | Connect to Vss(GND) or open.                                                                            |  |
| ŌNW                | Connect to Vcc through a resistor of 1 k $\Omega$ to 10 k $\Omega$ .                                    |  |
| RESETOUT           | Open                                                                                                    |  |
| ф                  | Open                                                                                                    |  |
| SYNC               | Open                                                                                                    |  |
| AVss               | Connect to Vss(GND).                                                                                    |  |
| CMPVcc             | Connect to Vss(GND).                                                                                    |  |
| СМРоит             | Open                                                                                                    |  |
| Хоит               | Open (only when using external clock).                                                                  |  |

# 2.2 Timer

## 2.2.1 Memory map of timer



Fig. 2.2.1 Memory map of timer related registers

# 2.2.2 Related registers



Fig. 2.2.2 Structure of Timer XY control register



Fig. 2.2.3 Structure of Timer X Low-order, Timer X High-order, Timer Y Low-order, Timer Y High-order

# **APPLICATION**



Fig. 2.2.4 Structure of Timer 1, Timer 3



Fig. 2.2.5 Structure of Timer 2



Fig. 2.2.6 Structure of Timer X mode register



Fig. 2.2.7 Structure of Timer Y mode register

# **APPLICATION**

Table. 2.2.1 Function of CNTR<sub>0</sub>/CNTR<sub>1</sub> active edge switch bit

| Operating mode of                | Function of CNTRo/CNTR1 edge switch bit                        |                                                                                                      |  |  |
|----------------------------------|----------------------------------------------------------------|------------------------------------------------------------------------------------------------------|--|--|
| Timer X/Timer Y                  | (bit 5 of each address 27 <sub>16</sub> and 28 <sub>16</sub> ) |                                                                                                      |  |  |
| Timer mode                       | "0"                                                            | Generation of CNTR <sub>0</sub> /CNTR <sub>1</sub> interrupt request : Falling edge                  |  |  |
|                                  |                                                                | (No effect on timer count)                                                                           |  |  |
|                                  | "1"                                                            | <ul> <li>Generation of CNTR<sub>0</sub>/CNTR<sub>1</sub> interrupt request: Rising edge</li> </ul>   |  |  |
|                                  | 1                                                              | (No effect on timer count)                                                                           |  |  |
| Event counter mode               | "0"                                                            | <ul> <li>Timer X/Timer Y : Count at rising edge</li> </ul>                                           |  |  |
|                                  |                                                                | <ul> <li>Generation of CNTR<sub>0</sub>/CNTR<sub>1</sub> interrupt request : Falling edge</li> </ul> |  |  |
|                                  | "1"                                                            | Timer X/Timer Y : Count at falling edge                                                              |  |  |
|                                  |                                                                | Generation of CNTR <sub>0</sub> /CNTR <sub>1</sub> interrupt request : Rising edge                   |  |  |
| Pulse output mode                | "0"                                                            | <ul> <li>Start of pulse output : From "H" level</li> </ul>                                           |  |  |
|                                  | U                                                              | Generation of CNTR0/CNTR1 interrupt request : Falling edge                                           |  |  |
|                                  | "1"                                                            | <ul> <li>Start of pulse output : From "L" level</li> </ul>                                           |  |  |
|                                  |                                                                | Generation of CNTR <sub>0</sub> /CNTR <sub>1</sub> interrupt request : Rising edge                   |  |  |
| Pulse period measurement mode    |                                                                | <ul> <li>Timer X/Timer Y: Measurement of a period between a falling</li> </ul>                       |  |  |
|                                  | "0"                                                            | edge and the next falling edge                                                                       |  |  |
|                                  |                                                                | Generation of CNTR0/CNTR1 interrupt request : Falling edge                                           |  |  |
|                                  |                                                                | <ul> <li>Timer X/Timer Y: Measurement of a period between a rising</li> </ul>                        |  |  |
|                                  | "1"                                                            | edge and the next rising edge                                                                        |  |  |
|                                  |                                                                | Generation of CNTR0/CNTR1 interrupt request : Rising edge                                            |  |  |
| Pulse width measurement mode     | "0"                                                            | <ul> <li>Timer X/Timer Y: Measurement of "H" level width</li> </ul>                                  |  |  |
|                                  |                                                                | Generation of CNTR0/CNTR1 interrupt request : Falling edge                                           |  |  |
|                                  | "1"                                                            | <ul> <li>Timer X/Timer Y: Measurement of "L" level width</li> </ul>                                  |  |  |
|                                  | '                                                              | Generation of CNTR0/CNTR1 interrupt request : Rising edge                                            |  |  |
| Programmable one-shot generation | on<br>"0"                                                      | <ul> <li>Timer X/Timer Y: Start of a pulse output at "L" level, and</li> </ul>                       |  |  |
| mode                             |                                                                | output of an one-shot "H" level pulse                                                                |  |  |
|                                  |                                                                | Generation of CNTR0/CNTR1 interrupt request : Falling edge                                           |  |  |
|                                  |                                                                | <ul> <li>Timer X/Timer Y: Start of a pulse output at "H" level, and</li> </ul>                       |  |  |
|                                  | "1"                                                            | output of an one-shot "L" level pulse                                                                |  |  |
|                                  |                                                                | <ul> <li>Generation of CNTR<sub>0</sub>/CNTR<sub>1</sub> interrupt request : Rising edge</li> </ul>  |  |  |



Fig. 2.2.8 Structure of Timer 123 mode register



Fig. 2.2.9 Structure of Interrupt edge selection register



Fig. 2.2.10 Structure of Interrupt request register 1



Fig. 2.2.11 Structure of Interrupt request register 2



Fig. 2.2.12 Structure of Interrupt control register 1



Fig. 2.2.13 Structure of Interrupt control register 2

#### 2.2.3 Timer application examples

#### (1) Basic functions and uses

## [Function 1] Control of Event interval (Timer X, Timer Y, Timer 1, Timer 2, Timer 3)

The Timer count stop bit is set to "0" after setting a count value to a timer. Then a timer interrupt request occurs after a certain period.

#### [Use] • Generation of an output signal timing

Generation of a waiting time

# [Function 2] Control of Cyclic operation (Timer X, Timer Y, Timer 1, Timer 2, Timer 3)

The value of a timer latch is automatically written to a corresponding timer every time a timer underflows, and each cyclic timer interrupt request occurs.

#### [Use] • Generation of cyclic interrupts

- Clock function (measurement of 25m second) → Application example 1
- · Control of a main routine cycle

# [Function 3] Output of Rectangular waveform (Timer X, Timer Y, Timer 2)

The output level of the CNTR pin is inverted every time a timer underflows (Pulse output mode).

#### **[Use]** • A piezoelectric buzzer output → Application example 2

Generation of the remote-control carrier waveforms

#### [Function 4] Count of External pulse (Timer X, Timer Y)

External pulses input to the CNTR pin are selected as a timer count source (Event counter mode).

#### [Use] • Measurement of frequency → Application example 3

- Division of external pulses.
- Generation of interrupts in a cycle based on an external pulse. (count of a reel pulse)

# [Function 5] Measurement of External pulse width (Timer X, Timer Y)

The "H" or "L" level width of external pulses input to CNTR pin is measured (Pulse width measurement mode).

# [Use] • Measurement of external pulse frequency (Measurement of pulse width of FG pulse\* generated by motor) → Application example 4

Measurement of external pulse duty (when the frequency is fixed)

★FG pulse : Pulse used for detecting the motor speed to control the motor speed.

# **APPLICATION**

# 2.2 Timer

# (2) Timer application example 1 : Clock function (measurement of 25 ms)

Outline: The input clock is divided by a timer so that the clock counts up every 25 ms.

**Specifications**: • The clock f(XIN) = 8 MHz is divided by a timer.

• The clock is counted at intervals of 25 ms by the Timer 3 interrupt.

Figure 2.2.14 shows a connection of timers and a setting of division ratios, Figures 2.2.15 show a setting of related registers, and Figure 2.2.16 shows a control procedure.



Fig. 2.2.14 Connection of timers and setting of division ratios [Clock function]



Fig. 2.2.15 Setting of related registers [Clock function]

#### Control procedure:

Figure 2.2.16 shows a control procedure.



Fig. 2.2.16 Control procedure [Clock function]

## (3) Timer application example 2 : Piezoelectric buzzer output

**Outline :** The rectangular waveform output function of a timer is applied for a piezoelectric buzzer output.

- **Specifications**: The rectangular waveform resulting from dividing clock f(XIN) = 8 MHz into about 2 kHz (2049 Hz) is output from the P54/CNTR0 pin.
  - The level of the P54/CNTR0 pin fixes to "H" while a piezoelectric buzzer output is stopped.

Figure 2.2.17 shows an example of a peripheral circuit, and Figure 2.2.18 shows a connection of the timer and setting of the division ratio.



Fig. 2.2.17 Example of a peripheral circuit



Fig. 2.2.18 Connection of the timer and setting of the division ratio [Piezoelectric buzzer output]



Fig. 2.2.19 Setting of related registers [Piezoelectric buzzer output]

# APPLICATION

#### 2.2 Timer

#### Control procedure:

Figure 2.2.20 shows a control procedure.



Fig. 2.2.20 Control procedure [Piezoelectric buzzer output]

#### (4) Timer application example 3: Measurement of frequency

Outline: The following two values are compared for judging if the frequency is within a certain range.

- A value counted a pulse which is input to P55/CNTR1 pin by a timer.
- A referance value

**Specifications:** • The pulse is input to the P55/CNTR1 pin and counted by the Timer Y.

- A count value is read out at the interval of about 2 ms (Timer X interrupt interval). When the count value is 28 to 40, it is regarded the input pulse as a valid.
- Because the timer is a down-counter, the count value is compared with 227 to 215\*.
  - \*227 to 215 = 255 (initialized value of counter) 28 to 40 (the number of valid value).

Figure 2.2.21 shows a method for judging if input pulse exists, and Figure 2.2.22 and Figure 2.2.23 show a setting of related registers.



Fig 2.2.21 A method for judging if input pulse exists



Fig. 2.2.22 Setting of related registers (1) [Measurement of frequency]

# **APPLICATION**



Fig. 2.2.23 Setting of related registers (2) [Measurement of frequency]

#### Control procedure:

Figure 2.2.24 shows a control procedure.



Fig. 2.2.24 Control procedure [Measurement of frequency]

(5) Timer application example 4 : Measurement of pulse width of FG pulse generated by motor

Outline: The "H" level width of a pulse input to the P54/CNTR0 pin is counted by Timer X. An underflow is detected by Timer X interrupt and an end of the input pulse "H" level is detected by CNTR0 interrupt.

**Specifications**: • The "H" level width of FG pulse input to the P54/CNTR0 pin is counted by Timer X.

(Example : When the clock frequency is 8 MHz, the count source would be 2  $\,\mu$ s that is obtained by dividing the clock frequency by 16. Measurement can be made up to 131.072 ms in the range of FFFF16 to 000016.)

Figure 2.2.25 shows a connection of the timer and setting of the division ratio, and Figure 2.2.26 shows a setting of related registers.



Fig. 2.2.25 Connection of the timer and setting of the division ratio [Measurement of pulse width]

#### 2.2 Timer



Fig. 2.2.26 Setting of related registers [Measurement of pulse width]

Figure 2.2.27 and Figure 2.2.28 show a control procedure.



Fig. 2.2.27 Control procedure (1) [Measurement of pulse width]

#### 2.2 Timer



Process it by software in accordance with the necessity.

#### Example

- 1. Be started the Timer X count at "L" level of the CNTRo input signal. (A level of the CNTRo input signal is judged by reading a content of the Port P54 register.)
- 2. Be invalid the first CNTRo interrupt after starting the Timer X count.

#### [When the Timer X count is started at "L" level of the CNTRo input signal]



#### [When the Timer X count is started at "H" level of the CNTRo input signal]



Fig. 2.2.28 Control procedure (2) [Measurement of pulse width]

## 2.3.1 Memory map of serial I/O



Fig. 2.3.1 Memory map of serial I/O related registers

#### 2.3.2 Related registers



Fig. 2.3.2 Structure of Transmit/Receive buffer register



Fig. 2.3.3 Structure of Serial I/O1 status register



Fig. 2.3.4 Structure of Serial I/O1 control register



Fig. 2.3.5 Structure of UART control register



Fig. 2.3.6 Structure of Baud rate generator



Fig. 2.3.7 Structure of Serial I/O2 control register 1



Fig. 2.3.8 Structure of Serial I/O2 control register 2



Fig. 2.3.9 Structure of Serial I/O2 register



Fig. 2.3.10 Structure of Interrupt edge selection register



Fig. 2.3.11 Structure of Interrupt request register 1



Fig. 2.3.12 Structure of Interrupt request register 2

| Interrupt control register<br>b7 b6 b5 b4 b3 b2 b1 b0 | _    |                                               |                                                 |          |   |   |
|-------------------------------------------------------|------|-----------------------------------------------|-------------------------------------------------|----------|---|---|
|                                                       | ] Ir | nterrupt control register 1 (ICON             | 1) [Address: 3E <sub>16</sub> ]                 |          |   |   |
|                                                       | В    | Name                                          | Function                                        | At reset | R | W |
|                                                       | 0    | INT₀ interrupt enable bit                     | 0 : Interrupt disabled 1 : Interrupt enabled    | 0        | 0 | 0 |
|                                                       | _ 1  | INT <sub>1</sub> interrupt enable bit         | 0 : Interrupt disabled 1 : Interrupt enabled    | 0        | 0 | 0 |
|                                                       | . 2  | Serial I/O1 receive interrupt enable bit      | 0 : Interrupt disabled<br>1 : Interrupt enabled | 0        | 0 | 0 |
|                                                       | 3    | Serial I/O1 transmit interrupt enable bit     | 0 : Interrupt disabled 1 : Interrupt enabled    | 0        | 0 | 0 |
|                                                       | 4    | Timer X interrupt enable bit                  | 0 : Interrupt disabled 1 : Interrupt enabled    | 0        | 0 | 0 |
|                                                       | 5    | Timer Y interrupt enable bit                  | 0 : Interrupt disabled 1 : Interrupt enabled    | 0        | 0 | 0 |
|                                                       | 6    | Timer 2/INT <sub>3</sub> interrupt enable bit | 0 : Interrupt disabled<br>1 : Interrupt enabled | 0        | 0 | 0 |
| <u> </u>                                              | 7    | Timer 3/INT4 interrupt enable bit             | 0 : Interrupt disabled 1 : Interrupt enabled    | 0        | 0 | 0 |

Fig. 2.3.13 Structure of Interrupt control register 1



Fig. 2.3.14 Structure of Interrupt control register 2

#### 2.3.3 Serial I/O connection examples

#### (1) Control of peripheral IC equipped with CS pin

There are connection examples using a clock synchronous serial I/O mode. Figure 2.3.15 shows connection examples of a peripheral IC equipped with the CS pin.



Fig. 2.3.15 Serial I/O connection examples (1)

#### (2) Connection with microcomputer

Figure 2.3.16 shows connection examples of the other microcomputers.



Fig. 2.3.16 Serial I/O connection examples (2)

#### 2.3.4 Setting of serial I/O transfer data format

A clock synchronous or clock asynchronous (UART) is selected as a data format of the serial I/O1. The serial I/O2 operates in a clock synchronous.

Figure 2.3.17 shows a setting of serial I/O transfer data format.



Fig. 2.3.17 Setting of Serial I/O transfer data format

#### 2.3.5 Serial I/O application examples

#### (1) Communication using a clock synchronous serial I/O (transmit/receive)

Outline: 2-byte data is transmitted and received through the clock synchronous serial I/O. The SRDY1 signal is used for communication control.

Figure 2.3.18 shows a connection diagram, and Figure 2.3.19 shows a timing chart.



Fig. 2.3.18 Connection diagram [Communication using a clock synchronous serial I/O]

- Specifications: The Serial I/O1 is used (clock synchronous serial I/O is selected)
  - Synchronous clock frequency: 125 kHz (f(XIN) = 8 MHz is divided by 64)
  - The Srdy1 (receivable signal) is used.
  - The receiving side outputs the SRDY1 signal at intervals of 2 ms (generated by timer), and 2-byte data is transferred from the transmitting side to the receiving side.



Fig. 2.3.19 Timing chart [Communication using a clock synchronous serial I/O]



Fig. 2.3.20 Setting of related registers at a transmitting side [Communication using a clock synchronous serial I/O]



Fig. 2.3.21 Setting of related registers at a receiving side [Communication using a clock synchronous serial I/O]

**Control procedure :** Figure 2.3.22 shows a control procedure at a transmitting side, and Figure 2.3.23 shows a control procedure at a receiving side.



Fig. 2.3.22 Control procedure at a transmitting side [Communication using a clock synchronous serial I/O]



Fig. 2.3.23 Control procedure at a receiving side [Communication using a clock synchronous serial I/O]

#### (2) Output of serial data (control of a peripheral IC)

**Outline**: 4-byte data is transmitted and received through the clock synchronous serial I/O. The CS signal is output to a peripheral IC through the port P53.



Fig. 2.3.24 Connection diagram [Output of serial data]

Specifications: • The Serial I/O is used. (clock synchronous serial I/O is selected)

- Synchronous clock frequency: 125 kHz (f(XIN) = 8 MHz is divided by 64)
- Transfer direction : LSB first
- The Serial I/O interrupt is not used.
- The Port P53 is connected to the  $\overline{\text{CS}}$  pin ("L" active) of the peripheral IC for a transmission control (the output level of the port P53 is controlled by software).

Figre 2.3.25 shows an output timing chart of serial data.



Fig. 2.3.25 Timing chart [Output of serial data]

#### 2.3 Serial I/O

Figure 2.3.26 shows a setting of serial I/O1 related registers, and Figure 2.3.27 shows a setting of serial I/O1 transmission data.



Fig. 2.3.26 Setting of serial I/O1 related registers [Output of serial data]

|       | Transmit/Receive buffer register | r (Address : 1816)                                                                                                                                                 |
|-------|----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TB/RB | b7 b0                            | Set a transmission data.  Check that transmission of the previous data is completed before writing data (bit 3 of the Interrupt request register 1 is set to "1"). |

Fig. 2.3.27 Setting of serial I/O1 transmission data [Output of serial data]

#### 2.3 Serial I/O

**Control procedure :** When the registers are set as shown in Fig. 2.3.26, the Serial I/O1 can transmit 1-byte data simply by writing data to the Transmit buffer register.

Thus, after setting the CS signal to "L," write the transmission data to the Receive buffer register on a 1-byte base, and return the CS signal to "H" when the desired number of bytes have been transmitted.

Figure 2.3.28 shows a control procedure of serial I/O1.



Fig. 2.3.28 Control procedure of serial I/O1 [Output of serial data]

Figure 2.3.29 shows a setting of serial I/O2 related registers, and Figure 2.3.30 shows a setting of serial I/O2 transmission data.



Fig. 2.3.29 Setting of serial I/O2 related registers [Output of serial data]



Fig. 2.3.30 Setting of serial I/O2 transmission data [Output of serial data]

**Control procedure :** When the registers are set as shown in Fig. 2.3.29, the Serial I/O2 can transmit 1-byte data simply by writing data to the Serial I/O2 register.

Thus, after setting the CS signal to "L," write the transmission data to the Serial I/O1 register on a 1-byte base, and return the CS signal to "H" when the desired number of bytes have been transmitted.

Figure 2.3.31 shows a control procedure of serial I/O2.



Fig. 2.3.31 Control procedure of serial I/O2 [Output of serial data]

(3) Cyclic transmission or reception of block data (data of a specified number of bytes) between microcomputers [without using an automatic transfer]

Outline: When a clock synchronous serial I/O is used for communication, synchronization of the clock and the data between the transmitting and receiving sides may be lost because of noise included in the synchronizing clock. Thus, it is necessary to be corrected constantly. This "heading adjustment" is carried out by using the interval between blocks in this example.



Fig. 2.3.32 Connection diagram [Cyclic transmission or reception of block data between microcomputers]

Specifications: • The serial I/O1 is used (clock synchronous serial I/O is selected).

• Synchronous clock frequency: 125 kHz (f(XIN) = 8 MHz is divided by 64)

• Byte cycle: 488 µs

• Number of bytes for transmission or reception: 8 byte/block

Block transfer cycle: 16 ms
Block transfer period: 3.5 ms
Interval between blocks: 12.5 ms
Heading adjustive time: 8 ms

#### Limitations of the specifications

- 1. Reading of the reception data and setting of the next transmission data must be completed within the time obtained from "byte cycle time for transferring 1-byte data" (in this example, the time taken from generating of the Serial I/O1 receive interrupt request to generating of the next synchronizing clock is 428 μs).
- 2. "Heading adjustive time < interval between blocks" must be satisfied.

The communication is performed according to the timing shown below. In the slave unit, when a synchronizing clock is not input within a certain time (heading adjustive time), the next clock input is processed as the beginning (heading) of a block.

When a clock is input again after one block (8 byte) is received, the clock is ignored.

Figure 2.3.34 shows a setting of related registers.



Fig. 2.3.33 Timing chart [Cyclic transmission or reception of block data between microcomputers]



Fig. 2.3.34 Setting of related registers [Cyclic transmission or reception of block data between microcomputers]

#### Control procedure:

#### 1) Control in the master unit

After a setting of the related registers is completed as shown in Figure 2.3.34, in the master unit transmission or reception of 1-byte data is started simply by writing transmission data to the Transmit buffer register.

To perform the communication in the timing shown in Figure 2.3.33, therefore, take the timing into account and write transmission data. Read out the reception data when the Serial I/O1 transmit interrupt request bit is set to "1," or before the next transmission data is written to the Transmit buffer register.

A processing example in the master unit using timer interrupts is shown below.



Fig. 2.3.35 Control in the master unit

#### 2 Control in the slave unit

After a setting of the related registers is completed as shown in Figure 2.3.34, the slave unit becomes the state which is received a synchronizing clock at all times, and the Serial I/O1 receive interrupt request bit is set to "1" every time an 8-bit synchronous clock is received.

By the serial I/O1 receive interrupt processing routine, the data to be transmitted next is written to the Transmit buffer register after received data is read out.

However, if no serial I/O1 receive interrupt occurs for more than a certain time (head adjustive time), the following processing will be performed.

- 1. The first 1 byte data of the transmission data in the block is written into the Transmission buffer register.
- 2. The data to be received next is processed as the first 1 byte of the received data in the block.

Figure 2.3.36 shows the control in the slave unit using a serial I/O1 receive interrupt and any timer interrupt (for head adjustive).



Fig. 2.3.36 Control in the slave unit

#### (4) Communication (transmit/receive) using an asynchronous serial I/O (UART)

Point: 2-byte data is transmitted and received through an asynchronous serial I/O. The port P42 is used for communication control.

Figure 2.3.37 shows a connection diagram, and Figure 2.3.38 shows a timing chart.



Fig. 2.3.37 Connection diagram [Communication using UART]

- **Specifications:** The Serial I/O1 is used (UART is selected).
  - Transfer bit rate: 9600 bps (f(XIN) = 4.9152 MHz is divided by 512)
  - Communication control using port P42 (The output level of the port P42 is controlled by softoware.)
  - 2-byte data is transferred from the transmitting side to the receiving side at intervals of 10 ms (generated by timer).



Fig. 2.3.38 Timing chart [Communication using UART]

### 2.3 Serial I/O

Table 2.3.1 shows setting examples of Baud rate generator (BRG) values and transfer bit rate values, Figure 2.3.39 shows a setting of related registers at a transmitting side, and Figure 2.3.40 shows a setting of related registers at a receiving side.

Table 2.3.1 Setting examples of Baud rate generator values and transfer bit rate values

|                       |                    | at f(XIN) = 4.9152 MHz |                   | at f(XIN) = 7.3728 MHz |                   | at f(XIN) = 8 MHz |                   |
|-----------------------|--------------------|------------------------|-------------------|------------------------|-------------------|-------------------|-------------------|
| rate(bps)<br>(Note 1) | Source<br>(Note 2) | BRG setting value      | Actual time (bps) | BRG setting value      | Actual time (bps) | BRG setting value | Actual time (bps) |
| 600                   | f(XIN)/4           | 127(7F <sub>16</sub> ) | 600.00            | 191(BF <sub>16</sub> ) | 600.00            | 207(CF16)         | 600.96            |
| 1200                  | f(XIN)/4           | 63(3F <sub>16</sub> )  | 1200.00           | 95(5F16)               | 1200.00           | 103(6716)         | 1201.92           |
| 2400                  | f(XIN)/4           | 31(1F <sub>16</sub> )  | 2400.00           | 47(2F16)               | 2400.00           | 51(3316)          | 2403.85           |
| 4800                  | f(XIN)/4           | 15(0F16)               | 4800.00           | 23(1716)               | 4800.00           | 25(1916)          | 4807.69           |
| 9600                  | f(XIN)/4           | 7(0716)                | 9600.00           | 11(0B16)               | 9600.00           | 12(0C16)          | 9615.38           |
| 19200                 | f(XIN)/4           | 3(0316)                | 19200.00          | 5(0516)                | 19200.00          | 5(0516)           | 20833.33          |
| 38400                 | f(XIN)/4           | 1(0116)                | 38400.00          | 2(0216)                | 38400.00          | 2(0216)           | 41666.67          |
| 76800                 | f(XIN)             | 3(0316)                | 76800.00          | 5(0516)                | 76800.00          | 5(0516)           | 83333.33          |
| 31250                 | f(XIN)             |                        |                   |                        |                   | 15(0F16)          | 31250.00          |
| 62500                 | f(XIN)             |                        |                   |                        |                   | 7(0716)           | 62500.00          |

Notes 1: Equation of transfer bit rate

Transfer bit rate (bps) = 
$$\frac{f(XIN)}{(BRG \text{ setting value + 1)} \times 16 \times m}$$

m: when bit 0 of the Serial I/O1 control register (Address: 1A16) is set to "0," a value of m is 1.

when bit 0 of the Serial I/O1 control register (Address: 1A<sub>16</sub>) is set to "1," a value of m is 4.

2: A BRG count source is selected by bit 0 of the Serial I/O1 control register (Address: 1A16).



Fig. 2.3.39 Setting of related registers at a transmitting side [Communication using UART]



Fig. 2.3.40 Setting of related registers at a receiving side [Communication using UART]

**Control procedure :** Figure 2.3.41 shows a control procedure at a transmitting side, and Figure 2.3.42 shows a control procedure at a receiving side.



Fig. 2.3.41 Control procedure at a transmitting side [Communication using UART]



Fig. 2.3.42 Control procedure at a receiving side [Communication using UART]

## 2.4 Real time output port (RTP)

### 2.4.1 Memory map of real time output port

| ı                  |                                             | 1 |
|--------------------|---------------------------------------------|---|
|                    |                                             |   |
| 002A <sub>16</sub> | Real time port register (RTP)               |   |
| 002B <sub>16</sub> | Real time port control register 0 (RTPCON0) |   |
| 002C <sub>16</sub> | Real time port control register 1 (RTPCON1) |   |
| 002D <sub>16</sub> | Real time port control register 2 (RTPCON2) |   |
| 002E <sub>16</sub> | Real time port control register 3 (RTPCON3) |   |
| 002F <sub>16</sub> | Timer A Low-order (TAL)                     |   |
| 003016             | Timer A High-order (TAH)                    |   |
| 003116             | Timer B Low-order (TBL)                     |   |
| 003216             | Timer B High-order (TBH)                    |   |
|                    |                                             |   |

Fig. 2.4.1 Memory map of real time output port related registers

#### 2.4.2 Related registers



Fig. 2.4.2 Structure of Real time port register



Fig. 2.4.3 Structure of Real time port control register 0



Fig. 2.4.4 Structure of Real time port control register 1



Fig. 2.4.5 Structure of Real time port control register 2



Fig. 2.4.6 Structure of Real time port control register 3



Fig. 2.4.7 Structure of Timer A Low-order, Timer A High-order, Timer B Low-order, Timer B High-order

# 2.4.3 Real time output port application examples Control of stepping motor

Outline: The rotation of the stepping motor is controlled by using Real time output ports.

Figure 2.4.8 shows a connection diagram.



Fig. 2.4.8 Connection diagram

Specifications: • Each of two motors is controlled by using four Real time output ports.

- Clock f(XIN) = 8 MHz
- The same data table is used for acceleration and deceleration.
   (20 steps, 500 pps max.)
- The value of the Timer A and B are updated by each interrupt processing routine.
- When the Timer A and/or B stops, the "L" level is output.

Figure 2.4.9 shows the operation patterns of the motor to be controlled in this application example. The Timer A and the Timer B can control the motor independently with different operation patterns.



Fig. 2.4.9 Operation patterns of motor

The motor is accelerated and decelerated by updating the timer value in the Timer interrupt processing routine. Figure 2.4.10 shows an example of timer table for acceleration and deceleration. A table common to both Timer A and Timer B is used in this application example.

As shown in the following figure, the motor speed is controlled by setting a value in the low-order side of the table first at acceleration and by setting a value the high-order side of the table first at deceleration. At a constant motor speed, the motor operation is continued with the last timer value of acceleration.



Fig. 2.4.10 Example of timer table for acceleration and deceleration

Figure 2.4.11 shows an example of operation pattern table to operate the motor by the operation patterns shown in Figure 2.4.9. The total number of operation patterns, the direction of motor rotation and number of steps at a constant motor speed are set in this table.

The motor can be rotated by an arbitrary distance by changing this number of steps. (In this application example, up to 255 steps can be set.)

An operation pattern table is set for each of the Timer A and the Timer B.

| 04                                   | Total number of operation patterns                                            |                     |
|--------------------------------------|-------------------------------------------------------------------------------|---------------------|
| 04 <sub>16</sub><br>00 <sub>16</sub> | Forward rotation                                                              | Operation pattern 1 |
| C8 <sub>16</sub>                     | 200 steps at a constant motor speed Reverse rotation                          |                     |
| 9616                                 | 150 steps at a constant motor speed                                           | Operation pattern 2 |
| 00 <sub>16</sub><br>64 <sub>16</sub> | Forward rotation  100 steps at a constant motor speed                         | Operation pattern 3 |
| FF <sub>16</sub>                     | Reverse rotation                                                              | Operation pattern 4 |
| FA <sub>16</sub>                     | 250 steps at a constant motor speed                                           |                     |
|                                      | as a forward rotation in this example. as a reverse rotation in this example. |                     |

Fig. 2.4.11 Example of operation pattern table

Figure 2.4.12 shows an example of output data table. Output data is selected in the 4 types of tables shown in Figure 2.4.12 according to the information on forward rotation and reverse rotation referenced in the operation pattern table shown in Figure 2.4.11, and then set in Real time port registers 0 to 7. For example, in case the Timer B continues to control the motor in the forward direction when the data of operation pattern 2 is set after the Timer A has output operation pattern 1, the data of table 3 is set in Real time port registers 0 to 7.

| ⟨Table 1⟩                                                                 | ⟨Table 2⟩                   | ⟨Table 3⟩                                              | ⟨Table 4⟩                    |
|---------------------------------------------------------------------------|-----------------------------|--------------------------------------------------------|------------------------------|
| RTP7-RTP4: Forward rotation                                               | RTP7-RTP4: Reverse rotation | RTP7-RTP4 : Forward rotation                           | RTP7-RTP4 : Reverse rotation |
| RTP3-RTP0 : Forward rotation                                              | RTP3–RTP0: Forward rotation | RTP3–RTP0: Reverse rotation                            | RTP3-RTP0 : Reverse rotation |
| b7 b0  Real time port register 7 0 0 1 0 0 1                              | b7 b0 1 0 0 0 1             | b7 b0 0 0 1 1 0 0 1                                    | b7 b0 1 0 0 1                |
| b7 b0  Real time port register 6 0 0 1 1 0 0 1 1                          | b7 b0 1 0 0 0 1 1           | $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$ | b7 b0<br>1 0 0 1 0 0 0       |
| b7 b0  Real time port register 5 0 0 1 0 0 0 1 0                          | b7 b0 1 1 0 0 0 1 0         | b7 b0 0 1 1 1 0 0                                      | b7 b0 1 1 0 0                |
| b7 b0  Real time port register 4 0 1 1 0 0 1 1 0                          | b7 b0 0 1 1 0               | b7 b0 0 1 0 0 0                                        | b7 b0 0 1 0 0 0 1 0 0        |
| b7 b0  Real time port register 3 0 1 0 0 0 1 0 0                          | b7 b0 0 1 0 0 0             | b7 b0 0 1 1 0                                          | b7 b0 0 1 1 0                |
| b7 b0  Real time port register 2 1 1 0 0 1 1 0 0                          | b7 b0 0 1 0 1 1 0 0         | b7 b0 1 0 0 0 1 0                                      | b7 b0 0 1 0 0 1 0            |
| b7         b0           Real time port register 1         1 0 0 0 1 0 0 0 | b7 b0 0 1 1 1 0 0 0         | b7 b0 1 0 0 0 1 1                                      | b7 b0 0 1 1 0 0 1 1          |
| b7 b0  Real time port register 0 1 0 0 1 1 0 0 1                          | b7 b0 0 0 1 1 0 0 1         | b7 b0 1 0 0 0 1                                        | b7 b0 0 0 1 0 0 0 1          |

Fig. 2.4.12 Example of output data table

#### 2.4 Real time output port

Figure 2.4.13 shows the waveforms which are output from RTP0 to RTP7 as a result that the Timer A and the Timer B are operated by using the data of Figure 2.4.10 to Figure 2.4.12. This timing chart is for the case where the Timer A controls operation pattern 1 and the Timer B controls operation pattern 3.



Fig. 2.4.13 Timing of Real time output

Figure 2.4.14 shows the setting method and output timing for the Timer A. The same setting method is used even for the Timer B. Before the count of the Timer A is started, initial values (t1, t2) are set in the Timer A1 latch and the Timer A0 latch. After the count of the Timer A is started, the timer value (t3, ...) is updated in the Timer A interrupt processing routine.

The next latch is automatically specified each time a value is set in the timer, so it is not necessary to specify a write latch in bit 7 of RTPCON1 when the timer value is updated.

In this application example, the real time output port is switched over to the programmable I/O port after termination of the last output because the "L" level is output from RTP0 to RTP7 when the timer stops as a matter of specification. However, when the count of the Timer A is stopped and the real time output port is switched over to the programmable I/O port after termination of the last output, the next RTP data is output in a short period from an underflow of the Timer A till a count stop of the Timer A. To avoid outputting the next RTP data in the short period, the count of the Timer A is stopped at a start of the last output (though the last output data is output) and the last output period is counted by using different timers (Timer X for the Timer A and timer Y for the Timer B in this case). After that counting, when the Timer X underflows, the real time output port is switched over to the programmable I/O port and the "L" level is output.

To continue to output the last output data after the timer stops, just stop the count of the Timer A after termination of the last output.

Figure 2.4.14 shows the setting method and output timing and Figure 2.4.15 to Figure 2.4.18 show the control procedures for related registers.



- Note 1: Numbers 0 to 7 indicate Real time port registers 0 to 7.
  - 2: The output pointer value (bits 6 to 4 of real time port control register 1) is decreased by 1 at each underflow of the Timer A. Thus, the current output pointer value which is read out indicates the next Real time port register to be output.
  - 3: The "L" level is output after the timer stops. Thus, the last output is executed by creating time by software (Timer X) after the stop of the timer and switching over the real time output port to the programmable I/O port. (For the reason that if the Timer A is stopped during or after an interrupt caused at the termination of the last output, the next data (data of Real time port register 7) is output in a short period from the underflow of the Timer A to the count stop of the Timer A.) To continue to output the last output data after the timer stops, just stop the count of the timer after termination of the last output.
  - 4: Set the timer values t1 and t2 before an RTP output.

Fig. 2.4.14 Setting method and output timing



Fig. 2.4.15 Setting of related registers (1)



Fig. 2.4.16 Setting of related registers (2)



Fig. 2.4.17 Setting of related registers (3)



Fig. 2.4.18 Setting of related registers (4)

#### 2.4 Real time output port

#### Control procedure:

Figure 2.4.19-Figure 2.4.22 show control procedures.



Fig. 2.4.19 Control procedure (1)



Fig. 2.4.20 Control procedure (2)



Fig. 2.4.21 Control procedure (3)



Fig. 2.4.22 Control procedure (4)

#### 2.5 A-D converter

#### 2.5 A-D converter

#### 2.5.1 Memory map of A-D conversion



Fig. 2.5.1 Memory map of A-D conversion related registers

#### 2.5.2 Related registers



Fig. 2.5.2 Structure of A-D control register



Fig. 2.5.3 Structure of A-D conversion register

#### 2.5 A-D converter

| o7 b6 b5 b4 b3 b2 b1 | b0 |    |                                                                         |                                                   |          |   |   |
|----------------------|----|----|-------------------------------------------------------------------------|---------------------------------------------------|----------|---|---|
|                      | П  | In | terrupt request reigster 2 (IREQ                                        | 2) [Address : 3D <sub>16</sub> ]                  |          |   |   |
|                      |    | В  | Name                                                                    | Function                                          | At reset | R | W |
|                      |    | 0  | CNTR₀ interrupt request bit                                             | 0 : No interrupt request 1 : Interrupt request    | 0        | 0 | * |
|                      |    | 1  | CNTR <sub>1</sub> interrupt request bit                                 | 0 : No interrupt request<br>1 : Interrupt request | 0        | 0 | * |
|                      |    | 2  | Serial I/O2 interrupt request bit                                       | 0 : No interrupt request 1 : Interrupt request    | 0        | 0 | * |
|                      |    | 3  | Timer 1/INT2 interrupt request bit                                      | 0 : No interrupt request 1 : Interrupt request    | 0        | 0 | * |
|                      |    | 4  | Timer A interrupt request bit                                           | 0 : No interrupt request 1 : Interrupt request    | 0        | 0 | * |
|                      |    | 5  | Timer B interrupt request bit                                           | 0 : No interrupt request<br>1 : Interrupt request | 0        | 0 | * |
|                      |    | 6  | ADT/AD conversion interrupt request bit                                 | 0 : No interrupt request 1 : Interrupt request    | 0        | 0 | * |
| L                    |    | 7  | Nothing is allocated for this bit.<br>When this bit is read out, the va |                                                   | 0        | 0 | × |

Fig. 2.5.4 Structure of Interrupt request register 2



Fig. 2.5.5 Structure of Interrupt control register 2

# 2.5.3 A-D conversion application example Conversion of Analog input voltage

Outline: The analog input voltage input from the sensor is converted into digital values.

Refer to the following examples for using an internal trigger or an external trigger.

#### (1) Read for analog signal using an internal trigger

Figure 2.5.6 shows a connection diagram, and Figure 2.5.7 shows a setting of related registers.



Fig. 2.5.6 Connection diagram [Read for analog signal using an internal trigger]

**Specifications**: • The analog input voltage input from the sensor is converted into digital values. (Note)

- The P74/AN1 pin is used as an analog input pin.
- A-D conversion start with an internal trigger (by setting bit 4 of A-D control register to "0").

Note: Example

When a reference voltage, 5.12 V is input to the ADVREF pin and a voltage, 4 V to the P74/AN1 pin, an input voltage is converted to a following value.  $(256 / 5.12 \text{ V}) \times 4 \text{ V} = 200 \text{ (C816)}$ 



Fig. 2.5.7 Setting of related registers [Read for analog signal using an internal trigger]

#### 2.5 A-D converter

**Control procedure :** By setting the related registers as shown in Figure 2.5.8, the analog input voltage input from the sensor are converted into digital values.



Fig. 2.5.8 Control procedure [Read for analog signal using an internal trigger]

#### (2) Read for analog signal using an external trigger

Figure 2.5.9 shows a connection diagram, and Figure 2.5.10 shows a setting of related registers.



Fig. 2.5.9 Connection diagram [Read for analog signal using an external trigger]

**Specifications : •** The analog input voltage input from the sensor is converted into digital values. (Note)

- The P74/AN1 pin is used as an analog input pin.
- A-D conversion start with an external trigger (by inputting a falling edge to the P73/SRDY2/ADT/AN0 pin ).

Note: Example

When a reference voltage,  $5.12\ V$  is input to the ADVREF pin and a voltage,  $4\ V$  to the P74/AN1 pin, an input voltage is converted to a following value.

 $(256 / 5.12 \text{ V}) \times 4 \text{ V} = 200 \text{ (C816)}$ 



Fig. 2.5.10 Setting of related registers [Read for analog signal using an external trigger]

#### 2.5 A-D converter

**Control procedure**: By setting the related registers as shown in Figure 2.5.11, the analog input voltage input from the sensor are converted into digital values.



Fig. 2.5.11 Control procedure [Read for analog signal using an external trigger]

#### 2.6 Reset

#### 2.6.1 Connection example of reset IC



Fig. 2.6.1 Example of Poweron reset circuit

Figure 2.6.2 shows the system example which switch to the RAM backup mode by detecting a drop of the system power source voltage with the INT interrupt.



Fig. 2.6.2 RAM back-up system

# 2.7 Application circuit example

# 2.7 Application circuit example

Refer to the following applicaion circuit examples using the 3807 group microcomputer.

| • | Hot water supply system application example       | Figure | 2.7.1 |
|---|---------------------------------------------------|--------|-------|
| • | CD changer (car audio) application example        | Figure | 2.7.2 |
| • | Hot water washing toilet seat application example | Figure | 2.7.3 |



Fig. 2.7.1 Hot water supply system application example



Fig. 2.7.2 CD changer (car audio) application example



Fig. 2.7.3 Hot water washing toilet seat application example

# CHAPTER 3

# **APPENDIX**

- 3.1 Electrical characteristics
- 3.2 Standard characteristics
- 3.3 Notes on use
- 3.4 Countermeasures against noise
- 3.5 List of registers
- 3.6 Mask ROM ordering method
- 3.7 Mark specification form
- 3.8 Package outline
- 3.9 Machine instructions
- 3.10 List of instruction codes
- 3.11 SFR memory map
- 3.12 Pin configuration

# **APPENDIX**

## 3.1 Electrical characteristics

## 3.1 Electrical characteristics

#### 3.1.1 Absolute maximum ratings

Table 3.1.1 Absolute maximum ratings

| Symbol |                      | Parameter                                                                                           | Conditions                      | Ratings             | Unit |
|--------|----------------------|-----------------------------------------------------------------------------------------------------|---------------------------------|---------------------|------|
| Vcc    | Power source volta   | age                                                                                                 |                                 | -0.3 to 7.0         | V    |
| CMPVcc | Analog comparato     | r power source voltage                                                                              |                                 | -0.3 to 7.0         | V    |
| VI     | Input voltage        | P00-P07, P10-P17, P20-P27,<br>P30-P37, P40-P47, P50-P57,<br>P60-P65, P70-P77, P80-P87,<br>ADVREF    |                                 | -0.3 to Vcc +0.3    | V    |
| VI     | Input voltage        | RESET, XIN                                                                                          | All voltages are                | -0.3 to Vcc +0.3    | V    |
| Vı     | Input voltage        | CNVss (ROM version)                                                                                 | based on Vss.                   | -0.3 to 7           | V    |
| VI     | Input voltage        | CNVss (PROM version)                                                                                | Output transistors are cut off. | -0.3 to 13          | V    |
| VI     | In-phase input volt  | age CMPIN, CMPREF                                                                                   | are cut on.                     | -0.3 to CMPVcc +0.3 | V    |
| VID    | Differential input v | oltage  CMPIN-CMPREF                                                                                |                                 | CMPVcc              | V    |
| Vo     | Output voltage       | P00-P07, P10-P17, P20-P27,<br>P30-P37, P40-P47, P50-P57,<br>P60-P62, P65, P70-P77,<br>P80-P87, XOUT |                                 | -0.3 to Vcc +0.3    | V    |
| Vo     | Output voltage       | СМРоит                                                                                              |                                 | -0.3 to CMPVcc +0.3 | V    |
| Pd     | Power dissipation    |                                                                                                     | Ta = 25°C                       | 500                 | mW   |
| Topr   | Operating tempera    | ature                                                                                               |                                 | -20 to 85           | °C   |
| Tstg   | Storage temperatu    | ire                                                                                                 |                                 | -40 to 125          | °C   |

#### 3.1.2 Recommended operating conditions

Table 3.1.2 Recommended operating conditions (1) (Vcc = 2.7 to 5.5 V, Ta = - 20 to 85 °C, unless otherwise noted)

| Comple al | Deservator                                    |                                                                                        |        | I Imit |         |      |  |
|-----------|-----------------------------------------------|----------------------------------------------------------------------------------------|--------|--------|---------|------|--|
| Symbol    | Parameter                                     |                                                                                        |        | Тур.   | Max.    | Unit |  |
| Vcc       | Power source voltage                          | $f(XIN) \leq 4.1MHz$                                                                   | 2.7    | 5.0    | 5.5     | V    |  |
|           |                                               | f(XIN) = 8MHz                                                                          | 4.0    | 5.0    | 5.5     | V    |  |
| Vss       | Power source voltage                          |                                                                                        |        | 0      |         | V    |  |
| ADVREF    | A-D comparator reference voltage              |                                                                                        | 2.0    |        | Vcc     | V    |  |
| DAVREF    | D-A comparator reference voltage              |                                                                                        | 2.7    |        | Vcc     | V    |  |
| CMPVcc    | Analog comparator power source voltage        |                                                                                        |        | Vcc    |         | V    |  |
| AVss      | Analog power source voltage                   | Analog power source voltage                                                            |        | 0      |         | V    |  |
| VIA       | A-D comparator input voltage                  | AN0—AN12                                                                               | AVss   |        | Vcc     | V    |  |
| VIH       | "H" input voltage                             | P00—P07, P10—P17, P30, P31,<br>P33—P37, P40—P47, P50—P57,<br>P60—P65, P70—P77, P80—P87 | 0.8Vcc |        | Vcc     | V    |  |
| VIH       | "H" input voltage (CMOS input level selected) | P20—P27, P32                                                                           | 0.8Vcc |        | Vcc     | V    |  |
| VIH       | "H" input voltage (TTL input level selected)  | P20—P27, P32 (Note)                                                                    | 2.0    |        | Vcc     | V    |  |
| VIH       | "H" input voltage                             | RESET, XIN, CNVss                                                                      | 0.8Vcc |        | Vcc     | V    |  |
| VIL       | "L" input voltage                             | P00—P07, P10—P17, P30, P31,<br>P33—P37, P40—P47, P50—P57,<br>P60—P65, P70—P77, P80—P87 | 0      |        | 0.2Vcc  | V    |  |
| VIL       | "L" input voltage (CMOS input level selected) | P20—P27, P32                                                                           | 0      |        | 0.2Vcc  | V    |  |
| VIL       | "L" input voltage (TTL input level selected)  | P20—P27, P32 (Note)                                                                    | 0      |        | 0.8     | V    |  |
| VIL       | "L" input voltage                             | RESET, CNVss                                                                           | 0      |        | 0.2Vcc  | V    |  |
| VIL       | "L" input voltage                             | XIN                                                                                    | 0      |        | 0.16Vcc | V    |  |

Note: When Vcc is 4.0 to 5.5 V.

Table 3.1.3 Recommended operating conditions (2)

(Vcc = 2.7 to 5.5 V, Ta = - 20 to 85 °C, unless otherwise noted)

| Symbol             | Parameter                               |                                                    |      | Unit |      |      |
|--------------------|-----------------------------------------|----------------------------------------------------|------|------|------|------|
| Symbol             | Para                                    | meter                                              | Min. | Тур. | Max. | Unit |
| $\Sigma$ IOH(peak) | "H" total peak output current (Note)    | P00–P07, P10–P17, P20–P27,<br>P30–P37, P80–P87     |      |      | -80  | mA   |
| $\Sigma$ IOH(peak) | "H" total peak output current (Note)    | P40–P47, P50–P57, P60–P62, P65,<br>CMPOUT, P70–P77 |      |      | -80  | mA   |
| $\sum$ IOL(peak)   | "L" total peak output current (Note)    | P00–P07, P10–P17, P20–P23,<br>P30–P37, P80–P87     |      |      | 80   | mA   |
|                    | "L" total peak output current (Note)    | in single chip mode                                |      |      | 80   | mA   |
|                    | P24–P27                                 | in memory expansion mode and microprocessor mode   |      |      | 80   | mA   |
| $\Sigma$ IOL(peak) | "L" total peak output current (Note)    | P40–P47, P50–P57, P60–P62, P65,<br>CMPOUT, P70–P77 |      |      | 80   | mA   |
| ∑IOH(avg)          | "H" total average output current (Note) | P00–P07, P10–P17, P20–P27,<br>P30–P37, P80–P87     |      |      | -40  | mA   |
| ∑IOH(avg)          | "H" total average output current (Note) | P40–P47, P50–P57, P60–P62, P65,<br>CMPout, P70–P77 |      |      | -40  | mA   |
| $\Sigma$ IOL(avg)  | "L" total average output current (Note) | P00–P07, P10–P17, P20–P23,<br>P30–P37, P80–P87     |      |      | 40   | mA   |
| $\sum$ IOL(avg)    | "L" total average output current (Note) | in single chip mode                                |      |      | 40   | mA   |
|                    | P24–P27                                 | in memory expansion mode and microprocessor mode   |      |      | 40   | mA   |
| $\Sigma$ IOL(avg)  | "L" total average output current (Note) | P40–P47, P50–P57, P60–P62, P65, CMPout, P70–P77    |      |      | 40   | mA   |

**Note:** The total output current is the sum of all the currents flowing through all the applicable ports. The total average current is an average value measured over 100ms. The total peak current is the peak value of all the currents.



#### 3.1 Electrical characteristics

Table 3.1.4 Recommended operating conditions (3) (Vcc = 2.7 to 5.5 V, Ta = -20 to 85 °C, unless otherwise noted)

| Symbol    | Parameter                                       |                                                                                                       |      |           | Unit       |       |
|-----------|-------------------------------------------------|-------------------------------------------------------------------------------------------------------|------|-----------|------------|-------|
| Symbol    | Fall                                            | ameter                                                                                                | Min. | Тур. Мах. |            | Offic |
| IOH(peak) | "H" peak output current (Note 1)                | P00-P07, P10-P17, P20-P27,<br>P30-P37, P40-P47, P50-P57,<br>P60-P62, P65, СМРоит, P70-P77,<br>P80-P87 |      |           | -10        | mA    |
| IOL(peak) | "L" peak output current (Note 1)                | P00-P07, P10-P17, P20-P23,<br>P30-P37, P40-P47, P50-P57,<br>P60-P62, P65, СМРоит, P70-P77,<br>P80-P87 |      |           | 10         | mA    |
| IOL(peak) | "L" peak output current (Note 1)                | in single chip mode                                                                                   |      |           | 20         | mA    |
|           | P24–P27                                         | in memory expansion mode and microprocessor mode                                                      |      |           | 10         | mA    |
| IOH(avg)  | "H" average output current (Note 2)             | P00-P07, P10-P17, P20-P27,<br>P30-P37, P40-P47, P50-P57,<br>P60-P62, P65, СМРОUТ, P70-P77,<br>P80-P87 |      |           | <b>-</b> 5 | mA    |
| IOL(avg)  | "L" average output current (Note 2)             | P00-P07, P10-P17, P20-P23,<br>P30-P37, P40-P47, P50-P57,<br>P60-P62, P65, CMPOUT, P70-P77,<br>P80-P87 |      |           | 5          | mA    |
| IOL(avg)  | "L" average output current (Note 2)             | in single chip mode                                                                                   |      |           | 15         | mA    |
|           | P24–P27                                         | in memory expansion mode and microprocessor mode                                                      |      |           | 5          | mA    |
| f(XIN)    | Main clock input oscillation frequency (Note 3) | High-speed mode<br>4.0V ≤ Vcc ≤ 5.5V                                                                  |      |           | 8          | MHz   |
|           |                                                 | High-speed mode<br>2.7V ≤ Vcc ≤ 4.0V                                                                  |      |           | 3Vcc-4     | MHz   |
|           |                                                 | Middle-speed mode<br>4.0V ≤ Vcc ≤ 5.5V                                                                |      |           | 8          | MHz   |
|           |                                                 | Middle-speed mode (Note 5)<br>2.7V ≤ Vcc ≤ 4.0V                                                       |      |           | 8          | MHz   |
|           |                                                 | Middle-speed mode (Note 5)<br>2.7V ≤ Vcc ≤ 4.0V                                                       |      |           | 3Vcc-4     | MHz   |
| f(XCIN)   | Sub-clock input oscillation frequency (         | Note 3, 4)                                                                                            |      | 32.768    | 50         | kHz   |

Note1: The peak output current is the peak current flowing in each port.
2: The average output current IoL (avg), IoH (avg) in an average value measured over 100ms.

<sup>3:</sup> When the oscillation frequency has a duty cyde of 50%.

<sup>4:</sup> When using the microcomputer in low-speed mode, set the sub-clock input oscillation frequency on condition that f(XCIN) < f(XIN)/

<sup>5:</sup> When using the timer X/Y, timer A/B (real time output port), timer 1/2/3, serial I/O1, serial I/O2, and A-D converter, set the main clock input oscillation frequency to the max. 3 Vcc–4 (MHz).

#### 3.1.3 Electrical characteristics

Table 3.1.5 Electrical characteristics (1) (Vcc = 2.7 to 5.5 V, Vss = 0 V, Ta = - 20 to 85  $^{\circ}$ C, unless otherwise noted)

| Comple at | Doromotor          | Took oon dikingo                                                                      | Limits                                                   |         |      | I India |      |
|-----------|--------------------|---------------------------------------------------------------------------------------|----------------------------------------------------------|---------|------|---------|------|
| Symbol    |                    | Parameter                                                                             | Parameter Test conditions                                |         | Тур. | Max.    | Unit |
| Voн       | "H" output voltage | P00–P07, P10–P17, P20–P27,<br>P30–P37, P40–P47, P50–P57,                              | IOH = -10mA<br>VCC = 4.0 to 5.5V                         | Vcc-2.0 |      |         | V    |
|           |                    | P60–P62, P65, P70–P77,<br>P80–P87, CMPOUT (Note 1)                                    | IOH = -1.0mA<br>VCC = 2.7 to 5.5V                        | Vcc-1.0 |      |         | V    |
| VOL       | "L" output voltage | P00–P07, P10–P17, P20–P27,<br>P30–P37, P40–P47, P50–P57,                              | IOL = 10mA<br>VCC = 4.0 to 5.5V                          |         |      | 2.0     | V    |
|           |                    | P60–P62, P65, P70–P77,<br>P80–P87, CMPOUT                                             | IOL = 1.6mA<br>VCC = 2.7 to 5.5V                         |         |      | 0.4     | V    |
| VT+-VT-   | Hysteresis         | P42, P43, P51–P55, P73 (Note 2),<br>CNTR0, CNTR1, INT0–INT4, ADT                      |                                                          |         | 0.4  |         | V    |
| VT+-VT-   | Hysteresis         | RXD, SCLK1, SIN2, SCLK2                                                               |                                                          |         | 0.5  |         | V    |
| VT+-VT-   | Hysteresis         | RESET                                                                                 |                                                          |         | 0.5  |         | V    |
| Іін       | "H" input current  | P00–P07, P10–P17, P20–P27,<br>P30–P37, P40–P47, P50–P57,<br>P60–P65, P70–P77, P80–P87 | VI = VCC<br>(Pin floating. Pull-up<br>transistors "off") |         |      | 5.0     | μА   |
| Іін       | "H" input current  | RESET, CNVss                                                                          | VI = VCC                                                 |         |      | 5.0     | μΑ   |
| Іін       | "H" input current  | XIN                                                                                   | VI = VCC                                                 |         | 4    |         | μΑ   |
| lıL       | "L" input current  | P00–P07, P10–P17, P20–P27,<br>P30–P37, P40–P47, P50–P57,<br>P60–P65, P70–P77, P80–P87 | VI = VSS<br>(Pin floating. Pull-up<br>transistors "off") |         |      | -5.0    | μА   |
| lıL       | "L" input current  | RESET, CNVss                                                                          | VI = VSS                                                 |         |      | -5.0    | μΑ   |
| IIL       | "L" input current  | XIN                                                                                   | VI = VSS                                                 |         | -4   |         | μА   |
| lıL       | "L" input current  | P00-P07, P10-P17, P20-P27                                                             | Pull-up transistors "on"<br>VI = Vss                     |         | -0.2 |         | mA   |
| VRAM      | RAM hold voltage   |                                                                                       | When clock stopped                                       | 2.0     |      | 5.5     | V    |

Note 1: P45 is measured when the P45/TxD P-channel output disable bit of the UART control register (bit 4 of address 001B16) is "0". P71, and P12 are measured when the P71/Sout2 and P72/Sclk2 P-channel output disable bit of the serial I/O2 control register 1 (bit 7 of address 001D16).

<sup>2:</sup> P73 is measured when the AD external trigger valid bit of the A-D control register (bit 6 of address 003416) is "1".



## 3.1 Electrical characteristics

Table 3.1.6 Electrical characteristics (2)

(Vcc = 2.7 to 5.5 V, Vss = 0 V, Ta = - 20 to 85 °C, unless otherwise noted)

| Symbol   | Parameter                              | Test conditions                                                                                                                                 |           | Limits                                |      |      | Unit  |
|----------|----------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|-----------|---------------------------------------|------|------|-------|
| Cyrribor |                                        |                                                                                                                                                 |           | Min.                                  | Тур. | Max. | Offic |
| Icc      | Power source current                   | High-speed mode<br>f(XIN) = 8MHz<br>f(XCIN) = 32.768kHz<br>Output transistors "off"                                                             |           |                                       | 6.8  | 13   | mA    |
|          |                                        | High-speed mode f(XIN) = 8MHz (in WIT state) f(XCIN) = 32.768kHz Output transistors "off"                                                       |           |                                       | 1.6  |      | mA    |
|          |                                        | Low-speed mode  f(XIN) = stopped  f(XCIN) = 32.768kHz  Low-power dissipation mode (CM3 = 0)  Output transistors "off"                           | )         |                                       | 60   | 200  | μА    |
|          |                                        | Low-speed mode  f(XIN) = stopped  f(XCIN) = 32.768kHz (in WIT state)  Low-power dissipation mode (CM3 = 0)  Output transistors "off"            | )         |                                       | 20   | 40   | μА    |
|          |                                        | Low-speed mode (Vcc = 3V)  f(XIN) = stopped  f(XCIN) = 32.768kHz  Low-power dissipation mode (CM3 = 0)  Output transistors "off"                | )         |                                       | 20   | 55   | μА    |
|          |                                        | Low-speed mode (Vcc = 3V)  f(XIN) = stopped  f(XCIN) = 32.768kHz (in WIT state)  Low-power dissipation mode (CM3 = 0)  Output transistors "off" | )         |                                       | 5.0  | 10.0 | μА    |
|          |                                        | Middle-speed mode f(XIN) = 8MHz f(XCIN) = stopped Output transistors "off"                                                                      |           |                                       | 4.0  | 7.0  | mA    |
|          |                                        | Middle-speed mode<br>f(XIN) = 8MHz (in WIT state)<br>f(XCIN) = stopped<br>Output transistors "off"                                              |           |                                       | 1.5  |      | mA    |
|          |                                        | Increment when A-D conversion is exe $f(XIN) = 8MHz$                                                                                            | cuted     |                                       | 800  |      | μА    |
|          |                                        | All oscillation stopped (in STP state) Output transistors "off"                                                                                 | Ta = 25°C | · · · · · · · · · · · · · · · · · · · | 0.1  | 1.0  | μΑ    |
|          |                                        | Output transistors on                                                                                                                           | Ta = 85°C |                                       |      | 10   | μΑ    |
| CMPIcc   | Analog comparator Power source current |                                                                                                                                                 |           |                                       | 200  | 500  | μΑ    |

#### 3.1.4 A-D converter characteristics

Table 3.1.7 A-D converter characteristics

(Vcc = 2.7 to 5.5 V, Vss = AVss = 0 V, ADVREF = 2.0 V to Vcc, Ta = -20 to 85 °C, unless otherwise noted)

| Cumbal  | Symbol Parameter       |                | Toot conditions |                     | Limits |      |      |              |
|---------|------------------------|----------------|-----------------|---------------------|--------|------|------|--------------|
| Symbol  |                        |                | Test conditions | Min.                | Тур.   | Max. | Unit |              |
| _       | Resolution             |                |                 |                     |        |      | 8    | Bits         |
| _       | Absolute accuracy (exc | luding quantiz | zation error)   | VCC = ADVREF = 5.0V |        |      | ±2   | LSB          |
| tCONV   | Conversion time        |                |                 |                     |        |      | 50   | tc( $\phi$ ) |
| RLADDER | Ladder resistor        |                |                 |                     | 12     | 35   | 100  | kΩ           |
| IADVREF | Reference power        | ADVREF         | "on"            | ADVREF = 5.0V       | 50     | 150  | 200  | μА           |
|         | source input current   | ADVREF         | "off"           |                     |        |      | 5    | μА           |
| II(AD)  | A-D port input current |                |                 |                     |        |      | 5.0  | μА           |

#### 3.1.5 D-A converter characteristics

Table 3.1.8 D-A converter characteristics

(Vcc = 2.7 to 5.5 V, Vss = AVss = 0 V, DAVREF = 2.7 V to Vcc, Ta = -20 to 85 °C, unless otherwise noted)

| Symbol  | Symbol Parameter     |                         | Parameter Test conditions |      | Toot conditions | Limits |       |  | Unit |
|---------|----------------------|-------------------------|---------------------------|------|-----------------|--------|-------|--|------|
| Symbol  | Га                   | nameter                 | rest conditions           | Min. | Тур.            | Max.   | Offic |  |      |
| _       | Resolution           |                         |                           |      |                 | 8      | Bits  |  |      |
| _       | Absolute accuracy    | Vcc = 4.0 to 5.5V       |                           |      |                 | 1.0    | %     |  |      |
|         |                      | Vcc = 2.7 to 4.0V       |                           |      |                 | 2.5    | %     |  |      |
| tsu     | Setting time         |                         |                           |      |                 | 3      | μs    |  |      |
| Ro      | Output resistor      |                         |                           | 1    | 2.5             | 4      | kΩ    |  |      |
| IDAVREF | Reference power sour | ce input current (Note) |                           |      |                 | 3.2    | mA    |  |      |

Note: Using one D-A converter, with the value in the D-A conversion register of the other D-A converter being "0016".

## 3.1.6 Analog comparator characteristics

## Table 3.1.9 Analog comparator characteristics

(Vcc = 2.7 to 5.5 V, Vss = AVss = 0 V, CMPVcc = 2.7 V to Vcc, Ta = - 20 to 85  $^{\circ}$ C, unless otherwise noted)

| Cumbal | Parameter                    | Toot conditions                                     |      | Unit |                |      |
|--------|------------------------------|-----------------------------------------------------|------|------|----------------|------|
| Symbol | Parameter                    | Test conditions                                     | Min. | Тур. | Max.           | Unit |
| Vio    | Input offset voltage         | CMPVcc = $5.0V$<br>CMPREF = $2.5V$ , Rs = $0\Omega$ |      | 3    | 50             | mV   |
| Ів     | Input bias current           |                                                     |      |      | 5              | μА   |
| lio    | Input offset current         |                                                     |      |      | 5              | μА   |
| VICM   | In-phase input voltage range |                                                     | 1.2  |      | CMPVcc<br>-0.5 | V    |
| Av     | Voltage gain                 |                                                     |      | ∞    |                |      |
| tPD    | Response time                | CMPVcc = 5.0V<br>CMPREF = 2.5V                      |      | 60   | 2500           | ns   |

# **APPENDIX**

# 3.1 Electrical characteristics

# 3.1.7 Timing requirements

Table 3.1.10 Timing requirements (1) (Vcc = 4.0 to 5.5 V, Vss = 0 V, Ta = - 20 to 85  $^{\circ}$ C, unless otherwise noted)

| Cymphol         | Parameter                                                   |      | Limits |      |      |
|-----------------|-------------------------------------------------------------|------|--------|------|------|
| Symbol          | Parameter                                                   | Min. | Тур.   | Max. | Unit |
| tw(RESET)       | Reset input "L" pulse width                                 | 2    |        |      | μs   |
| tc(XIN)         | External clock input cycle time                             | 125  |        |      | ns   |
| twh(XIN)        | External clock input "H" pulse width                        | 50   |        |      | ns   |
| twL(XIN)        | External clock input "L" pulse width                        | 50   |        |      | ns   |
| tc(CNTR)        | CNTR <sub>0</sub> , CNTR <sub>1</sub> input cycle time      | 200  |        |      | ns   |
| twn(CNTR)       | CNTR <sub>0</sub> , CNTR <sub>1</sub> input "H" pulse width | 80   |        |      | ns   |
| twL(CNTR)       | CNTR <sub>0</sub> , CNTR <sub>1</sub> input "L" pulse width | 80   |        |      | ns   |
| twH(INT)        | INTo to INT4 input "H" pulse width                          | 80   |        |      | ns   |
| twL(INT)        | INTo to INT4 input "L" pulse width                          | 80   |        |      | ns   |
| tc(Sclk1)       | Serial I/O1 clock input cycle time (Note)                   | 800  |        |      | ns   |
| twH(ScLK1)      | Serial I/O1 clock input "H" pulse width (Note)              | 370  |        |      | ns   |
| twL(Sclk1)      | Serial I/O1 clock input "L" pulse width (Note)              | 370  |        |      | ns   |
| tsu(RXD-SCLK1)  | Serial I/O1 clock input set up time                         | 220  |        |      | ns   |
| th(SCLK1-RXD)   | Serial I/O1 clock input hold time                           | 100  |        |      | ns   |
| tC(SCLK2)       | Serial I/O2 clock input cycle time                          | 1000 |        |      | ns   |
| tWH(SCLK2)      | Serial I/O2 clock input "H" pulse width                     | 400  |        |      | ns   |
| twL(Sclk2)      | Serial I/O2 clock input "L" pulse width                     | 400  |        |      | ns   |
| tsu(SIN2-SCLK2) | Serial I/O2 clock input set up time                         | 200  |        |      | ns   |
| th(SCLK2-SIN2)  | Serial I/O2 clock input hold time                           | 200  |        |      | ns   |

Note: When bit 6 of address 001A16 is "1" (clock synchronous).

Divide this value by four when bit 6 of address 001A16 is "0" (UART).

Table 3.1.11 Timing requirements (2)

(Vcc = 2.7 to 5.5 V, Vss = 0 V, Ta = -20 to 85 °C, unless otherwise noted)

| 0 1 1           | 5 .                                                         | Limits |      |      | 11.00 |
|-----------------|-------------------------------------------------------------|--------|------|------|-------|
| Symbol          | Parameter                                                   | Min.   | Тур. | Max. | Unit  |
| tw(RESET)       | Reset input "L" pulse width                                 | 2      |      |      | μs    |
| tc(XIN)         | External clock input cycle time                             | 243    |      |      | ns    |
| twh(XIN)        | External clock input "H" pulse width                        | 100    |      |      | ns    |
| twl(XIN)        | External clock input "L" pulse width                        | 100    |      |      | ns    |
| tc(CNTR)        | CNTR <sub>0</sub> , CNTR <sub>1</sub> input cycle time      | 500    |      |      | ns    |
| twn(CNTR)       | CNTR <sub>0</sub> , CNTR <sub>1</sub> input "H" pulse width | 230    |      |      | ns    |
| twL(CNTR)       | CNTR <sub>0</sub> , CNTR <sub>1</sub> input "L" pulse width | 230    |      |      | ns    |
| twh(INT)        | INTo to INT4 input "H" pulse width                          | 230    |      |      | ns    |
| twL(INT)        | INTo to INT4 input "L" pulse width                          | 230    |      |      | ns    |
| tc(Sclk1)       | Serial I/O1 clock input cycle time (Note)                   | 2000   |      |      | ns    |
| twh(Sclk1)      | Serial I/O1 clock input "H" pulse width (Note)              | 950    |      |      | ns    |
| twl(Sclk1)      | Serial I/O1 clock input "L" pulse width (Note)              | 950    |      |      | ns    |
| tsu(RXD-SCLK1)  | Serial I/O1 clock input set up time                         | 400    |      |      | ns    |
| th(SCLK1-RXD)   | Serial I/O1 clock input hold time                           | 200    |      |      | ns    |
| tc(Sclk2)       | Serial I/O2 clock input cycle time                          | 2000   |      |      | ns    |
| twh(Sclk2)      | Serial I/O2 clock input "H" pulse width                     | 950    |      |      | ns    |
| twL(SCLK2)      | Serial I/O2 clock input "L" pulse width                     | 950    |      |      | ns    |
| tsu(SIN2-SCLK2) | Serial I/O2 clock input set up time                         | 400    |      |      | ns    |
| th(SCLK2-SIN2)  | Serial I/O2 clock input hold time                           | 300    |      |      | ns    |

Note: When bit 6 of address 001A16 is "1" (clock synchronous).

Divide this value by four when bit 6 of address 001A16 is "0" (UART).

## 3.1.8 Switching characteristics

Table 3.1.12 Switching characteristics (1) (Vcc = 4.0 to 5.5 V, Vss = 0 V, Ta = -20 to 85 °C, unless otherwise noted)

| Cymphol         | Parameter                                | Test conditions | Limits          |      |      | Unit |
|-----------------|------------------------------------------|-----------------|-----------------|------|------|------|
| Symbol          | Symbol                                   |                 | Min.            | Тур. | Max. |      |
| twh(Sclk1)      | Serial I/O1 clock output "H" pulse width | Fig. 3.1.1      | tc(Sclk1)/2-30  |      |      | ns   |
| tWL(SCLK1)      | Serial I/O1 clock output "L" pulse width |                 | tc(Sclk1)/2-30  |      |      | ns   |
| td(SCLK1-TXD)   | Serial I/O1 output delay time (Note 1)   |                 |                 |      | 140  | ns   |
| tv(SCLK1-TXD)   | Serial I/O1 output valid time (Note 1)   |                 | -30             |      |      | ns   |
| tr(SCLK1)       | Serial I/O1 clock output rising time     |                 |                 |      | 30   | ns   |
| tf(SCLK1)       | Serial I/O1 clock output falling time    |                 |                 |      | 30   | ns   |
| twh(Sclk2)      | Serial I/O2 clock output "H" pulse width | Fig. 3.1.1      | tc(Sclk2)/2-160 |      |      | ns   |
| tWL(SCLK2)      | Serial I/O2 clock output "L" pulse width |                 | tc(Sclk2)/2-160 |      |      | ns   |
| td(SCLK2-SOUT2) | Serial I/O2 output delay time (Note 2)   |                 |                 |      | 200  | ns   |
| tv(SCLK2-SOUT2) | Serial I/O2 output valid time (Note 2)   |                 | 0               |      |      | ns   |
| tf(SCLK2)       | Serial I/O2 clock output falling time    |                 |                 |      | 30   | ns   |
| tr(CMOS)        | CMOS output rising time (Note 3)         | Fig. 3.1.1      |                 | 10   | 30   | ns   |
| tf(CMOS)        | CMOS output falling time (Note 3)        |                 |                 | 10   | 30   | ns   |

Note 1: When the P45/TxD P-channel output disable bit of the UART control register (bit 4 of address 001B16) is "0".

2: When the P71/SOUT2, P72/SCLK2 P-channel output disable bit of the serial I/O2 control register1 (bit 7 of address 001D16) is "0".

3: XOUT pin is excluded.

Table 3.1.13 Switching characteristics (2)

(Vcc = 2.7 to 5.5 V, Vss = 0 V, Ta = -20 to 85 °C, unless otherwise noted)

| Cumbal          | Parameter                                | Took oon dikingo | Limits          |      |      | Unit |
|-----------------|------------------------------------------|------------------|-----------------|------|------|------|
| Symbol          | Parameter                                | Test conditions  | Min.            | Тур. | Max. | Onit |
| twh(Sclk1)      | Serial I/O1 clock output "H" pulse width | Fig. 3.1.1       | tc(SclK1)/2-50  |      |      | ns   |
| tWL(SCLK1)      | Serial I/O1 clock output "L" pulse width |                  | tc(SclK1)/2-50  |      |      | ns   |
| td(SCLK1-TXD)   | Serial I/O1 output delay time (Note 1)   |                  |                 |      | 350  | ns   |
| tv(SCLK1-TXD)   | Serial I/O1 output valid time (Note 1)   | ]                | -30             |      |      | ns   |
| tr(SCLK1)       | Serial I/O1 clock output rising time     | ]                |                 |      | 50   | ns   |
| tf(SCLK1)       | Serial I/O1 clock output falling time    |                  |                 |      | 50   | ns   |
| twh(Sclk2)      | Serial I/O2 clock output "H" pulse width | Fig. 3.1.1       | tc(Sclk2)/2-240 |      |      | ns   |
| tWL(SCLK2)      | Serial I/O2 clock output "L" pulse width | ]                | tc(Sclk2)/2-240 |      |      | ns   |
| td(SCLK2-SOUT2) | Serial I/O2 output delay time (Note 2)   |                  |                 |      | 400  | ns   |
| tv(SCLK2-SOUT2) | Serial I/O2 output valid time (Note 2)   |                  | 0               |      |      | ns   |
| tf(SCLK2)       | Serial I/O2 clock output falling time    | ]                |                 |      | 50   | ns   |
| tr(CMOS)        | CMOS output rising time (Note 3)         | Fig. 3.1.1       |                 | 20   | 50   | ns   |
| tf(CMOS)        | CMOS output falling time (Note 3)        |                  |                 | 20   | 50   | ns   |

Note 1: When the P45/TxD P-channel output disable bit of the UART control register (bit 4 of address 001B16) is "0".

2: When the P71/SOUT2, P72/SCLK2 P-channel output disable bit of the serial I/O2 control register1 (bit 7 of address 001D16) is "0".

3: XOUT pin is excluded.



# 3.1.9 Timing requirements in memory expansion mode and microprocessor mode

Table 3.1.14 Timing requirements in memory expansion and microprocessor mode (Vcc = 4.0 to 5.5 V, Vss = 0 V, Ta = − 20 to 85 °C, in high-speed mode, unless otherwise noted)

| Cumbal                                                               | Parameter             |      | Unit |      |      |
|----------------------------------------------------------------------|-----------------------|------|------|------|------|
| Symbol                                                               | Parameter             | Min. | Тур. | Max. | Unit |
| tsu(ONW−φ)                                                           | ONW input set up time | -20  |      |      | ns   |
| th( $\phi$ –ONW)                                                     | ONW input hold time   | -20  |      |      | ns   |
| tsu(DB− <i>ϕ</i> )                                                   | Data bus set up time  | 50   |      |      | ns   |
| th( $\phi$ –DB)                                                      | Data bus hold time    | 0    |      |      | ns   |
| tsu(ONW-RD), tsu(ONW-WR)                                             | ONW input set up time | -20  |      |      | ns   |
| $th(\overline{RD}-\overline{ONW}), th(\overline{WR}-\overline{ONW})$ | ONW input hold time   | -20  |      |      | ns   |
| tsu(DB-RD)                                                           | Data bus set up time  | 50   |      |      | ns   |
| th(RD-DB)                                                            | Data bus hold time    | 0    |      |      | ns   |

## 3.1.10 Switching characteristics in memory expansion mode and microprocessor mode

Table 3.1.15 Switching characteristics in memory expansion and microprocessor mode (Vcc = 4.0 to 5.5 V, Vss = 0 V,  $Ta = -20 \text{ to } 85 ^{\circ}\text{C}$ , in high-speed mode, unless otherwise noted)

| C. mah al                                       | Davasastas                                              | Took oondiking  |             | Llait      |      |      |
|-------------------------------------------------|---------------------------------------------------------|-----------------|-------------|------------|------|------|
| Symbol                                          | Parameter                                               | Test conditions | Min.        | Тур.       | Max. | Unit |
| tc( $\phi$ )                                    | φ clock cycle time                                      | Fig. 3.1.1      |             | 2tc(XIN)   |      | ns   |
| <b>t</b> wн(φ)                                  | φ clock "H" pulse width                                 |                 | tc(XIN)-10  |            |      | ns   |
| twL(φ)                                          | φ clock "L" pulse width                                 |                 | tc(XIN)-10  |            |      | ns   |
| td(φ–AH)                                        | AD15-AD8 delay time                                     |                 |             | 16         | 35   | ns   |
| td(φ-AL)                                        | AD7-AD0 delay time                                      |                 |             | 20         | 40   | ns   |
| tv(φ–AH)                                        | AD15-AD8 valid time                                     |                 | 2           | 5          |      | ns   |
| tv(φ-AL)                                        | AD7-AD0 valid time                                      |                 | 2           | 5          |      | ns   |
| td(φ-SYNC)                                      | SYNC delay time                                         |                 |             | 16         |      | ns   |
| tv(φ-SYNC)                                      | SYNC valid time                                         |                 |             | 5          |      | ns   |
| td(φ–DB)                                        | Data bus delay time                                     |                 |             | 15         | 30   | ns   |
| tv(φ–DB)                                        | Data bus valid time                                     |                 | 10          |            |      | ns   |
| twL(RD), twL(WR)                                | RD pulse width, WR pulse width                          |                 | tc(XIN)-10  |            |      | ns   |
|                                                 | RD pulse width, WR pulse width (When one-wait is valid) |                 | 3tc(XIN)-10 |            |      | ns   |
| $td(AH-\overline{RD}), td(AH-\overline{WR})$    | AD15-AD8 delay time                                     |                 | tc(XIN)-35  | tc(XIN)-16 |      | ns   |
| $td(AL-\overline{RD})$ , $td(AL-\overline{WR})$ | AD7-AD0 delay time                                      |                 | tc(XIN)-40  | tc(XIN)-20 |      | ns   |
| tv(RD-AH), tv(WR-AH)                            | AD15-AD8 valid time                                     |                 | 2           | 5          |      | ns   |
| tv(RD-AL), tv(WR-AL)                            | AD7-AD0 valid time                                      |                 | 2           | 5          |      | ns   |
| td(WR-DB)                                       | Data bus delay time                                     |                 |             | 15         | 30   | ns   |
| tv(WR-DB)                                       | Data bus valid time                                     |                 | 10          |            |      | ns   |
| td(RESET-RESETOUT)                              | RESETOUT output delay time                              |                 |             |            | 200  | ns   |
| tv(φ-RESETouτ)                                  | RESETout output valid time (Note)                       |                 | 0           |            | 100  | ns   |

Note: The RESEToυτ output goes "H" in sync with the fall of the φ clock that is anywhere between about 8 cycle and 13 cycles after the RESET input goes "H".



Fig. 3.1.1 Circuit for measuring output switching characteristics (1)



Fig. 3.1. 2 Circuit for measuring output switching characteristics (2)



Fig. 3.1.3 Timing diagram (1) (in single-chip mode)



Fig. 3.1.4 Timing diagram (2) (in memory expansion mode and microprocessor mode)



Fig. 3.1.5 Timing diagram (3) (in memory expansion mode and microprocessor mode)



Fig. 3.1.6 Timing diagram (4) (in memory expansion mode and microprocessor mode)



Fig. 3.1.7 Timing diagram (5) (in memory expansion mode and microprocessor mode)

# 3.2 Standard characteristics

# 3.2.1 Power source current characteristic examples

Figures 3.2.1 and Figure 3.2.2 show power source current characteristic examples.



Fig. 3.2.1 Power source current characteristic example



Fig. 3.2.2 Power source current characteristic example (in wait mode)

# 3.2 Standard characteristics

## 3.2.2 Port standard characteristic examples

Figures 3.2.3, Figure 3.2.4, Figure 3.2.5, and Figure 3.2.6 show port standard characteristic examples.



Fig. 3.2.3 Standard characteristic example of CMOS output port at P-channel drive (1)



Fig. 3.2.4 Standard characteristic example of CMOS output port at P-channel drive (2)



Fig. 3.2.5 Standard characteristic example of CMOS output port at N-channel drive (1)



Fig. 3.2.6 Standard characteristic example of CMOS output port at N-channel drive (2)

# 3.2 Standard characteristics



Fig. 3.2.7 Standard characteristic example of CMOS output port at N-channel drive (4)



Fig. 3.2.8 Standard characteristic example of CMOS output port at N-channel drive (5)

## 3.2.3 Input current standard characteristic examples

Figure 3.2.9 and Figure 3.2.10 show input current standard characteristic examples.



Fig. 3.2.9 Standard characteristic example of input current at connecting pull-up transistor (1)



Fig. 3.2.10 Standard characteristic example of input current at connecting pull-up transistor (2)

# **APPENDIX**

# 3.2 Standard characteristics

#### 3.2.4 A-D conversion standard characteristics

Figure 3.2.11 shows the A-D conversion standard characteristics.

The lower-side line on the graph indicates the absolute precision error. It represents the deviation from the ideal value. For example, the conversion of output code from 0 to 1 occurs ideally at the point of ANo = 10 mV, but the measured value is 0 mV. Accordingly, the measured point of conversion is represented as "10 - 0 = 10 mV."

The upper-side line on the graph indicates the width of input voltages equivalent to output codes. For example, the measured width of the input voltage for output code 13 is 22 mV, so the differential nonlinear error is represented as "22 - 20 = 2 mV" (0.1 LSB).



Fig. 3.2.11 A-D conversion standard characteristics

#### 3.2.5 D-A conversion standard characteristics

Figure 3.2.12 shows the D-A conversion standard characteristics. The lower-side line on the graph indicates the absolute precision error. In this case, it represents the difference between the ideal analog output value for an input code and the measured value.

The upper-side line on the graph indicates the change width of output analog value to a one-bit change of input code.



Fig. 3.2.12 D-A conversion standard characteristics

## 3.3 Notes on use

## 3.3 Notes on use

### 3.3.1 Notes on interrupts

# (1) Sequence for switching an external interrupt detection edge

When the external interrupt detection edge must be switched, make sure the following sequence.

#### Reason

The interrupt circuit recognizes the switching of the detection edge as the change of external input signals. This may cause an unnecessary interrupt.

#### (2) Bit 7 of the interrupt control register 2

Fix the bit 7 of the interrupt control register 2 (Address: $003F_{16}$ ) to "0".

Figure 3.3.1 shows the structure of the interrupt control register 2.





Fig. 3.3.1 Structure of interrupt control register 2

### 3.3.2 Notes on the serial I/O1

### (1) Stop of data transmission

As for the serial I/O1 that can be used as either a clock synchronous or an asynchronous (UART) serial I/O, clear the transmit enable bit to "0" (transmit disabled), and clear the serial I/O enable bit to "0" (serial I/O1 disabled)in the following cases:

- when stopping data transmission during transmitting data in the clock synchronous serial I/O mode
- when stopping data transmission during transmitting data in the UART mode
- when stopping only data transmission during transmitting and receiving data in the UART mode

#### Reason

Since transmission is not stopped and the transmission circuit is not initialized even if the serial I/O1 enable bit is cleared to "0" (serial I/O1 disabled), the internal transmission is running (in this case, since pins TxD, RxD, Sclk1, and Srdy1 function as I/O ports, the transmission data is not output). When data is written to the transmit buffer register in this state, the data is transferred to the transmit shift register and start to be shifted. When the serial I/O1 enable bit is set to "1" at this time, the data during internally shifting is output to the TxD pin and it may cause an operation failure to a microcomputer.

## (2) Stop of data reception

As for the serial I/O1 that can be used as either a clock synchronous or an asynchronous (UART) serial I/O, clear the receive enable bit to "0" (receive disabled), or clear the serial I/O enable bit to "0" (serial I/O disabled) in the following case :

- when stopping data reception during receiving data in the clock synchronous serial I/O mode Clear the receive enable bit to "0" (receive disabled) in the following cases:
- when stopping data reception during receiving data in the UART mode
- when stopping only data reception during transmitting and receiving data in the UART mode

#### (3) Stop of data transmission and reception in a clock synchronous serial I/O mode

As for the serial I/O1 that can be used as either a clock synchronous or an asynchronous (UART) serial I/O, clear both the transmit enable bit and receive enable bit to "0" (transmit and receive disabled) at the same time in the following case:

• when stopping data transmission and reception during transmitting and receiving data in the clock synchronous mode (when data is transmitted and received in the clock synchronous serial I/O mode, any one of data transmission and reception cannot be stopped.)

#### Reason

In the clock synchronous serial I/O mode, the same clock is used for transmission and reception. If any one of transmission and reception is disabled, a bit error occurs because transmission and reception cannot be synchronized.

In this mode, the clock circuit of the transmission circuit also operates for data reception. Accordingly, the transmission circuit does not stop by clearing only the transmit enable bit to "0" (transmit disabled). Also, the transmission circuit is not initialized by clearing the serial I/O1 enable bit to "0" (serial I/O1 disabled) (refer to (1)).

## (4) The SRDY pin on a receiving side

When signals are output from the SRDY pin on the reception side by using an external clock in the clock synchronous serial I/O mode, set all of the receive enable bit, the SRDY output enable bit, and the transmit enable bit to "1" (transmit enabled).

# (5) Stop of data reception in a clock synchronous serial I/O mode

Set the serial I/O1 control register again after the transmission and the reception circuits are reset by clearing both the transmit enable bit and the receive enable bit to "0."



# (6) Control of data transmission using the transmit shift completion flag

The transmit shift completion flag changes from "1" to "0" with a delay of 0.5 to 1.5 shift clocks. When checking the transmit shift completion flag after writing a data to the transmit buffer register for controlling a data transmission, note this delay.

#### (7) Control of data transmission using an external clock

When an external clock is used as the synchronous clock for data transmission, set the transmit enable bit to "1" at "H" level of the SCLK input signal. Also, write data to the transmit buffer register at "H" level of the SCLK input signal.

#### 3.3.3 Notes on the A-D converter

## (1) Input of signals from signal source with high impedance to an analog input pin

Make the signal source impedance for analog input low, or equip an analog input pin with an external capacitor of 0.01  $\mu$ F to 1  $\mu$ F. Further, make sure to check the operation of application products on the user side.

#### Reason

The A-D converter builds in the capacitor for analog voltage comparison. Accordingly, when signals from signal source with high impedance are input to an analog input pin, a charge and discharge noise generates. This may cause the A-D conversion precision to be worse.

## 3.3 Notes on use

#### (2) AVss pin

Connect a power source for the A-D converter, AVss pin to the Vss line of the analog circuit.

## (3) A clock frequency during an A-D conversion

The comparator consists of a capacity coupling, and a charge of the capacity will be lost if the clock frequency is too low. Thus, make sure the following during an A-D conversion.

- f(XIN) is 500 kHz or more .
  - (When the ONW pin is "L", f(XIN) is 1 MHz or more.)
- Do not execute the STP instruction and WIT instruction.

## 3.3.4 Notes on the RESET pin

When a rising time of the reset signal is long, connect a ceramic capacitor or others across the RESET pin and the Vss pin. And use a 1000 pF or more capacitor for high frequency use. When connecting the capacitor, make sure the following:

- •Make the length of the wiring which is connected to a capacitor the shortest possible.
- •Make sure to check the operation of application products on the user side.

#### Reason

If the several nanosecond or several ten nanosecond impulse noise enters the RESET pin, a microcomputer may malfunction.

### 3.3.5 Notes on input and output pins

### (1) Fix of a port input level in stand-by state

Fix input levels of an input and an I/O port for getting effect of low-power dissipation in stand-by state, especially for the I/O ports of the N-channel open-drain.

Pull-up (connect the port to Vcc) or pull-down (connect the port to Vss) these ports through a resistor.

When determining a resistance value, make sure the following:

- External circuit
- Variation of output levels during the ordinary operation
- \* stand-by state : the stop mode by executing the **STP** instruction the wait mode by executing the **WIT** instruction

## Reason

Even when setting as an output port with its direction register, in the following state:

●N-channel.....when the content of the port latch is "1"

the transistor becomes the OFF state, which causes the ports to be the high-impedance state. Make sure that the level becomes "undefined" depending on external circuits.

Accordingly, the potential which is input to the input buffer in a microcomputer is unstable in the state that input levels of an input and an I/O port are "undefined." This may cause power source current.

## (2) Modify of the content of I/O port latch

When the content of the port latch of an I/O port is modified with the bit managing instruction\*, the value of the unspecified bit may be changed.

#### Reason

The bit managing instruction is read-modify-write instruction for reading and writing data by a byte unit. Accordingly, when this instruction is executed on one bit of the port latch of an I/O port, the following is executed to all bits of the port latch.

- •As for a bit which is set as an input port: The pin state is read in the CPU, and is written to this bit after bit managing.
- •As for a bit which is set as an output port: The bit value is read in the CPU, and is written to this bit after bit managing.

Make sure the following:

- •Even when a port which is set as an output port is changed for an input port, its port latch holds the output data.
- ●Even when a bit of a port latch which is set as an input port is not speccified with a bit managing instruction, its value may be changed in case where content of the pin differs from a content of the port latch.
  - \* bit managing instructions : **SEB**, and **CLB** instruction

#### (3) The AVss pin when not using the A-D converter

When not using the A-D converter, handle a power source pin for the A-D converter, AVss pin as follows:

AVss : Connect to the Vss pin

#### Reason

If the AVSS pin is opened, the microcomputer may malfunction by effect of noise or others.

### 3.3.6 Notes on memory expansion mode and microprocessor mode

#### (1) Writing data to the port latch of port P3

In the memory expansion or the microprocessor mode, ports P30 and P31 can be used as the output port. Use the **LDM** or **STA** instruction for writing data to the port latch (address 000616) of port P3.

When using a read-modify-write instruction (the **SEB** or the **CLB** instruction), allocate the read and the write enabled memory at address 000616.

#### Reason

In the memory expansion or microprocessor mode, address 000616 is allocated in the external area. Accordingly,

- Data is read from the external memory.
- Data is written to both the port latch of the port P3 and the external memory.

Accordingly, when executing a read-modify-write instruction for address 000616, external memory data is read and modified, and the result is written in both the port latch of the port P3 and the external memory. If the read enabled memory is not allocated at address 000616, the read data is undefined. The undefined data is modified and written to the port latch of the port P3. The port latch data of port P3 becomes "undefined."

# (2) Overlap of an internal memory and an external memory

When the internal and the external memory are overlapped in the memory expansion mode, the internal memory is valid in this overlapped area. When the CPU writes or reads to this area, the following is performed:

- When reading data
  - Only the data in the internal memory is read into the CPU and the data in the external memory is not read into the CPU. However, as the read signal and address are still valid, the external memory data of the corresponding address is output to the external data bus.
- When writing data
  - Data is written in both the internal and the external memory.

# **APPENDIX**

## 3.3 Notes on use

#### 3.3.7 Notes on built-in PROM

# (1) Programming adapter

To write or read data into/from the internal PROM, use the dedicated programming adapter and general-purpose PROM programmer as shown in Table 3.3.1.

**Table 3.3.1 Programming adapter** 

| Microcomputer    | Programming adapter |
|------------------|---------------------|
| M38073E4FS       | PCA4738L-80A        |
| M38073E4FP       | 50.4505             |
| (one-time blank) | PCA4738F-80A        |

## (2) Write and read

In PROM mode, operation is the same as that of the M5M27C256AK, but programming conditions of PROM programmer are not set automatically because there are no internal device ID codes.

Accurately set the following conditions for data write/read. Take care not to apply 21 V to Vpp pin (is also used as the CNVss pin), or the product may be permanently damaged.

- Programming voltage: 12.5 V
- Setting of programming adapter switch: refer to table 3.3.2
- Setting of PROM programmer address: refer to table 3.3.3

Table 3.3.2 Setting of programming adapter switch

| Programming adapter | SW 1 | SW 2 | SW 3 |
|---------------------|------|------|------|
| PCA4738F-80A        | CMOS | CMOS | OFF  |
| PCA4738L-80A        | CMOS | CMOS | OFF  |

## Table 3.3.3 Setting of PROM programmer address

| Microcomputer | PROM programmer start address | PROM programmer completion address |  |
|---------------|-------------------------------|------------------------------------|--|
| M38073E4FS    |                               |                                    |  |
| M38073E4FP    | Address : 408016 (Note 1)     | Address : 7FFD16 (Note 1)          |  |

Note: Addresses C08016 to FFFD16 in the internal PROM correspond to addresses 408016 to 7FFD16 in the ROM programmer.

#### (3) Erasing

Contents of the windowed EPROM are erased through an ultraviolet light source of the wavelength 2537-Ångstrom. At least 15 W-sec/cm<sup>2</sup> are required to erase EPROM contents.

Countermeasures against noise are described below. The following countermeasures are effective against noise in theory, however, it is necessary not only to take measures as follows but to evaluate before actual use.

#### 3.4.1 Shortest wiring length

The wiring on a printed circuit board can be as an antenna which feeds noise into the microcomputer.

The shorter the total wiring length (by mm unit), the less the possibility of noise insertion into a microcomputer.

# (1) Wiring for the RESET pin

Make the length of wiring which is connected to the RESET pin as short as possible. Especially, connect a capacitor across the RESET pin and the Vss pin with the shortest possible wiring (within 20mm).

#### Reason

The reset works to initialize a microcomputer.

The width of a pulse input into the RESET pin is determined by the timing necessary conditions. If noise having a shorter pulse width than the standard is input to the RESET pin, the reset is released before the internal state of the microcomputer is completely initialized. This may cause a program runaway.



Fig. 3.4.1 Wiring for the RESET pin

### (2) Wiring for clock input/output pins

- •Make the length of wiring which is connected to clock I/O pins as short as possible.
- •Make the length of wiring (within 20mm) across the grounding lead of a capacitor which is connected to an oscillator and the Vss pin of a microcomputer as short as possible.
- •Separate the Vss pattern only for oscillation from other Vss patterns.

#### Reason

A microcomputer's operation synchronizes with a clock generated by the oscillator (circuit). If noise enters clock I/O pins, clock waveforms may be deformed. This may cause a malfunction or program runaway.

Also, if a potential difference is caused by the noise between the Vss level of a microcomputer and the Vss level of an oscillator, the correct clock will not be input in the microcomputer.



Fig. 3.4.2 Wiring for clock I/O pins

# (3) Wiring for the VPP pin of the One Time PROM version and the EPROM version

# (In this microcomputer the VPP pin is also used as the CNVss pin)

Connect an approximately 5 k $\Omega$  resistor to the VPP pin the shortest possible in series and also to the VSS pin. When not connecting the resistor, make the length of wiring between the VPP pin and the VSS pin the shortest possible.

Note:Even when a circuit which included an approximately 5 k $\Omega$  resistor is used in the Mask ROM version, the maicrocomputer operates correctly.

#### Reason

The VPP pin of the One Time PROM and the EPROM version is the power source input pin for the built-in PROM. When programming in the built-in PROM, the impedance of the VPP pin is low to allow the electric current for wiring flow into the PROM. Because of this, noise can enter easily. If noise enters the VPP pin, abnormal instruction codes or data are read from the built-in PROM, which may cause a program runaway.



Fig. 3.4.3 Wiring for the VPP pin of the One Time PROM and the EPROM version

# 3.4.2 Connection of a bypass capacitor across the Vss line and the Vcc line

Connect an approximately 0.1  $\mu F$  bypass capacitor across the Vss line and the Vcc line as follows:

- •Connect a bypass capacitor across the Vss pin and the Vcc pin at equal length .
- ●Connect a bypass capacitor across the Vss pin and the Vcc pin with the shortest possible wiring.
- ●Use lines with a larger diameter than other signal lines for Vss line and Vcc line.



Fig. 3.4.4 Bypass capacitor across the Vss line and the Vcc line

#### 3.4.3 Wiring to analog input pins

- •Connect an approximately 100  $\Omega$  to 1 k $\Omega$  resistor to an analog signal line which is connected to an analog input pin in series. Besides, connect the resistor to the microcomputer as close as possible.
- Connect an approximately 1000 pF capacitor across the Vss pin and the analog input pin. Besides, connect the capacitor to the Vss pin as close as possible. Also, connect the capacitor across the analog input pin and the Vss pin at equal length.

#### Reason

Signals which is input in an analog input pin (such as an A-D converter input pin) are usually output signals from sensor. The sensor which detects a change of event is installed far from the printed circuit board with a microcomputer, the wiring to an analog input pin is longer necessarily. This long wiring functions as an antenna which feeds noise into the microcomputer, which causes noise to an analog input pin.

If a capacitor between an analog input pin and the Vss pin is grounded at a position far away from the Vss pin, noise on the GND line may enter a microcomputer through the capacitor.

#### 3.4.4. Consideration for oscillator

Take care to prevent an oscillator that generates clocks for a microcomputer operation from being affected by other signals.

# (1) Keeping an oscillator away from large current signal lines

Install a microcomputer (and especially an oscillator) as far as possible from signal lines where a current larger than the tolerance of current value flows.

#### Reason

In the system using a microcomputer, there are signal lines for controlling motors, LEDs, and thermal heads or others. When a large current flows through those signal lines, strong noise occurs because of mutual inductance.

# (2) Keeping an oscillator away from signal lines where potential levels change frequently

Install an oscillator and a connecting pattern of an osillator away from signal lines where potential levels change frequently. Also, do not cross such signal lines over the clock lines or the signal lines which are sensitive to noise.

### Reason

Signal lines where potential levels change frequently (such as the CNTR pin line) may affect other lines at signal rising or falling edge. If such lines cross over a clock line, clock waveforms may be deformed, which causes a microcomputer failure or a program runaway.



Fig.3.4.5 Analog signal line and a resistor and a capacitor



Fig.3.4.6 Wiring for a large current signal line



Fig.3.4.7 Wiring to a signal line where potential levels change frequently

### 3.4.5 Setup for I/O ports

Setup I/O ports using hardware and software as follows:

#### <Hardware>

•Connect a resistor of 100  $\Omega$  or more to an I/O port inseries.

#### <Software>

- •As for an input port, read data several times by a program for checking whether input levels are equal or not.
- As for an output port, since the output data may reverse because of noise, rewrite data to its port latch at fixed periods.
- Rewirte data to direction registers and pull-up control registers (only the product having it) at fixed periods.



Fig. 3.4.8 Setup for I/O ports

When a direction register is set for input port again at fixed periods, a several-nanosecond short pulse may be output from this port. If this is undesirable, connect a capacitor to this port to remove the noise pulse.

# 3.4.6 Providing of watchdog timer function by software

If a microcomputer runs away because of noise or others, it can be detected by a software watchdog timer and the microcomputer can be reset to normal operation. This is equal to or more effective than program runaway detection by a hardware watchdog timer. The following shows an example of a watchdog timer provided by software.

In the following example, to reset a microcomputer to normal operation, the main routine detects errors of the interrupt processing routine and the interrupt processing routine detects errors of the main routine. This example assumes that interrupt processing is repeated multiple times in a single main routine processing.

## <The main routine>

 Assigns a single byte of RAM to a software watchdog timer (SWDT) and writes the initial value N in the SWDT once at each execution of the main routine. The initial value N should satisfy the following condition:



Fig. 3.4.9 Watchdog timer by software

N+1 ≥ (Counts of interrupt processing executed in each main routine)

As the main routine execution cycle may change because of an interrupt processing or others, the initial value N should have a margin.

- •Watches the operation of the interrupt processing routine by comparing the SWDT contents with counts of interrupt processing count after the initial value N has been set.
- •Detects that the interrupt processing routine has failed and determines to branch to the program initialization routine for recovery processing in the following cases:

If the SWDT contents do not change after interrupt processing

# **APPENDIX**

# 3.4 Countermeasures against noise

- <The interrupt processing routine>
  - •Decrements the SWDT contents by 1 at each interrupt processing.
  - •Determins that the main routine operates normally when the SWDT contents are reset to the initial value N at almost fixed cycles (at the fixed interrupt processing count).
  - Detects that the main routine has failed and determines to branch to the program initialization routine for recovery processing in the following case:
  - When the contents of the SWDT reach 0 or less by continuative decrement without initializing to the initial value N .



Fig. 3.5.1 Structure of Port Pi (i = 0, 1, 2, 3, 4, 5, 7, 8)



Fig. 3.5.2 Structure of Port Pi direction register (i = 0, 1, 2, 3, 4, 5, 7, 8)



Fig. 3.5.3 Structure of Port P6



Fig. 3.5.4 Structure of Port P6 direction register



Fig. 3.5.5 Structure of Timer XY control reigster



Fig. 3.5.6 Structure of Port P2P3 control register



Fig. 3.5.7 Structure of Pull-up control register



Fig. 3.5.8 Structure of Watchdog timer control register



Fig. 3.5.9 Structure of Transmit/Receive buffer register



Fig. 3.5.10 Structure of Serial I/O1 status register



Fig. 3.5.11 Structure of Serial I/O1 control register



Fig. 3.5.12 Structure of UART control register



Fig. 3.5.13 Structure of Baud rate generator



Fig. 3.5.14 Structure of Serial I/O2 control register 1



Fig. 3.5.15 Structure of Serial I/O2 control register 2



Fig. 3.5.16 Structure of Serial I/O2 register

|   |         | b2 b1 b0 | ner X High-order, Timer Y Low-order, Timer Y High-order  Timer X Low-order (TXL), Timer X High-order (TXH) [Address: 2016, 2116]  Timer Y Low-order (TYL), Timer Y High-order (TYH) [Address: 2216, 2316] |                                                                                                    |          |   |   |
|---|---------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------|----------|---|---|
|   |         |          | В                                                                                                                                                                                                         | Function                                                                                           | At reset | R | W |
|   |         |          | 0                                                                                                                                                                                                         | A count value of each timer is set.     At writing                                                 | 1        | 0 | 0 |
|   |         | 1        | A value set in this register is written to both a Timer and a corresponding Timer latch at the same time, or to only a Timer latch.                                                                       | 1                                                                                                  | 0        | С |   |
|   |         |          | 2                                                                                                                                                                                                         | A value is written to low-order first.      At reading                                             | 1        | 0 | С |
|   |         |          | 3                                                                                                                                                                                                         | When this register is read out, a value (count value) of a corresponding Timer is read out.        | 1        | 0 | 0 |
|   | <u></u> |          | 4                                                                                                                                                                                                         | A measurement value is read out in pulse period measurement mode and pulse width measurement mode. | 1        | 0 | С |
|   |         | 5        | <ul> <li>A value is read out from high-order first.</li> </ul>                                                                                                                                            | 1                                                                                                  | 0        | С |   |
|   |         |          | 6                                                                                                                                                                                                         |                                                                                                    | 1        | 0 | С |
| L |         |          | 7                                                                                                                                                                                                         |                                                                                                    | 1        | 0 | С |

Fig. 3.5.17 Structure of Timer X Low-order, Timer X High-order, Timer Y Low-order, Timer Y High-order



Fig. 3.5.18 Structure of Timer 1, Timer 3



Fig. 3.5.19 Structure of Timer 2



Fig. 3.5.20 Structure of Timer X mode register



Fig. 3.5.21 Structure of Timer Y mode register

Table. 3.5.1 Function of CNTR<sub>0</sub>/CNTR<sub>1</sub> edge switch bit

| Operating mode of                |     | Function of CNTR <sub>0</sub> /CNTR <sub>1</sub> edge switch bit                    |  |  |
|----------------------------------|-----|-------------------------------------------------------------------------------------|--|--|
| Timer X/Timer Y                  |     | (bit 5 of each address 27 <sub>16</sub> and 28 <sub>16</sub> )                      |  |  |
| Timer mode                       | "0" | Generation of CNTR <sub>0</sub> /CNTR <sub>1</sub> interrupt request : Falling edge |  |  |
|                                  | U   | (No effect on timer count)                                                          |  |  |
|                                  | "1" | Generation of CNTR <sub>0</sub> /CNTR <sub>1</sub> interrupt request : Rising edge  |  |  |
|                                  | '   | (No effect on timer count)                                                          |  |  |
| Event counter mode               | "0" | Timer X/Timer Y : Count at rising edge                                              |  |  |
|                                  | 0   | Generation of CNTR0/CNTR1 interrupt request : Falling edge                          |  |  |
|                                  | "1" | Timer X/Timer Y : Count at falling edge                                             |  |  |
|                                  | ı   | Generation of CNTR <sub>0</sub> /CNTR <sub>1</sub> interrupt request : Rising edge  |  |  |
| Pulse output mode                | "0" | Start of pulse output : From "H" level                                              |  |  |
|                                  | U   | Generation of CNTR <sub>0</sub> /CNTR <sub>1</sub> interrupt request : Falling edge |  |  |
|                                  | "1" | Start of pulse output : From "L" level                                              |  |  |
|                                  | ı   | Generation of CNTR <sub>0</sub> /CNTR <sub>1</sub> interrupt request : Rising edge  |  |  |
| Pulse period measurement mode    |     | Timer X/Timer Y : Measurement of a period between a falling                         |  |  |
|                                  | "0" | edge and the next falling edge                                                      |  |  |
|                                  |     | Generation of CNTR <sub>0</sub> /CNTR <sub>1</sub> interrupt request : Falling edge |  |  |
|                                  |     | Timer X/Timer Y : Measurement of a period between a rising                          |  |  |
|                                  | "1" | edge and the next rising edge                                                       |  |  |
|                                  |     | Generation of CNTR <sub>0</sub> /CNTR <sub>1</sub> interrupt request : Rising edge  |  |  |
| Pulse width measurement mode     | "0" | Timer X/Timer Y : Measurement of "H" level width                                    |  |  |
|                                  | U   | Generation of CNTR0/CNTR1 interrupt request : Falling edge                          |  |  |
|                                  | "1" | <ul> <li>Timer X/Timer Y: Measurement of "L" level width</li> </ul>                 |  |  |
|                                  | ı   | Generation of CNTR <sub>0</sub> /CNTR <sub>1</sub> interrupt request : Rising edge  |  |  |
| Programmable one-shot generation |     | • Timer X/Timer Y: Start of a pulse output at "L" level, and                        |  |  |
| mode                             | "0" | output of an one-shot "H" level pulse                                               |  |  |
|                                  |     | Generation of CNTR0/CNTR1 interrupt request : Falling edge                          |  |  |
|                                  |     | Timer X/Timer Y: Start of a pulse output at "H" level, and                          |  |  |
|                                  | "1" | output of an one-shot "L" level pulse                                               |  |  |
|                                  |     | Generation of CNTR <sub>0</sub> /CNTR <sub>1</sub> interrupt request : Rising edge  |  |  |



Fig. 3.5.22 Structure of Timer 123 mode register



Fig. 3.5.23 Structure of Real time port register



Fig. 3.5.24 Structure of Real time port control register 0



Fig. 3.5.25 Structure of Real time port control register 1



Fig. 3.5.26 Structure of Real time port control register 2

| Real time port control reg |     | <u>r 3</u>                                             |                                           |          |   |   |
|----------------------------|-----|--------------------------------------------------------|-------------------------------------------|----------|---|---|
| b7 b6 b5 b4 b3 b2 b1 b0    | 1   |                                                        |                                           |          |   |   |
|                            | F   | Real time port control register 3 (                    | RTPCON3) [Address: 2E <sub>16</sub> ]     |          |   |   |
|                            | В   | Name                                                   | Function                                  | At reset | R | W |
|                            | 0   | Real time port output selection bit (P82)              | 0 : I/O port<br>1 : Real time output port | 0        | 0 | 0 |
|                            | 1   | Real time port output selection bit (P8 <sub>3</sub> ) |                                           | 0        | 0 | 0 |
|                            | 2   | Real time port output selection bit (P84)              |                                           | 0        | 0 | 0 |
|                            | 3   | Real time port output selection bit (P85)              |                                           | 0        | 0 | 0 |
|                            | 4   | Real time port output selection bit (P86)              |                                           | 0        | 0 | 0 |
|                            | - 5 | Real time port output selection bit (P87)              |                                           | 0        | 0 | 0 |
|                            | 6   | Real time port output selection bit (P3 <sub>0</sub> ) |                                           | 0        | 0 | 0 |
| L                          | 7   | Real time port output selection bit (P3 <sub>1</sub> ) |                                           | 0        | 0 | 0 |

Fig. 3.5.27 Structure of Real time port control register 3



Fig. 3.5.28 Structure of Timer A Low-order, Timer A High-order, Timer B Low-order, Timer B High-order



Fig. 3.5.29 Structure of D-A control register



Fig. 3.5.30 Structure of A-D control register

#### 3.5 List of registers



Fig. 3.5.31 Structure of A-D conversion register



Fig. 3.5.32 Structure of D-Ai conversion register (i=1, 2, 3, 4)

| Interrupt edge selection re<br>b7 b6 b5 b4 b3 b2 b1 b0 | <u>g.o.</u> | <u> </u>                          |                                                |          |       |   |
|--------------------------------------------------------|-------------|-----------------------------------|------------------------------------------------|----------|-------|---|
|                                                        | Inte        | errupt edge selection registe     | r (INTEDGE) [Address : 3A <sub>16</sub> ]      |          |       |   |
|                                                        | В           | Name                              | Function                                       | At reset | R :\  | W |
|                                                        | 0           | INTo interrupt edge selection bit | 0 : Falling edge active 1 : Rising edge active | 0        | 0 (   | 0 |
|                                                        | 1           | INT1 interrupt edge selection bit | 0 : Falling edge active 1 : Rising edge active | 0        | 0 (   | 0 |
|                                                        | 2           | INT2 interrupt edge selection bit | Falling edge active     Rising edge active     | 0        | 0     | 0 |
|                                                        | 3           | INT3 interrupt edge selection bit | 0 : Falling edge active 1 : Rising edge active | 0        | 0 (   | 0 |
|                                                        | 4           | INT4 interrupt edge selection bit | 0 : Falling edge active 1 : Rising edge active | 0        | 0 : 0 | 0 |
|                                                        | . 5         | Timer 1/INT2 interrupt source bit | 0 : INT2 interrupt 1 : Timer 1 interrupt       | 0        | 0   0 | 0 |
|                                                        | 6           | Timer 2/INT3 interrupt source bit | 0 : INT3 interrupt 1 : Timer 2 interrupt       | 0        | 0 (   | 0 |
|                                                        | . 7         | Timer 3/INT4 interrupt source bit | 0 : INT4 interrupt<br>1 : Timer 3 interrupt    | 0        | 0   0 | 0 |

Fig. 3.5.33 Structure of Interrupt edge selection register



Fig. 3.5.34 Structure of CPU mode register

#### 3.5 List of registers

| Interrupt request register | _   |                                                |                                                   |          |   |   |
|----------------------------|-----|------------------------------------------------|---------------------------------------------------|----------|---|---|
|                            | 7   | terrupt request reigster 1 (IREQ               | 1) [Address : 3C <sub>16</sub> ]                  |          |   |   |
|                            | В   | Name                                           | Function                                          | At reset | R | W |
|                            | 0   | INT₀ interrupt request bit                     | 0 : No interrupt request<br>1 : Interrupt request | 0        | 0 | * |
|                            | _ 1 | INT₁ interrupt request bit                     | 0 : No interrupt request<br>1 : Interrupt request | 0        | 0 | * |
|                            | 2   | Serial I/O1 receive interrupt request bit      | 0 : No interrupt request<br>1 : Interrupt request | 0        | 0 | * |
|                            | _ 3 | Serial I/O1 transmit interrupt request bit     | 0 : No interrupt request<br>1 : Interrupt request | 0        | 0 | * |
|                            | 4   | Timer X interrupt request bit                  | 0 : No interrupt request<br>1 : Interrupt request | 0        | 0 | * |
|                            | 5   | Timer Y interrupt request bit                  | 0 : No interrupt request<br>1 : Interrupt request | 0        | 0 | * |
|                            | _ 6 | Timer 2/INT <sub>3</sub> interrupt request bit | 0 : No interrupt request 1 : Interrupt request    | 0        | 0 | * |
|                            | 7   | Timer 3/INT4 interrupt request                 | 0 : No interrupt request 1 : Interrupt request    | 0        | 0 | * |

Fig. 3.5.35 Structure of Interrupt request register 1



Fig. 3.5.36 Structure of Interrupt request register 2

| Interrupt control register b7 b6 b5 b4 b3 b2 b1 b0 | _    |                                               |                                                 |          |   |   |
|----------------------------------------------------|------|-----------------------------------------------|-------------------------------------------------|----------|---|---|
|                                                    | ] Ir | terrupt control register 1 (ICON              | 1) [Address: 3E <sub>16</sub> ]                 |          |   |   |
|                                                    | В    | Name                                          | Function                                        | At reset | R | W |
|                                                    | 0    | INT₀ interrupt enable bit                     | 0 : Interrupt disabled<br>1 : Interrupt enabled | 0        | 0 | 0 |
|                                                    | - 1  | INT₁ interrupt enable bit                     | 0 : Interrupt disabled<br>1 : Interrupt enabled | 0        | 0 | 0 |
|                                                    | . 2  | Serial I/O1 receive interrupt enable bit      | 0 : Interrupt disabled<br>1 : Interrupt enabled | 0        | 0 | 0 |
|                                                    | 3    | Serial I/O1 transmit interrupt enable bit     | 0 : Interrupt disabled 1 : Interrupt enabled    | 0        | 0 | 0 |
|                                                    | 4    | Timer X interrupt enable bit                  | 0 : Interrupt disabled<br>1 : Interrupt enabled | 0        | 0 | 0 |
|                                                    | - 5  | Timer Y interrupt enable bit                  | 0 : Interrupt disabled<br>1 : Interrupt enabled | 0        | 0 | 0 |
|                                                    | 6    | Timer 2/INT₃ interrupt enable bit             | 0 : Interrupt disabled<br>1 : Interrupt enabled | 0        | 0 | 0 |
| <u> </u>                                           | 7    | Timer 3/INT <sub>4</sub> interrupt enable bit | 0 : Interrupt disabled 1 : Interrupt enabled    | 0        | 0 | 0 |

Fig. 3.5.37 Structure of Interrupt control register 1



Fig. 3.5.38 Structure of Interrupt control register 2

#### **APPENDIX**

#### 3.6 Mask ROM ordering method

#### 3.6 Mask ROM ordering method

GZZ-SH11-00B<68A0>

# 740 FAMILY MASK ROM CONFIRMATION FORM SINGLE-CHIP MICROCOMPUTER M38073M4-XXXFP MITSUBISHI ELECTRIC

|         | Date:                  |                      |
|---------|------------------------|----------------------|
| eipt    | Section head signature | Supervisor signature |
| Receipt |                        |                      |

Mask ROM number

Note: Please fill in all items marked \*\*.

|   |          | Company     |       | TEL |   | nΦ            | Submitted by | Supervisor |
|---|----------|-------------|-------|-----|---|---------------|--------------|------------|
| * | Customer | name        |       | (   | ) | uanc<br>natur |              |            |
|   |          | Date issued | Date: |     |   | Issi<br>sigi  |              |            |

#### # 1. Confirmation

Specify the type of EPROMs submitted.

Three EPROMs are required for each pattern.

If at least two of the three sets of EPROMs submitted contain identical data, we will produce masks based on this data. We shall assume the responsibility for errors only if the mask ROM data on the products we produce differs from this data. Thus, extreme care must be taken to verify the data in the submitted EPROMs.

| Checksum code for entire EPROM |  |  | (hexadecimal notation) |
|--------------------------------|--|--|------------------------|
|                                |  |  |                        |

EPROM type (indicate the type used)

|                                                                | 21 From type (maleate the type acca)        |                                                           |  |  |  |  |
|----------------------------------------------------------------|---------------------------------------------|-----------------------------------------------------------|--|--|--|--|
|                                                                | 27256                                       | □ 27512                                                   |  |  |  |  |
| EPROM a                                                        | ddress                                      | EPROM address                                             |  |  |  |  |
| 0000 <sub>16</sub><br>000F <sub>16</sub><br>0010 <sub>16</sub> | Product name<br>ASCII code :<br>'M38073M4-' | 000016 Product name<br>ASCII code :<br>'M38073M4'         |  |  |  |  |
| 407F16<br>408016<br>7FFD16<br>7FFE16<br>7FFF16                 | data<br>ROM 16254 bytes                     | C07F16<br>C08016 data<br>ROM 16254 bytes<br>FFFE16 FFFF16 |  |  |  |  |

In the address space of the microcomputer, the internal ROM area is from address C080 $_{16}$  to FFFD $_{16}$ . The reset vector is stored in addresses FFFC $_{16}$  and FFFD $_{16}$ .

- (1) Set the data in the unused area (the shaded area of the diagram) to "FF16".
- (2) The ASCII codes of the product name "M38073M4-" must be entered in addresses 000016 to 000816. And set the data "FF16" in addresses 000916 to 000F16. The ASCII codes and addresses are listed to the right in hexadecimal notation.

| 000116         '3' = 3316         000916         FF16           000216         '8' = 3816         000A16         FF16           000316         '0' = 3016         000B16         FF16           000416         '7' = 3716         000C16         FF16           000516         '3' = 3316         000D16         FF16           000616         'M' = 4D16         000E16         FF16 | Address |                        | Address            |                          |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|------------------------|--------------------|--------------------------|
| 000216         '8' = 3816         000A16         FF16           000316         '0' = 3016         000B16         FF16           000416         '7' = 3716         000C16         FF16           000516         '3' = 3316         000D16         FF16           000616         'M' = 4D16         000E16         FF16                                                                 | 000016  | 'M' = 4D <sub>16</sub> | 000816             | ' – ' = 2D <sub>16</sub> |
| 000316         '0' = 3016         000B16         FF16           000416         '7' = 3716         000C16         FF16           000516         '3' = 3316         000D16         FF16           000616         'M' = 4D16         000E16         FF16                                                                                                                                 | 000116  | '3' = 33 <sub>16</sub> | 000916             | FF <sub>16</sub>         |
| 000416         '7' = 3716         000C16         FF16           000516         '3' = 3316         000D16         FF16           000616         'M' = 4D16         000E16         FF16                                                                                                                                                                                                 | 000216  | '8' = 38 <sub>16</sub> | 000A16             | FF <sub>16</sub>         |
| 000516                                                                                                                                                                                                                                                                                                                                                                                | 000316  | '0' = 30 <sub>16</sub> | 000B <sub>16</sub> | FF <sub>16</sub>         |
| 000616 'M' = 4D16 000E16 FF16                                                                                                                                                                                                                                                                                                                                                         | 000416  | '7' = 37 <sub>16</sub> | 000C <sub>16</sub> | FF <sub>16</sub>         |
|                                                                                                                                                                                                                                                                                                                                                                                       | 000516  | '3' = 33 <sub>16</sub> | 000D <sub>16</sub> | FF <sub>16</sub>         |
| 0007 <sub>16</sub> '4' = 34 <sub>16</sub> 000F <sub>16</sub> FF <sub>16</sub>                                                                                                                                                                                                                                                                                                         | 000616  | 'M' = 4D <sub>16</sub> | 000E <sub>16</sub> | FF <sub>16</sub>         |
|                                                                                                                                                                                                                                                                                                                                                                                       | 000716  | '4' = 34 <sub>16</sub> | 000F <sub>16</sub> | FF <sub>16</sub>         |

(1/2)

#### 3.6 Mask ROM ordering method

| GZZ-SH1 | 1-00 | )B<6 | 8A0> |
|---------|------|------|------|
|---------|------|------|------|

| Mask ROM number |  |
|-----------------|--|
|                 |  |

# 740 FAMILY MASK ROM CONFIRMATION FORM SINGLE-CHIP MICROCOMPUTER M38073M4-XXXFP MITSUBISHI ELECTRIC

We recommend the use of the following pseudo-command to set the start address of the assembler source program.

| EPROM type         | 27256                              | 27512                            |
|--------------------|------------------------------------|----------------------------------|
| The pseudo-command | *= △ \$8000<br>.BYTE △ 'M38073M4–' | *=△\$0000<br>.BYTE △ 'M38073M4–' |

Note: If the name of the product written to the EPROMs does not match the name of the mask confirmation form, the ROM will not be processed.

|   | _  |      | 141 .1        |
|---|----|------|---------------|
| * | 2. | Mark | specification |

Mark specification must be submitted using the correct form for the package being ordered. Fill out the appropriate mark specification form (80P6N for M38073M4-XXXFP) and attach it to the mask ROM confirmation form.

| Please answer the following questions a                                                     | about usage for use in our product inspection |
|---------------------------------------------------------------------------------------------|-----------------------------------------------|
| (1) How will you use the $X_{\mbox{\scriptsize IN-}}X_{\mbox{\scriptsize OUT}}$ oscillator? |                                               |
| Ceramic resonator                                                                           | Quartz crystal                                |

| External clock input | Other (  | )   |
|----------------------|----------|-----|
| vhat frequency?      | f(XIN) = | MHz |

(2) Which function will you use the pins P41/XcIN and P40/Xcout as P41 and P40, or XcIN and Xcout?

| Ports P4 <sub>1</sub> and P4 <sub>0</sub> function | XCIN and XCOUT function (external resonator) |
|----------------------------------------------------|----------------------------------------------|
|                                                    |                                              |

# 4. Comments

#### 3.7 Mark specification form

#### 80P6N (80-PIN QFP) MARK SPECIFICATION FORM

|                            | <br> |  |  |
|----------------------------|------|--|--|
| Mitsubishi IC catalog name |      |  |  |

Please choose one of the marking types below (A, B, C), and enter the Mitsubishi IC catalog name and the special mark (if needed).

#### A. Standard Mitsubishi Mark



#### B. Customer's Parts Number + Mitsubishi Catalog Name



Note1: The mark field should be written right aligned.

2: The fonts and size of characters are standard Mitsubishi type.

#### C. Special Mark Required



Note1: If the special mark is to be printed, indicate the desired layout of the mark in the left figure. The layout will be duplicated as close as possible.

Mitsubishi lot number (6-digit or 7-digit) and mask ROM number (3-digit) are always marked.

▲Mitsubishi logo is not required

2: If the customer's trade mark logo must be used in the special mark, check the box below. Please submit a clean original of the logo. For the new special character fonts a clean font original (ideally logo drawing) must be submitted.

Special logo required

The standard Mitsubishi font is used for all characters except for a logo.

## 3.8 Package outline





|                             |                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                |    |     |   |     |    |    |   | Α  | ddr | essi | ing                 | mod  | le |    |    |   |                   |      |   |
|-----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|-----|---|-----|----|----|---|----|-----|------|---------------------|------|----|----|----|---|-------------------|------|---|
| Symbol                      | Function                                                                                                                                                                                                                           | Details                                                                                                                                                                                                                                                                                                                                        |    | IMF | > |     | ı  | MM |   |    | Α   |      | Е                   | BIT, | Α  |    | ΖP |   | ВІ                | T, Z | P |
|                             |                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                | OP | n   | # | # C | ЭP | n  | # | OP | n   | #    | OP                  | n    | #  | OP | n  | # | OP                | n    | # |
| ADC<br>(Note 1)<br>(Note 5) | When T = 0<br>$A \leftarrow A + M + C$<br>When T = 1<br>$M(X) \leftarrow M(X) + M + C$                                                                                                                                             | Adds the carry, accumulator and memory contents. The results are entered into the accumulator.  Adds the contents of the memory in the address indicated by index register X, the contents of the memory specified by the addressing mode and the carry. The results are entered into the memory at the address indicated by index register X. |    |     |   | 6   | 69 | 2  | 2 |    |     |      |                     |      |    | 65 | 3  | 2 |                   |      |   |
| AND<br>(Note 1)             | When T = 0<br>$A \leftarrow A \land M$<br>When T = 1<br>$M(X) \leftarrow M(X) \land M$                                                                                                                                             | "AND's" the accumulator and memory contents.  The results are entered into the accumulator. "AND's" the contents of the memory of the address indicated by index register X and the contents of the memory specified by the addressing mode. The results are entered into the memory at the address indicated by index register X.             |    |     |   | 2   | 29 | 2  | 2 |    |     |      |                     |      |    | 25 | 3  | 2 |                   |      |   |
| ASL                         | 7 0<br>C← ← 0                                                                                                                                                                                                                      | Shifts the contents of accumulator or contents of memory one bit to the left. The low order bit of the accumulator or memory is cleared and the high order bit is shifted into the carry flag.                                                                                                                                                 |    |     |   |     |    |    |   | 0A | 2   | 1    |                     |      |    | 06 | 5  | 2 |                   |      |   |
| BBC<br>(Note 4)             | Ab or Mb = 0?                                                                                                                                                                                                                      | Branches when the contents of the bit specified in the accumulator or memory is "0".                                                                                                                                                                                                                                                           |    |     |   |     |    |    |   |    |     |      | 1 <u>,</u> 3<br>20i | 4    | 2  |    |    |   | 1 <u>7</u><br>20i | 5    | 3 |
| BBS<br>(Note 4)             | Ab or Mb = 1?                                                                                                                                                                                                                      | Branches when the contents of the bit specified in the accumulator or memory is "1".                                                                                                                                                                                                                                                           |    |     |   |     |    |    |   |    |     |      | 0 <u>3</u><br>20i   | 4    | 2  |    |    |   | 0 <u>7</u><br>20i | 5    | 3 |
| BCC<br>(Note 4)             | C = 0?                                                                                                                                                                                                                             | Branches when the contents of carry flag is "0".                                                                                                                                                                                                                                                                                               |    |     |   |     |    |    |   |    |     |      |                     |      |    |    |    |   |                   |      |   |
| BCS<br>(Note 4)             | C = 1?                                                                                                                                                                                                                             | Branches when the contents of carry flag is "1".                                                                                                                                                                                                                                                                                               |    |     |   |     |    |    |   |    |     |      |                     |      |    |    |    |   |                   |      |   |
| BEQ<br>(Note 4)             | Z = 1?                                                                                                                                                                                                                             | Branches when the contents of zero flag is "1".                                                                                                                                                                                                                                                                                                |    |     |   |     |    |    |   |    |     |      |                     |      |    |    |    |   |                   |      |   |
| BIT                         | A ^ M                                                                                                                                                                                                                              | "AND's" the contents of accumulator and memory. The results are not entered anywhere.                                                                                                                                                                                                                                                          |    |     |   |     |    |    |   |    |     |      |                     |      |    | 24 | 3  | 2 |                   |      |   |
| BMI<br>(Note 4)             | N = 1?                                                                                                                                                                                                                             | Branches when the contents of negative flag is "1".                                                                                                                                                                                                                                                                                            |    |     |   |     |    |    |   |    |     |      |                     |      |    |    |    |   |                   |      |   |
| BNE<br>(Note 4)             | Z = 0?                                                                                                                                                                                                                             | Branches when the contents of zero flag is "0".                                                                                                                                                                                                                                                                                                |    |     |   |     |    |    |   |    |     |      |                     |      |    |    |    |   |                   |      |   |
| BPL<br>(Note 4)             | N = 0?                                                                                                                                                                                                                             | Branches when the contents of negative flag is "0".                                                                                                                                                                                                                                                                                            |    |     |   |     |    |    |   |    |     |      |                     |      |    |    |    |   |                   |      |   |
| BRA                         | PC ← PC ± offset                                                                                                                                                                                                                   | Jumps to address specified by adding offset to the program counter.                                                                                                                                                                                                                                                                            |    |     |   |     |    |    |   |    |     |      |                     |      |    |    |    |   |                   |      | _ |
| BRK                         | $\begin{array}{c} B \leftarrow 1 \\ M(S) \leftarrow PCH \\ S \leftarrow S - 1 \\ M(S) \leftarrow PCL \\ S \leftarrow S - 1 \\ M(S) \leftarrow PS \\ S \leftarrow S - 1 \\ PCL \leftarrow ADL \\ PCH \leftarrow ADH \\ \end{array}$ | Executes a software interrupt.                                                                                                                                                                                                                                                                                                                 | 00 | 7   | 1 |     |    |    |   |    |     |      |                     |      |    |    |    |   |                   |      |   |

|    |       |   |    |     |   |    |     |   |    |     |   |    |     | Ad | dres | ssin | g mo | ode |       |    |    |     |   |    |     |   |    |     |   |    |    |   | F  | Proc | esso | or st | atus | reç | jiste | r |
|----|-------|---|----|-----|---|----|-----|---|----|-----|---|----|-----|----|------|------|------|-----|-------|----|----|-----|---|----|-----|---|----|-----|---|----|----|---|----|------|------|-------|------|-----|-------|---|
| 2  | ZP, 2 | X | Z  | ZP, | Υ |    | ABS | 3 | А  | BS, | Х | Α  | BS, | Υ  |      | IND  |      | ZF  | P, IN | ID | IN | ND, | X | IN | ND, | Υ | F  | REL |   |    | SP |   | 7  | 6    | 5    | 4     | 3    | 2   | 1     | 0 |
| OP | n     | # | OP | n   | # | OP | n   | # | ОР | n   | # | OP | n   | #  | OP   | n    | #    | OP  | n     | #  | OP | n   | # | OP | n   | # | OP | n   | # | OP | n  | # | N  | V    | Т    | В     | D    | ı   | Z     | С |
| 75 | 4     | 2 |    |     |   | 6D | 4   | 3 | 7D | 5   | 3 | 79 | 5   | 3  |      |      |      |     |       |    | 61 | 6   | 2 | 71 | 6   | 2 |    |     |   |    |    |   | N  | V    | •    | •     | •    | •   | Z     | С |
| 35 |       | 2 |    |     |   | 2D |     |   | 3D |     |   | 39 | 5   | 3  |      |      |      |     |       |    | 21 | 6   | 2 | 31 | 6   | 2 |    |     |   |    |    |   | N  | •    | •    | •     | •    | •   | Z     | • |
| 16 | 6     | 2 |    |     |   | 0E | 6   | 3 | 1E | 7   | 3 |    |     |    |      |      |      |     |       |    |    |     |   |    |     |   |    |     |   |    |    |   | N  | •    | •    | •     | •    | •   | Z     | С |
|    |       |   |    |     |   |    |     |   |    |     |   |    |     |    |      |      |      |     |       |    |    |     |   |    |     |   |    |     |   |    |    |   | •  | •    | •    | •     | •    | •   | •     | • |
|    |       |   |    |     |   |    |     |   |    |     |   |    |     |    |      |      |      |     |       |    |    |     |   |    |     |   |    |     |   |    |    |   | •  | •    | •    | •     | •    | •   | •     | • |
|    |       |   |    |     |   |    |     |   |    |     |   |    |     |    |      |      |      |     |       |    |    |     |   |    |     |   | 90 | 2   | 2 |    |    |   | •  | •    | •    | •     | •    | •   | •     | • |
|    |       |   |    |     |   |    |     |   |    |     |   |    |     |    |      |      |      |     |       |    |    |     |   |    |     |   | В0 | 2   | 2 |    |    |   | •  | •    | •    | •     | •    | •   | •     | • |
|    |       |   |    |     |   |    |     |   |    |     |   |    |     |    |      |      |      |     |       |    |    |     |   |    |     |   | F0 | 2   | 2 |    |    |   | •  | •    | •    | •     | •    | •   | •     | • |
|    |       |   |    |     |   | 2C | 4   | 3 |    |     |   |    |     |    |      |      |      |     |       |    |    |     |   |    |     |   |    |     |   |    |    |   | М7 | M6   | •    | •     | •    | •   | Z     | • |
|    |       |   |    |     |   |    |     |   |    |     |   |    |     |    |      |      |      |     |       |    |    |     |   |    |     |   | 30 | 2   | 2 |    |    |   | •  | •    | •    | •     | •    | •   | •     | • |
|    |       |   |    |     |   |    |     |   |    |     |   |    |     |    |      |      |      |     |       |    |    |     |   |    |     |   | D0 | 2   | 2 |    |    |   | ·  | •    | •    | •     | •    | •   | •     | • |
|    |       |   |    |     |   |    |     |   |    |     |   |    |     |    |      |      |      |     |       |    |    |     |   |    |     |   | 10 |     | 2 |    |    |   | •  | •    | ٠    | •     | •    | •   | •     | • |
|    |       |   |    |     |   |    |     |   |    |     |   |    |     |    |      |      |      |     |       |    |    |     |   |    |     |   | 80 | 4   | 2 |    |    |   | •  | •    | ٠    | •     | •    | •   | •     | • |
|    |       |   |    |     |   |    |     |   |    |     |   |    |     |    |      |      |      |     |       |    |    |     |   |    |     |   |    |     |   |    |    |   | •  | •    | •    | 1     | •    | 1   | •     | • |



|                 |                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                  |    |     |   |    |     |   | Α  | ddr | essi | ng r              | mod | е |    |    |   |           |      |   |
|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|-----|---|----|-----|---|----|-----|------|-------------------|-----|---|----|----|---|-----------|------|---|
| Symbol          | Function                                                                                                                                                        | Details                                                                                                                                                                                                                                                                                                                                          |    | IMF | ) |    | IMN | 1 |    | Α   |      | В                 | IT, | A |    | ΖP |   | BI.       | T, Z | Р |
|                 |                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                  | OP | n   | # | OP | n   | # | OP | n   | #    | OP                | n   | # | OP | n  | # | OP        | n    | # |
| BVC<br>(Note 4) | V = 0?                                                                                                                                                          | Branches when the contents of overflow flag is "0".                                                                                                                                                                                                                                                                                              |    |     |   |    |     |   |    |     |      |                   |     |   |    |    |   |           |      |   |
| BVS<br>(Note 4) | V = 1?                                                                                                                                                          | Branches when the contents of overflow flag is "1".                                                                                                                                                                                                                                                                                              |    |     |   |    |     |   |    |     |      |                   |     |   |    |    |   |           |      |   |
| CLB             | Ab or Mb $\leftarrow$ 0                                                                                                                                         | Clears the contents of the bit specified in the accumulator or memory to "0".                                                                                                                                                                                                                                                                    |    |     |   |    |     |   |    |     |      | 1 <u>В</u><br>20і | 2   | 1 |    |    |   | 1F<br>20i | 5    | 2 |
| CLC             | C ← 0                                                                                                                                                           | Clears the contents of the carry flag to "0".                                                                                                                                                                                                                                                                                                    | 18 | 2   | 1 |    |     |   |    |     |      |                   |     |   |    |    |   |           |      |   |
| CLD             | D ← 0                                                                                                                                                           | Clears the contents of decimal mode flag to "0".                                                                                                                                                                                                                                                                                                 | D8 | 2   | 1 |    |     |   |    |     |      |                   |     |   |    |    |   |           |      |   |
| CLI             | I ← 0                                                                                                                                                           | Clears the contents of interrupt disable flag to "0".                                                                                                                                                                                                                                                                                            | 58 | 2   | 1 |    |     |   |    |     |      |                   |     |   |    |    |   |           |      |   |
| CLT             | T ← 0                                                                                                                                                           | Clears the contents of index X mode flag to "0".                                                                                                                                                                                                                                                                                                 | 12 | 2   | 1 |    |     |   |    |     |      |                   |     |   |    |    |   |           |      |   |
| CLV             | V ← 0                                                                                                                                                           | Clears the contents overflow flag to "0".                                                                                                                                                                                                                                                                                                        | В8 | 2   | 1 |    |     |   |    |     |      |                   |     |   |    |    |   |           |      |   |
| CMP<br>(Note 3) | When T = 0<br>A - M<br>When T = 1<br>M(X) - M                                                                                                                   | Compares the contents of accumulator and memory. Compares the contents of the memory specified by the addressing mode with the contents of the address indicated by index register X.                                                                                                                                                            |    |     |   | C9 | 2   | 2 |    |     |      |                   |     |   | C5 | 3  | 2 |           |      |   |
| СОМ             | $M \leftarrow \overline{M}$                                                                                                                                     | Forms a one's complement of the contents of memory, and stores it into memory.                                                                                                                                                                                                                                                                   |    |     |   |    |     |   |    |     |      |                   |     |   | 44 | 5  | 2 |           |      |   |
| СРХ             | X – M                                                                                                                                                           | Compares the contents of index register X and memory.                                                                                                                                                                                                                                                                                            |    |     |   | E0 | 2   | 2 |    |     |      |                   |     |   | E4 | 3  | 2 |           |      |   |
| CPY             | Y – M                                                                                                                                                           | Compares the contents of index register Y and memory.                                                                                                                                                                                                                                                                                            |    |     |   | C0 | 2   | 2 |    |     |      |                   |     |   | C4 | 3  | 2 |           |      |   |
| DEC             | $A \leftarrow A - 1$ or $M \leftarrow M - 1$                                                                                                                    | Decrements the contents of the accumulator or memory by 1.                                                                                                                                                                                                                                                                                       |    |     |   |    |     |   | 1A | 2   | 1    |                   |     |   | C6 | 5  | 2 |           |      |   |
| DEX             | X ← X − 1                                                                                                                                                       | Decrements the contents of index register X by 1.                                                                                                                                                                                                                                                                                                | CA | 2   | 1 |    |     |   |    |     |      |                   |     |   |    |    |   |           |      |   |
| DEY             | Y ← Y − 1                                                                                                                                                       | Decrements the contents of index register Y by 1.                                                                                                                                                                                                                                                                                                | 88 | 2   | 1 |    |     |   |    |     |      |                   |     |   |    |    |   |           |      |   |
| DIV             | $\begin{aligned} A &\leftarrow (M(zz+X+1),\\ M(zz+X)) \ / \ A\\ M(S) &\leftarrow 1\text{'s complement}\\ \text{of Remainder}\\ S &\leftarrow S-1 \end{aligned}$ | Divides the 16-bit data that is the contents of M ( $zz + x + 1$ ) for high byte and the contents of M ( $zz + x$ ) for low byte by the accumulator. Stores the quotient in the accumulator and the 1's complement of the remainder on the stack.                                                                                                |    |     |   |    |     |   |    |     |      |                   |     |   |    |    |   |           |      |   |
| EOR<br>(Note 1) | When T = 0<br>$A \leftarrow A \forall M$<br>When T = 1<br>$M(X) \leftarrow M(X) \forall M$                                                                      | "Exclusive-ORs" the contents of accumulator and memory. The results are stored in the accumulator. "Exclusive-ORs" the contents of the memory specified by the addressing mode and the contents of the memory at the address indicated by index register X. The results are stored into the memory at the address indicated by index register X. |    |     |   | 49 | 2   | 2 |    |     |      |                   |     |   | 45 | 3  | 2 |           |      | _ |
| INC             | $A \leftarrow A + 1 \text{ or } M \leftarrow M + 1$                                                                                                             | Increments the contents of accumulator or memory by 1.                                                                                                                                                                                                                                                                                           |    |     |   |    |     |   | ЗА | 2   | 1    |                   |     |   | E6 | 5  | 2 |           |      |   |
| INX             | X ← X + 1                                                                                                                                                       | Increments the contents of index register X by 1.                                                                                                                                                                                                                                                                                                | E8 | 2   | 1 |    |     |   |    |     |      |                   |     |   |    |    |   |           |      |   |
| INY             | Y ← Y + 1                                                                                                                                                       | Increments the contents of index register Y by 1.                                                                                                                                                                                                                                                                                                | C8 | 2   | 1 |    |     |   |    |     |      |                   |     |   |    |    |   |           |      |   |

|    |       |   |    |   |   |    |   |   |    |   |   |    |   | Ad | dres | ssin | g m | ode |   |   |    |   |   |    |   |   |    |   |   |    |   |   | F | Proc | esso | or st | atus | reç | giste | r |
|----|-------|---|----|---|---|----|---|---|----|---|---|----|---|----|------|------|-----|-----|---|---|----|---|---|----|---|---|----|---|---|----|---|---|---|------|------|-------|------|-----|-------|---|
|    | ZP, ) |   |    |   |   |    |   |   |    |   |   |    |   |    |      | 2    | 1   | 0   |   |   |    |   |   |    |   |   |    |   |   |    |   |   |   |      |      |       |      |     |       |   |
| OP | n     | # | OP | n | # | OP | n | # | OP | n | # | OP | n | #  | OP   | n    | #   | OP  | n | # | OP | n | # | OP | n | # | OP | n | # | OP | n | # | N | V    | Т    | В     | D    | ı   | z     | С |
|    |       |   |    |   |   |    |   |   |    |   |   |    |   |    |      |      |     |     |   |   |    |   |   |    |   |   | 50 | 2 | 2 |    |   |   | • | •    | •    | •     | •    | •   | •     | • |
|    |       |   |    |   |   |    |   |   |    |   |   |    |   |    |      |      |     |     |   |   |    |   |   |    |   |   | 70 | 2 | 2 |    |   |   | • | •    | •    | •     | •    | •   | •     | • |
|    |       |   |    |   |   |    |   |   |    |   |   |    |   |    |      |      |     |     |   |   |    |   |   |    |   |   |    |   |   |    |   |   | • | •    | •    | •     | •    | •   | •     | • |
|    |       |   |    |   |   |    |   |   |    |   |   |    |   |    |      |      |     |     |   |   |    |   |   |    |   |   |    |   |   |    |   |   | • | •    | •    | •     | •    | •   | •     | 0 |
|    |       |   |    |   |   |    |   |   |    |   |   |    |   |    |      |      |     |     |   |   |    |   |   |    |   |   |    |   |   |    |   |   | • | •    | •    | •     | 0    | •   | •     | • |
|    |       |   |    |   |   |    |   |   |    |   |   |    |   |    |      |      |     |     |   |   |    |   |   |    |   |   |    |   |   |    |   |   | • | •    | •    | •     | •    | 0   | •     | • |
|    |       |   |    |   |   |    |   |   |    |   |   |    |   |    |      |      |     |     |   |   |    |   |   |    |   |   |    |   |   |    |   |   | • | •    | 0    | •     | •    | •   | •     | • |
|    |       |   |    |   |   |    |   |   |    |   |   |    |   |    |      |      |     |     |   |   |    |   |   |    |   |   |    |   |   |    |   |   | • | 0    | •    | •     | •    | •   | •     | • |
| D5 | 4     | 2 |    |   |   | CD | 4 | 3 | DD | 5 | 3 | D9 | 5 | 3  |      |      |     |     |   |   | C1 | 6 | 2 | D1 | 6 | 2 |    |   |   |    |   |   | N | •    | •    | •     | •    | •   | Z     | С |
|    |       |   |    |   |   |    |   |   |    |   |   |    |   |    |      |      |     |     |   |   |    |   |   |    |   |   |    |   |   |    |   |   | N | •    | •    | •     | •    | •   | Z     | • |
|    |       |   |    |   |   | EC | 4 | 3 |    |   |   |    |   |    |      |      |     |     |   |   |    |   |   |    |   |   |    |   |   |    |   |   | N | •    | •    | •     | •    | •   | Z     | С |
|    |       |   |    |   |   | СС | 4 | 3 |    |   |   |    |   |    |      |      |     |     |   |   |    |   |   |    |   |   |    |   |   |    |   |   | N | •    | •    | •     | •    | •   | Z     | С |
| D6 | 6     | 2 |    |   |   | CE | 6 | 3 | DE | 7 | 3 |    |   |    |      |      |     |     |   |   |    |   |   |    |   |   |    |   |   |    |   |   | N | •    | •    | •     | •    | •   | Z     | • |
|    |       |   |    |   |   |    |   |   |    |   |   |    |   |    |      |      |     |     |   |   |    |   |   |    |   |   |    |   |   |    |   |   | N | •    | •    | •     | •    | •   | Z     | • |
|    |       |   |    |   |   |    |   |   |    |   |   |    |   |    |      |      |     |     |   |   |    |   |   |    |   |   |    |   |   |    |   |   | N | •    | •    | •     | •    | •   | Z     | • |
| E2 | 16    | 2 |    |   |   |    |   |   |    |   |   |    |   |    |      |      |     |     |   |   |    |   |   |    |   |   |    |   |   |    |   |   | • | •    | •    | •     | •    | •   | •     | • |
| 55 | 4     | 2 |    |   |   | 4D | 4 | 3 | 5D | 5 | 3 | 59 | 5 | 3  |      |      |     |     |   |   | 41 | 6 | 2 | 51 | 6 | 2 |    |   |   |    |   |   | N | •    | •    | •     | •    | •   | Z     | • |
| F6 | 6     | 2 |    |   |   | EE | 6 | 3 | FE | 7 | 3 |    |   |    |      |      |     |     |   |   |    |   |   |    |   |   |    |   |   |    |   |   | N | •    | •    | •     | •    | •   | Z     | • |
|    |       |   |    |   |   |    |   |   |    |   |   |    |   |    |      |      |     |     |   |   |    |   |   |    |   |   |    |   |   |    |   |   | N | •    | •    | •     | •    | •   | Z     | • |
|    |       |   |    |   |   |    |   |   |    |   |   |    |   |    |      |      |     |     |   |   |    |   |   |    |   |   |    |   |   |    |   |   | N | •    | •    | •     | •    | •   | Z     | • |

## **APPENDIX**

|                 |                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                |    |     |   |    |     |   | Α  | ddr | essi | ing | mod  | е |    |    |   |    |      |   |
|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|-----|---|----|-----|---|----|-----|------|-----|------|---|----|----|---|----|------|---|
| Symbol          | Function                                                                                                                                                                                                                                                                                                                                                                                                                    | Details                                                                                                                                                                                                                                                                                        |    | IMF | > |    | IMI | Λ |    | Α   |      | E   | BIT, | Α |    | ΖP |   | ВІ | T, Z | Р |
|                 |                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                | ОР | n   | # | OF | n   | # | OP | n   | #    | OP  | n    | # | OP | n  | # | OP | n    | # |
| JMP             | If addressing mode is ABS PCL $\leftarrow$ ADL PCH $\leftarrow$ ADH If addressing mode is IND PCL $\leftarrow$ M (ADH, ADL) PCH $\leftarrow$ M (ADH, ADL + 1) If addressing mode is ZP, IND PCL $\leftarrow$ M(00, ADL) PCH $\leftarrow$ M(00, ADL + 1)                                                                                                                                                                     | Jumps to the specified address.                                                                                                                                                                                                                                                                |    |     |   |    |     |   |    |     |      |     |      |   |    |    |   |    |      |   |
| JSR             | $\begin{array}{l} M(S) \leftarrow PCH \\ S \leftarrow S-1 \\ M(S) \leftarrow PCL \\ S \leftarrow S-1 \\ After executing the above, if addressing mode is ABS, \\ PCL \leftarrow ADL \\ PCH \leftarrow ADH \\ if addressing mode is SP, \\ PCL \leftarrow ADL \\ PCH \leftarrow FF \\ If addressing mode is ZP, IND, \\ PCL \leftarrow M(00, ADL) \\ PCH \leftarrow M(00, ADL) \\ PCH \leftarrow M(00, ADL + 1) \end{array}$ | After storing contents of program counter in stack, and jumps to the specified address.                                                                                                                                                                                                        |    |     |   |    |     |   |    |     |      |     |      |   |    |    |   |    |      |   |
| LDA<br>(Note 2) |                                                                                                                                                                                                                                                                                                                                                                                                                             | Load accumulator with contents of memory.  Load memory indicated by index register X with contents of memory specified by the addressing mode.                                                                                                                                                 |    |     |   | AS | 2   | 2 |    |     |      |     |      |   | A5 | 3  | 2 |    |      |   |
| LDM             | M ← nn                                                                                                                                                                                                                                                                                                                                                                                                                      | Load memory with immediate value.                                                                                                                                                                                                                                                              |    |     |   |    |     |   |    |     |      |     |      |   | 3C | 4  | 3 |    |      |   |
| LDX             | $X \leftarrow M$                                                                                                                                                                                                                                                                                                                                                                                                            | Load index register X with contents of memory.                                                                                                                                                                                                                                                 |    |     |   | A2 | 2   | 2 |    |     |      |     |      |   | A6 | 3  | 2 |    |      |   |
| LDY             | $Y \leftarrow M$                                                                                                                                                                                                                                                                                                                                                                                                            | Load index register Y with contents of memory.                                                                                                                                                                                                                                                 |    |     |   | AC | 2   | 2 |    |     |      |     |      |   | A4 | 3  | 2 |    |      |   |
| LSR             | 7 0<br>0→→C                                                                                                                                                                                                                                                                                                                                                                                                                 | Shift the contents of accumulator or memory to the right by one bit. The low order bit of accumulator or memory is stored in carry, 7th bit is cleared.                                                                                                                                        |    |     |   |    |     |   | 4A | 2   | 1    |     |      |   | 46 | 5  | 2 |    |      |   |
| MUL             | $ \begin{array}{c} M(S) \cdot A \leftarrow A \times M(zz + X) \\ S \leftarrow S - 1 \end{array} $                                                                                                                                                                                                                                                                                                                           | Multiplies the accumulator with the contents of memory specified by the zero page X addressing mode and stores the high byte of the result on the stack and the low byte in the accumulator.                                                                                                   |    |     |   |    |     |   |    |     |      |     |      |   |    |    |   |    |      |   |
| NOP             | PC ← PC + 1                                                                                                                                                                                                                                                                                                                                                                                                                 | No operation.                                                                                                                                                                                                                                                                                  | EΑ | 2   | 1 |    |     |   |    |     |      |     |      |   |    |    |   |    |      |   |
| ORA<br>(Note 1) | When T = 0<br>$A \leftarrow A \lor M$<br>When T = 1<br>$M(X) \leftarrow M(X) \lor M$                                                                                                                                                                                                                                                                                                                                        | "Logical OR's" the contents of memory and accumulator. The result is stored in the accumulator. "Logical OR's" the contents of memory indicated by index register X and contents of memory specified by the addressing mode. The result is stored in the memory specified by index register X. |    |     |   | 09 | 2   | 2 |    |     |      |     |      |   | 05 | 3  | 2 |    |      |   |

|    |       |   |    |     |   |    |     |   |    |     |   |    |     | Ad | dres | sin | g m | ode |       |    |    |     |   |     |     |   |    |     |   |    |    |   | F | Proc | esso | or st | atus | s reg | giste | r |
|----|-------|---|----|-----|---|----|-----|---|----|-----|---|----|-----|----|------|-----|-----|-----|-------|----|----|-----|---|-----|-----|---|----|-----|---|----|----|---|---|------|------|-------|------|-------|-------|---|
|    | ZP, Z | X | Z  | ZP, | Υ |    | ABS | 3 | А  | BS, | Χ | Al | BS, | Υ  |      | IND |     | ZF  | P, IN | ID | ١١ | ۱D, | X | II. | ND, | Υ |    | REL |   |    | SP |   | 7 | 6    | 5    | 4     | 3    | 2     | 1     | 0 |
| OP | n     | # | OP | n   | # | OP | n   | # | OP | n   | # | OP | n   | #  | OP   | n   | #   | OP  | n     | #  | OP | n   | # | OP  | n   | # | OP | n   | # | OР | n  | # | N | ٧    | Т    | В     | D    | ı     | z     | С |
|    |       |   |    |     |   | 4C | 3   | 3 |    |     |   |    |     |    | 6C   | 5   | 3   | B2  | 4     | 2  |    |     |   |     |     |   |    |     |   |    |    |   | • | •    | •    | •     | •    | •     | •     | • |
|    |       |   |    |     |   | 20 | 6   | 3 |    |     |   |    |     |    |      |     |     | 02  | 7     | 2  |    |     |   |     |     |   |    |     |   | 22 | 5  | 2 | • | •    | ٠    | ٠     | •    | •     | ٠     | • |
| B5 | 4     | 2 |    |     |   | AD | 4   | 3 | BD | 5   | 3 | В9 | 5   | 3  |      |     |     |     |       |    | A1 | 6   | 2 | B1  | 6   | 2 |    |     |   |    |    |   | N | •    | •    | •     | •    | •     | Z     | • |
|    |       |   |    |     |   |    |     |   |    |     |   |    |     |    |      |     |     |     |       |    |    |     |   |     |     |   |    |     |   |    |    |   |   | •    | •    | •     | •    | •     | •     |   |
|    |       |   | В6 | 4   | 2 | ΑE | 4   | 3 |    |     |   | BE | 5   | 3  |      |     |     |     |       |    |    |     |   |     |     |   |    |     |   |    |    |   | N | •    | •    | •     | •    | •     | Z     | ٠ |
| В4 | 4     | 2 |    |     |   | AC | 4   | 3 | вс | 5   | 3 |    |     |    |      |     |     |     |       |    |    |     |   |     |     |   |    |     |   |    |    |   | N | •    | •    | •     | •    | •     | Z     | • |
| 56 | 6     | 2 |    |     |   | 4E | 6   | 3 | 5E | 7   | 3 |    |     |    |      |     |     |     |       |    |    |     |   |     |     |   |    |     |   |    |    |   | 0 | •    | •    | •     | •    | •     | Z     | С |
| 62 | 15    | 2 |    |     |   |    |     |   |    |     |   |    |     |    |      |     |     |     |       |    |    |     |   |     |     |   |    |     |   |    |    |   | • | •    | •    | •     | •    | •     | •     | • |
|    |       |   |    |     |   |    |     |   |    |     |   |    |     |    |      |     |     |     |       |    |    |     |   |     |     |   |    |     |   |    |    |   | · | •    | •    | •     | •    | •     | •     | • |
| 15 | 4     | 2 |    |     |   | 0D | 4   | 3 | 1D | 5   | 3 | 19 | 5   | 3  |      |     |     |     |       |    | 01 | 6   | 2 | 11  | 6   | 2 |    |     |   |    |    |   | N | •    | •    | •     | •    | •     | Z     | • |



|                             |                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                             |    |     |   |    |     |   | Δ  | ddre | essi | ng r              | mod  | е |    |    |   |           |      |   |
|-----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|-----|---|----|-----|---|----|------|------|-------------------|------|---|----|----|---|-----------|------|---|
| Symbol                      | Function                                                                                                                                                       | Details                                                                                                                                                                                                                                                                                                                                                                                                     |    | IMF | ) |    | IMN | 1 |    | Α    |      | В                 | SIT, | A |    | ΖP |   | ВІ        | T, Z | P |
|                             |                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                             | OP | n   | # | OP | n   | # | OP | n    | #    | OP                | n    | # | OP | n  | # | OP        | n    | # |
| PHA                         | $M(S) \leftarrow A \\ S \leftarrow S - 1$                                                                                                                      | Saves the contents of the accumulator in memory at the address indicated by the stack pointer and decrements the contents of stack pointer by 1.                                                                                                                                                                                                                                                            | 48 | 3   | 1 |    |     |   |    |      |      |                   |      |   |    |    |   |           |      |   |
| PHP                         | $M(S) \leftarrow PS \\ S \leftarrow S - 1$                                                                                                                     | Saves the contents of the processor status register in memory at the address indicated by the stack pointer and decrements the contents of the stack pointer by 1.                                                                                                                                                                                                                                          | 08 | 3   | 1 |    |     |   |    |      |      |                   |      |   |    |    |   |           |      |   |
| PLA                         | $\begin{array}{c} S \leftarrow S+1 \\ A \leftarrow M(S) \end{array}$                                                                                           | Increments the contents of the stack pointer by 1 and restores the accumulator from the memory at the address indicated by the stack pointer.                                                                                                                                                                                                                                                               | 68 | 4   | 1 |    |     |   |    |      |      |                   |      |   |    |    |   |           |      |   |
| PLP                         | $S \leftarrow S + 1$ $PS \leftarrow M(S)$                                                                                                                      | Increments the contents of stack pointer by 1 and restores the processor status register from the memory at the address indicated by the stack pointer.                                                                                                                                                                                                                                                     | 28 | 4   | 1 |    |     |   |    |      |      |                   |      |   |    |    |   |           |      |   |
| ROL                         | 7 0<br>← C←                                                                                                                                                    | Shifts the contents of the memory or accumulator to the left by one bit. The high order bit is shifted into the carry flag and the carry flag is shifted into the low order bit.                                                                                                                                                                                                                            |    |     |   |    |     |   | 2A | 2    | 1    |                   |      |   | 26 | 5  | 2 |           |      |   |
| ROR                         | 7 0<br>C                                                                                                                                                       | Shifts the contents of the memory or accumulator to the right by one bit. The low order bit is shifted into the carry flag and the carry flag is shifted into the high order bit.                                                                                                                                                                                                                           |    |     |   |    |     |   | 6A | 2    | 1    |                   |      |   | 66 | 5  | 2 |           |      |   |
| RRF                         | 7 0                                                                                                                                                            | Rotates the contents of memory to the right by 4 bits.                                                                                                                                                                                                                                                                                                                                                      |    |     |   |    |     |   |    |      |      |                   |      |   | 82 | 8  | 2 |           |      |   |
| RTI                         | $\begin{split} S \leftarrow S + 1 \\ PS \leftarrow M(S) \\ S \leftarrow S + 1 \\ PCL \leftarrow M(S) \\ S \leftarrow S + 1 \\ PCH \leftarrow M(S) \end{split}$ | Returns from an interrupt routine to the main routine.                                                                                                                                                                                                                                                                                                                                                      | 40 | 6   | 1 |    |     |   |    |      |      |                   |      |   |    |    |   |           |      |   |
| RTS                         | $\begin{array}{c} S \leftarrow S+1 \\ PCL \leftarrow M(S) \\ S \leftarrow S+1 \\ PCH \leftarrow M(S) \end{array}$                                              | Returns from a subroutine to the main routine.                                                                                                                                                                                                                                                                                                                                                              | 60 | 6   | 1 |    |     |   |    |      |      |                   |      |   |    |    |   |           |      |   |
| SBC<br>(Note 1)<br>(Note 5) | When T = 0<br>$A \leftarrow A - M - \overline{C}$<br>When T = 1<br>$M(X) \leftarrow M(X) - M - \overline{C}$                                                   | Subtracts the contents of memory and complement of carry flag from the contents of accumulator. The results are stored into the accumulator.  Subtracts contents of complement of carry flag and contents of the memory indicated by the addressing mode from the memory at the address indicated by index register X. The results are stored into the memory of the address indicated by index register X. |    |     |   | E9 | 2   | 2 |    |      |      |                   |      |   | E5 | 3  | 2 |           |      |   |
| SEB                         | Ab or Mb ← 1                                                                                                                                                   | Sets the specified bit in the accumulator or memory to "1".                                                                                                                                                                                                                                                                                                                                                 |    |     |   |    |     |   |    |      |      | 0 <u>В</u><br>20і | 2    | 1 |    |    |   | 0F<br>20i | 5    | 2 |
| SEC                         | C ← 1                                                                                                                                                          | Sets the contents of the carry flag to "1".                                                                                                                                                                                                                                                                                                                                                                 | 38 | 2   | 1 |    |     |   |    |      |      |                   |      |   |    |    |   |           |      |   |
| SED                         | D ← 1                                                                                                                                                          | Sets the contents of the decimal mode flag to "1".                                                                                                                                                                                                                                                                                                                                                          | F8 | 2   | 1 |    |     |   |    |      |      |                   |      |   |    |    |   |           |      |   |
| SEI                         | I ← 1                                                                                                                                                          | Sets the contents of the interrupt disable flag to "1".                                                                                                                                                                                                                                                                                                                                                     | 78 | 2   | 1 |    |     |   |    |      |      |                   |      |   |    |    |   |           |      |   |
| SET                         | T ← 1                                                                                                                                                          | Sets the contents of the index X mode flag to "1".                                                                                                                                                                                                                                                                                                                                                          | 32 | 2   | 1 |    |     |   |    |      |      |                   |      |   |    |    |   |           |      | ] |

|    |       |   |    |     |   |    |     |   |     |    |     |   |    |     | Ad | dres | ssin | g m | ode |       |    |    |     |   |    |     |   |    |     |   |    |    |   | F | Proc | esso | or st | atus  | s reç | giste | er e |
|----|-------|---|----|-----|---|----|-----|---|-----|----|-----|---|----|-----|----|------|------|-----|-----|-------|----|----|-----|---|----|-----|---|----|-----|---|----|----|---|---|------|------|-------|-------|-------|-------|------|
| Z  | ZP, 2 | X | 7  | ZP, | Υ |    | AB  | S |     | Αl | BS, | Х | А  | BS, | Υ  |      | IND  |     | ZF  | P, IN | 1D | 11 | ND, | X | 11 | ND, | Υ |    | REL | - |    | SP |   | 7 | 6    | 5    | 4     | 3     | 2     | 1     | 0    |
| OP | n     | # | OP | n   | # | OF | n   | # | # ( | OP | n   | # | OP | n   | #  | OP   | n    | #   | OP  | n     | #  | OP | n   | # | OP | n   | # | OP | n   | # | OP | n  | # | N | ٧    | Т    | В     | D     | ı     | Z     | С    |
|    |       |   |    |     |   |    |     |   |     |    |     |   |    |     |    |      |      |     |     |       |    |    |     |   |    |     |   |    |     |   |    |    |   | • | •    | •    | •     | •     | •     | •     | •    |
|    |       |   |    |     |   |    |     |   |     |    |     |   |    |     |    |      |      |     |     |       |    |    |     |   |    |     |   |    |     |   |    |    |   | • | •    | •    | •     | •     | •     | •     | •    |
|    |       |   |    |     |   |    |     |   |     |    |     |   |    |     |    |      |      |     |     |       |    |    |     |   |    |     |   |    |     |   |    |    |   | N | •    | •    | •     | •     | •     | Z     | •    |
|    |       |   |    |     |   |    |     |   |     |    |     |   |    |     |    |      |      |     |     |       |    |    |     |   |    |     |   |    |     |   |    |    |   |   | (Va  | lue  | sav   | ed i  | n sta | ack)  |      |
| 36 | 6     | 2 |    |     |   | 28 | 6   | ; | 3   | 3E | 7   | 3 |    |     |    |      |      |     |     |       |    |    |     |   |    |     |   |    |     |   |    |    |   | N | •    | •    | •     | •     | •     | Z     | С    |
| 76 | 6     | 2 |    |     |   | 6  | 6   | ; | 3   | 7E | 7   | 3 |    |     |    |      |      |     |     |       |    |    |     |   |    |     |   |    |     |   |    |    |   | N | •    | •    | •     | •     | •     | Z     | С    |
|    |       |   |    |     |   |    |     |   |     |    |     |   |    |     |    |      |      |     |     |       |    |    |     |   |    |     |   |    |     |   |    |    |   | • | •    | •    | •     | •     | •     | •     | •    |
|    |       |   |    |     |   |    |     |   |     |    |     |   |    |     |    |      |      |     |     |       |    |    |     |   |    |     |   |    |     |   |    |    |   |   | (Va  | lue  | sav   | ed ii | n sta | ack)  |      |
|    |       |   |    |     |   |    |     |   |     |    |     |   |    |     |    |      |      |     |     |       |    |    |     |   |    |     |   |    |     |   |    |    |   | • | •    | •    | •     | •     | •     | •     | •    |
| F5 | 4     | 2 |    |     |   | Εľ | 0 4 | ; | 3   | FD | 5   | 3 | F9 | 5   | 3  |      |      |     |     |       |    | E1 | 6   | 2 | F1 | 6   | 2 |    |     |   |    |    |   | N | V    | •    | •     | •     | •     | Z     | С    |
|    |       |   |    |     |   |    |     |   |     |    |     |   |    |     |    |      |      |     |     |       |    |    |     |   |    |     |   |    |     |   |    |    |   | • | •    | •    | •     | •     | •     | •     | •    |
|    |       |   |    |     |   |    |     |   |     |    |     |   |    |     |    |      |      |     |     |       |    |    |     |   |    |     |   |    |     |   |    |    |   | • | •    | •    | •     | •     | •     | •     | 1    |
|    |       |   |    |     |   |    |     |   |     |    |     |   |    |     |    |      |      |     |     |       |    |    |     |   |    |     |   |    |     |   |    |    |   | • | •    | •    | •     | 1     | •     | •     | ·    |
|    |       |   |    |     |   |    |     |   |     |    |     |   |    |     |    |      |      |     |     |       |    |    |     |   |    |     |   |    |     |   |    |    |   | • | •    |      | •     |       | 1     |       |      |
|    |       |   |    |     |   |    |     |   |     |    |     |   |    |     |    |      |      |     |     |       |    |    |     |   |    |     |   |    |     |   |    |    |   |   | •    | 1    | •     | •     | •     | •     | •    |

## **APPENDIX**

|        |                  |                                                                  |    |     |   |    |     |   | Α  | Addr | essi | ing ı | mod  | e |    |    |   |    |      |   |
|--------|------------------|------------------------------------------------------------------|----|-----|---|----|-----|---|----|------|------|-------|------|---|----|----|---|----|------|---|
| Symbol | Function         | Details                                                          |    | IMP | , |    | IMI | Л |    | Α    |      | Е     | BIT, | Α |    | ΖP |   | ВІ | T, Z | Р |
|        |                  |                                                                  | OP | n   | # | OF | n   | # | OP | n    | #    | OP    | n    | # | OP | n  | # | OP | n    | # |
| STA    | $M \leftarrow A$ | Stores the contents of accumulator in memory.                    |    |     |   |    |     |   |    |      |      |       |      |   | 85 | 4  | 2 |    |      |   |
| STP    |                  | Stops the oscillator.                                            | 42 | 2   | 1 |    |     |   |    |      |      |       |      |   |    |    |   |    |      |   |
| STX    | $M \leftarrow X$ | Stores the contents of index register X in memory.               |    |     |   |    |     |   |    |      |      |       |      |   | 86 | 4  | 2 |    |      |   |
| STY    | $M \leftarrow Y$ | Stores the contents of index register Y in memory.               |    |     |   |    |     |   |    |      |      |       |      |   | 84 | 4  | 2 |    |      |   |
| TAX    | X ← A            | Transfers the contents of the accumulator to index register X.   | AA | 2   | 1 |    |     |   |    |      |      |       |      |   |    |    |   |    |      |   |
| TAY    | Y ← A            | Transfers the contents of the accumulator to index register Y.   | А8 | 2   | 1 |    |     |   |    |      |      |       |      |   |    |    |   |    |      |   |
| TST    | M = 0?           | Tests whether the contents of memory are "0" or not.             |    |     |   |    |     |   |    |      |      |       |      |   | 64 | 3  | 2 |    |      |   |
| TSX    | X←S              | Transfers the contents of the stack pointer to index register X. | ВА | 2   | 1 |    |     |   |    |      |      |       |      |   |    |    |   |    |      |   |
| TXA    | $A \leftarrow X$ | Transfers the contents of index register X to the accumulator.   | 8A | 2   | 1 |    |     |   |    |      |      |       |      |   |    |    |   |    |      |   |
| TXS    | S←X              | Transfers the contents of index register X to the stack pointer. | 9A | 2   | 1 |    |     |   |    |      |      |       |      |   |    |    |   |    |      |   |
| TYA    | $A \leftarrow Y$ | Transfers the contents of index register Y to the accumulator.   | 98 | 2   | 1 |    |     |   |    |      |      |       |      |   |    |    |   |    |      |   |
| WIT    |                  | Stops the internal clock.                                        | C2 | 2   | 1 |    |     |   |    |      |      |       |      |   |    |    |   |    |      |   |

- Notes 1: The number of cycles "n" is increased by 3 when T is 1.

  2: The number of cycles "n" is increased by 2 when T is 1.

  3: The number of cycles "n" is increased by 1 when T is 1.

  4: The number of cycles "n" is increased by 2 when branching has occurred.

  5: N, V, and Z flags are invalid in decimal operation mode.

|    |       |   |    |       |   |    |     |   |    |     |   |    |     | Ad | dres | ssin | g m | ode |       |    |    |       |   |     |     |   |    |     |   |    |    |   | F | roc | esso | or st | atus | reç | giste | r |
|----|-------|---|----|-------|---|----|-----|---|----|-----|---|----|-----|----|------|------|-----|-----|-------|----|----|-------|---|-----|-----|---|----|-----|---|----|----|---|---|-----|------|-------|------|-----|-------|---|
| Z  | ZP, 2 | X | Z  | ZP, ` | Y | ,  | ABS | 3 | А  | BS, | Χ | А  | BS, | Υ  |      | IND  |     | ZF  | P, IN | ID | IN | ID, I | X | II. | ND, | Υ | F  | REL |   |    | SP |   | 7 | 6   | 5    | 4     | 3    | 2   | 1     | 0 |
| OP | n     | # | OР | n     | # | OP | n   | # | OP | n   | # | OP | n   | #  | OP   | n    | #   | OP  | n     | #  | OP | n     | # | OP  | n   | # | OP | n   | # | OP | n  | # | N | ٧   | Т    | В     | D    | ı   | z     | С |
| 95 | 5     | 2 |    |       |   | 8D | 5   | 3 | 9D | 6   | 3 | 99 | 6   | 3  |      |      |     |     |       |    | 81 | 7     | 2 | 91  | 7   | 2 |    |     |   |    |    |   | • | •   | •    | •     | •    | •   | •     | • |
|    |       |   |    |       |   |    |     |   |    |     |   |    |     |    |      |      |     |     |       |    |    |       |   |     |     |   |    |     |   |    |    |   | • | •   | •    | •     | •    | •   | •     | • |
|    |       |   | 96 | 5     | 2 | 8E | 5   | 3 |    |     |   |    |     |    |      |      |     |     |       |    |    |       |   |     |     |   |    |     |   |    |    |   | • | •   | •    | •     | •    | •   | •     | • |
| 94 | 5     | 2 |    |       |   | 8C | 5   | 3 |    |     |   |    |     |    |      |      |     |     |       |    |    |       |   |     |     |   |    |     |   |    |    |   | • | •   | •    | •     | •    | •   | •     | • |
|    |       |   |    |       |   |    |     |   |    |     |   |    |     |    |      |      |     |     |       |    |    |       |   |     |     |   |    |     |   |    |    |   | N | •   | •    | •     | •    | •   | Z     | • |
|    |       |   |    |       |   |    |     |   |    |     |   |    |     |    |      |      |     |     |       |    |    |       |   |     |     |   |    |     |   |    |    |   | N | •   | •    | •     | •    | •   | Z     | • |
|    |       |   |    |       |   |    |     |   |    |     |   |    |     |    |      |      |     |     |       |    |    |       |   |     |     |   |    |     |   |    |    |   | N | •   | •    | •     | •    | •   | Z     | • |
|    |       |   |    |       |   |    |     |   |    |     |   |    |     |    |      |      |     |     |       |    |    |       |   |     |     |   |    |     |   |    |    |   | N | •   | •    | •     | •    | •   | Z     | • |
|    |       |   |    |       |   |    |     |   |    |     |   |    |     |    |      |      |     |     |       |    |    |       |   |     |     |   |    |     |   |    |    |   | N | •   | •    | •     | •    | •   | Z     | • |
|    |       |   |    |       |   |    |     |   |    |     |   |    |     |    |      |      |     |     |       |    |    |       |   |     |     |   |    |     |   |    |    |   | • | •   | •    | •     | •    | •   | •     | • |
|    |       |   |    |       |   |    |     |   |    |     |   |    |     |    |      |      |     |     |       |    |    |       |   |     |     |   |    |     |   |    |    |   | N | •   | •    | •     | •    | •   | Z     | • |
|    |       |   |    |       |   |    |     |   |    |     |   |    |     |    |      |      |     |     |       |    |    |       |   |     |     |   |    |     |   |    |    |   | • | •   | •    | •     | •    | •   | •     | • |

| Symbol  | Contents                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Symbol      | Contents                                              |
|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|-------------------------------------------------------|
| IMP     | Implied addressing mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | +           | Addition                                              |
| IMM     | Immediate addressing mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | _           | Subtraction                                           |
| Α       | Accumulator or Accumulator addressing mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | ٨           | Logical OR                                            |
|         | , and the second | V           | Logical AND                                           |
| BIT, A  | Accumulator bit relative addressing mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | A           | Logical exclusive OR                                  |
|         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | _           | Negation                                              |
| ZP      | Zero page addressing mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | ←           | Shows direction of data flow                          |
| BIT, ZP | Zero page bit relative addressing mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | X           | Index register X                                      |
|         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Υ           | Index register Y                                      |
| ZP, X   | Zero page X addressing mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | S           | Stack pointer                                         |
| ZP, Y   | Zero page Y addressing mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | PC          | Program counter                                       |
| ABS     | Absolute addressing mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | PS          | Processor status register                             |
| ABS, X  | Absolute X addressing mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | РСн         | 8 high-order bits of program counter                  |
| ABS, Y  | Absolute Y addressing mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | PCL         | 8 low-order bits of program counter                   |
| IND     | Indirect absolute addressing mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | ADH         | 8 high-order bits of address                          |
|         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | ADL         | 8 low-order bits of address                           |
| ZP, IND | Zero page indirect absolute addressing mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | FF          | FF in Hexadecimal notation                            |
|         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | nn          | Immediate value                                       |
| IND, X  | Indirect X addressing mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | M           | Memory specified by address designation of any ad-    |
| IND, Y  | Indirect Y addressing mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |             | dressing mode                                         |
| REL     | Relative addressing mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | M(X)        | Memory of address indicated by contents of index      |
| SP      | Special page addressing mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |             | register X                                            |
| С       | Carry flag                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | M(S)        | Memory of address indicated by contents of stack      |
| Z       | Zero flag                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |             | pointer                                               |
| I       | Interrupt disable flag                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | M(ADH, ADL) | Contents of memory at address indicated by ADH and    |
| D       | Decimal mode flag                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |             | ADL, in ADH is 8 high-order bits and ADL is 8 low-or- |
| В       | Break flag                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |             | der bits.                                             |
| T       | X-modified arithmetic mode flag                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | M(00, ADL)  | Contents of address indicated by zero page ADL        |
| V       | Overflow flag                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Ab          | 1 bit of accumulator                                  |
| N       | Negative flag                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Mb          | 1 bit of memory                                       |
|         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | OP          | Opcode                                                |
|         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | n<br>       | Number of cycles                                      |
|         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | #           | Number of bytes                                       |



## 3.10 List of instruction codes

## 3.10 List of instruction codes

|         | D3 – D0               | 0000       | 0001          | 0010           | 0011        | 0100         | 0101         | 0110         | 0111         | 1000 | 1001          | 1010     | 1011        | 1100          | 1101          | 1110          | 1111         |
|---------|-----------------------|------------|---------------|----------------|-------------|--------------|--------------|--------------|--------------|------|---------------|----------|-------------|---------------|---------------|---------------|--------------|
| D7 – D4 | xadecimal<br>notation | 0          | 1             | 2              | 3           | 4            | 5            | 6            | 7            | 8    | 9             | A        | В           | С             | D             | E             | F            |
| 0000    | 0                     | BRK        | ORA<br>IND, X | JSR<br>ZP, IND | BBS<br>0, A | _            | ORA<br>ZP    | ASL<br>ZP    | BBS<br>0, ZP | PHP  | ORA<br>IMM    | ASL<br>A | SEB<br>0, A | _             | ORA<br>ABS    | ASL<br>ABS    | SEB<br>0, ZP |
| 0001    | 1                     | BPL        | ORA<br>IND, Y | CLT            | BBC<br>0, A | _            | ORA<br>ZP, X | ASL<br>ZP, X | BBC<br>0, ZP | CLC  | ORA<br>ABS, Y | DEC<br>A | CLB<br>0, A | _             | ORA<br>ABS, X | ASL<br>ABS, X | CLB<br>0, ZP |
| 0010    | 2                     | JSR<br>ABS | AND<br>IND, X | JSR<br>SP      | BBS<br>1, A | BIT<br>ZP    | AND<br>ZP    | ROL<br>ZP    | BBS<br>1, ZP | PLP  | AND<br>IMM    | ROL<br>A | SEB<br>1, A | BIT<br>ABS    | AND<br>ABS    | ROL<br>ABS    | SEB<br>1, ZP |
| 0011    | 3                     | BMI        | AND<br>IND, Y | SET            | BBC<br>1, A | ı            | AND<br>ZP, X | ROL<br>ZP, X | BBC<br>1, ZP | SEC  | AND<br>ABS, Y | INC<br>A | CLB<br>1, A | LDM<br>ZP     | AND<br>ABS, X | ROL<br>ABS, X | CLB<br>1, ZP |
| 0100    | 4                     | RTI        | EOR<br>IND, X | STP            | BBS<br>2, A | COM<br>ZP    | EOR<br>ZP    | LSR<br>ZP    | BBS<br>2, ZP | PHA  | EOR<br>IMM    | LSR<br>A | SEB<br>2, A | JMP<br>ABS    | EOR<br>ABS    | LSR<br>ABS    | SEB<br>2, ZP |
| 0101    | 5                     | BVC        | EOR<br>IND, Y | _              | BBC<br>2, A | -            | EOR<br>ZP, X | LSR<br>ZP, X | BBC<br>2, ZP | CLI  | EOR<br>ABS, Y | _        | CLB<br>2, A | _             | EOR<br>ABS, X | LSR<br>ABS, X | CLB<br>2, ZP |
| 0110    | 6                     | RTS        | ADC<br>IND, X | MUL<br>ZP, X   | BBS<br>3, A | TST<br>ZP    | ADC<br>ZP    | ROR<br>ZP    | BBS<br>3, ZP | PLA  | ADC<br>IMM    | ROR<br>A | SEB<br>3, A | JMP<br>IND    | ADC<br>ABS    | ROR<br>ABS    | SEB<br>3, ZP |
| 0111    | 7                     | BVS        | ADC<br>IND, Y | _              | BBC<br>3, A | _            | ADC<br>ZP, X | ROR<br>ZP, X | BBC<br>3, ZP | SEI  | ADC<br>ABS, Y | _        | CLB<br>3, A | _             | ADC<br>ABS, X | ROR<br>ABS, X | CLB<br>3, ZP |
| 1000    | 8                     | BRA        | STA<br>IND, X | RRF<br>ZP      | BBS<br>4, A | STY<br>ZP    | STA<br>ZP    | STX<br>ZP    | BBS<br>4, ZP | DEY  | _             | TXA      | SEB<br>4, A | STY<br>ABS    | STA<br>ABS    | STX<br>ABS    | SEB<br>4, ZP |
| 1001    | 9                     | BCC        | STA<br>IND, Y | _              | BBC<br>4, A | STY<br>ZP, X | STA<br>ZP, X | STX<br>ZP, Y | BBC<br>4, ZP | TYA  | STA<br>ABS, Y | TXS      | CLB<br>4, A | _             | STA<br>ABS, X | _             | CLB<br>4, ZP |
| 1010    | А                     | LDY<br>IMM | LDA<br>IND, X | LDX<br>IMM     | BBS<br>5, A | LDY<br>ZP    | LDA<br>ZP    | LDX<br>ZP    | BBS<br>5, ZP | TAY  | LDA<br>IMM    | TAX      | SEB<br>5, A | LDY<br>ABS    | LDA<br>ABS    | LDX<br>ABS    | SEB<br>5, ZP |
| 1011    | В                     | BCS        | LDA<br>IND, Y | JMP<br>ZP, IND | BBC<br>5, A | LDY<br>ZP, X | LDA<br>ZP, X | LDX<br>ZP, Y | BBC<br>5, ZP | CLV  | LDA<br>ABS, Y | TSX      | CLB<br>5, A | LDY<br>ABS, X | LDA<br>ABS, X | LDX<br>ABS, Y | CLB<br>5, ZP |
| 1100    | С                     | CPY<br>IMM | CMP<br>IND, X | WIT            | BBS<br>6, A | CPY<br>ZP    | CMP<br>ZP    | DEC<br>ZP    | BBS<br>6, ZP | INY  | CMP<br>IMM    | DEX      | SEB<br>6, A | CPY<br>ABS    | CMP<br>ABS    | DEC<br>ABS    | SEB<br>6, ZP |
| 1101    | D                     | BNE        | CMP<br>IND, Y | -              | BBC<br>6, A | _            | CMP<br>ZP, X | DEC<br>ZP, X | BBC<br>6, ZP | CLD  | CMP<br>ABS, Y | _        | CLB<br>6, A | _             | CMP<br>ABS, X | DEC<br>ABS, X | CLB<br>6, ZP |
| 1110    | Е                     | CPX<br>IMM | SBC<br>IND, X | DIV<br>ZP, X   | BBS<br>7, A | CPX<br>ZP    | SBC<br>ZP    | INC<br>ZP    | BBS<br>7, ZP | INX  | SBC<br>IMM    | NOP      | SEB<br>7, A | CPX<br>ABS    | SBC<br>ABS    | INC<br>ABS    | SEB<br>7, ZP |
| 1111    | F                     | BEQ        | SBC<br>IND, Y | _              | BBC<br>7, A | _            | SBC<br>ZP, X | INC<br>ZP, X | BBC<br>7, ZP | SED  | SBC<br>ABS, Y | _        | CLB<br>7, A | _             | SBC<br>ABS, X | INC<br>ABS, X | CLB<br>7, ZP |

| 3-bvte | instruction |
|--------|-------------|

<sup>2-</sup>byte instruction

<sup>1-</sup>byte instruction

## 3.11 SFR memory map

| 000016             | Port P0 (P0)                              | 002016             | Timer X (low-order) (TXL)                   |
|--------------------|-------------------------------------------|--------------------|---------------------------------------------|
| 000016             | Port P0 direction register (P0D)          | 002016             | Timer X (high-order) (TXH)                  |
| 000116             | Port P1 (P1)                              | 002116             | Timer Y (low-order) (TYL)                   |
| 000216             | Port P1 direction register (P1D)          | 002216             | Timer Y (high-order) (TYH)                  |
| 000416             | Port P2 (P2)                              | 002416             | Timer 1 (T1)                                |
| 000516             | Port P2 direction register (P2D)          | 002516             | Timer 2 (T2)                                |
| 000616             | Port P3 (P3)                              | 002616             | Timer 3 (T3)                                |
| 000716             | Port P3 direction register (P3D)          | 002716             | Timer X mode register (TXM)                 |
| 000816             | Port P4 (P4)                              | 002816             | Timer Y mode register (TYM)                 |
| 000916             | Port P4 direction register (P4D)          | 002916             | Timer 123 mode register (T123M)             |
| 000A16             | Port P5 (P5)                              | 002A16             | Real time port register (RTP)               |
| 000B16             | Port P5 direction register (P5D)          | 002B <sub>16</sub> | Real time port control register 0 (RTPCON0) |
| 000C16             | Port P6 (P6)                              | 002C16             | Real time port control register 1 (RTPCON1) |
| 000D16             | Port P6 direction register (P6D)          | 002D16             | Real time port control register 2 (RTPCON2) |
| 000E16             | Port P7 (P7)                              | 002E <sub>16</sub> | Real time port control register 3 (RTPCON3) |
| 000F16             | Port P7 direction register (P7D)          | 002F16             | Timer A (low-order) (TAL)                   |
| 001016             | Port P8 (P8)                              | 003016             | Timer A (high-order) (TAH)                  |
| 001116             | Port P8 direction register (P8D)          | 003116             | Timer B (low-order) (TBL)                   |
| 001216             |                                           | 003216             | Timer B (high-order) (TBH)                  |
| 001316             |                                           | 003316             | D-A control register (DACON)                |
| 001416             | Timer XY control register (TXYCON)        | 003416             | A-D control register (ADCON)                |
| 001516             | Port P2P3 control register (P2P3C)        | 003516             | A-D conversion register (AD)                |
| 001616             | Pull-up control register (PULL)           | 003616             | D-A1 conversion register (DA1)              |
| 001716             | Watchdog timer control register (WDTCON)  | 003716             | D-A2 conversion register (DA2)              |
| 001816             | Transmit/Receive buffer register (TB/RB)  | 003816             | D-A3 conversion register (DA3)              |
| 001916             | Serial I/O1 status register (SIO1STS)     | 003916             | D-A4 conversion register (DA4)              |
| 001A <sub>16</sub> | Serial I/O1 control register (SIO1CON)    | 003A16             | Interrupt edge selection register (INTEDGE) |
| 001B <sub>16</sub> | UART control register (UARTCON)           | 003B <sub>16</sub> | CPU mode register (CPUM)                    |
| 001C <sub>16</sub> | Baud rate generator (BRG)                 | 003C16             | Interrupt request register 1(IREQ1)         |
| 001D <sub>16</sub> | Serial I/O2 control register 1 (SIO2CON1) | 003D16             | Interrupt request register 2(IREQ2)         |
| 001E <sub>16</sub> | Serial I/O2 control register 2 (SIO2CON2) | 003E16             | Interrupt control register 1(ICON1)         |
| 001F <sub>16</sub> | Serial I/O2 register (SIO2)               | 003F16             | Interrupt control register 2(ICON2)         |
|                    |                                           |                    |                                             |

#### 3.12 Pin configuration



#### MITSUBISHI SEMICONDUCTORS USER'S MANUAL 3807 Group

Nov. First Edition 1996

Editioned by

Committee of editing of Mitsubishi Semiconductor USER'S MANUAL

Published by

Mitsubishi Electric Corp., Semiconductor Marketing Division

This book, or parts thereof, may not be reproduced in any form without permission of Mitsubishi Electric Corporation.

©1996 MITSUBISHI ELECTRIC CORPORATION

## 3807 Group User's Manual



| REVISION DESCRIPTION LIST | 3807 Group User's Manual |
|---------------------------|--------------------------|
|                           | 1                        |

| Rev. | Revision Description | Rev.   |
|------|----------------------|--------|
| No.  | Revision Description | date   |
| 1.0  | First Edition        | 971101 |
|      |                      |        |
|      |                      |        |
|      |                      |        |
|      |                      |        |
|      |                      |        |
|      |                      |        |
|      |                      |        |
|      |                      |        |
|      |                      |        |
|      |                      |        |
|      |                      |        |
|      |                      |        |
|      |                      |        |
|      |                      |        |
|      |                      |        |
|      |                      |        |
|      |                      |        |
|      |                      |        |
|      |                      |        |
|      |                      |        |
|      |                      |        |
|      |                      |        |
|      |                      |        |
|      |                      |        |
|      |                      |        |
|      |                      |        |
|      |                      |        |
|      |                      |        |
|      |                      |        |
|      |                      |        |
|      |                      |        |
|      |                      |        |
|      |                      |        |
|      |                      |        |
|      |                      |        |
|      |                      |        |