



# μ**PD75336**

# **4-BIT SINGLE-CHIP MICROCOMPUTER**

μPD75336 μPD75P338

© NEC Corporation 1991

6427525 0094844 68T **8** 

This Material Copyrighted By Its Respective Manufacturer

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

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

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

The devices listed in this document are not suitable for use in aerospace equipment, submarine cables, nuclear reactor control systems and life support systems. If customers intend to use NEC devices for above applications or they intend to use "Standard" quality grade NEC devices for applications not intended by NEC, please contact our sales people in advance.

Application examples recommended by NEC Corporation

Standard: Computer, Office equipment, Communication equipment, Test and Measurement equipment, Machine tools, Industrial robots, Audio and Visual equipment, Other consumer products, etc.

Special: Automotive and Transportation equipment, Traffic control systems, Antidisaster systems, Anticrime systems, etc.

M7 92.6

💶 6427525 0094845 516 🎟

# Major Revisions in This Edition

| Location        | Description                                                                                           |
|-----------------|-------------------------------------------------------------------------------------------------------|
| Whole<br>manual | uPD75P336GK Under development → Development<br>completed                                              |
| 1-6             | Amendment of Table 1-1 "Differences between<br>uPD75336 and uPD75P336"                                |
| 2-13            | 2.2.10 INTO, INT1<br>Addition of text covering STOP mode and HALT mode<br>release                     |
| 2-14            | 2.2.11 INT2<br>Addition of text covering STOP mode and HALT mode<br>release                           |
| 2-18            | Amendment of 2.2.26 IC (uPD75336 only) item                                                           |
| 5-7             | Amendment of Figure 5-3 "Configurations of Ports 3n and 6n"                                           |
| 5-7             | Amendment of Figure 5-4 "Configurations of Ports 2<br>and 7                                           |
| 5-8             | Addition of cautions to Table 5-5 "Maximum Time<br>Required for System Clock and CPU Clock Switching" |
| 6-6             | Amendment of text in 6.3 (1) "Interrupt request flags<br>& interrupt enable flags"                    |
| 8-1             | Amendment of Table 8-1 "Hardware Status after Reset"                                                  |
| B-1             | Appendix B "Development Tools" Version upgrade of relevant MS-DOS (Ver. 5.00/5.00A)                   |

- i -• 6427525 0094846 452 🎟 PREFACE

Intended

Readership : This manual is intended for user engineers who understand the uPD75336 and uPD75P336 functions and wish to design an application system with those functions.

Purpose : This manual has been prepared to enable the users to have an understanding of the uPD75336 and uPD75P336 hardware functions.

How to Read

- this Manual: Readers of this manual are required to have a general knowledge of electric and logic circuits and microcomputers.
  - . Users who have previously used the uPD75328
    - → The basic functions are the same. The uPD75336 can be used as the 16K version of the uPD75328. The uPD75336 has an improved CPU (instructions and registers) and timer. Refer to Appendix A. "Functional comparison of uPD75336, uPD75P336 and uPD75328" for details of additional functions and instructions.
  - . Users who use this manual for the uPD75P336
    - → Unless there are functional differences, this manual describes the uPD75336 as a representative type. After checking the functional differences by referring to Section 1.3 "Differences between uPD75336 and uPD75P336", use this manual by replacing "uPD75336" with "uPD75P336".

- ii -• 6427525 0094847 399 •

- . When checking instruction functions with knowledge of mnemonics
  - > Refer to Appendix D.2 "Instruction Index
    (in Alphabetical Order)".
- . When checking instructions with understanding of functions but not mnemonics
  - Check the mnemonics of functions by referring to Section 10.2 "Instruction Set and Operations" and then check the functions by referring to Section 10.4 "Instruction Functions and Use".
- . When having an understanding of uPD75336 and uPD75P336
  - After checking the main functions by referring to Section 1.1 "Function Outline", read this manual in the order of the contents.
- . For the electrical specifications of the uPD75336/75P336

→ See the separate Data Sheet.

- iii -■ 6427525 0094848 225 ■

This Material Copyrighted By Its Respective Manufacturer

| Legend | : | Data representation | ns: | Most significant digit on<br>the left and least<br>significant digit on the<br>right |
|--------|---|---------------------|-----|--------------------------------------------------------------------------------------|
|        |   | Active-low          |     |                                                                                      |
|        |   | representations     | :   | $\overline{xxx}$ (line above pin and                                                 |
|        |   |                     |     | signal names)                                                                        |
|        |   | Memory map address  | :   | Upper - low, lower - high                                                            |
|        |   | *                   | :   | Description of * in the text                                                         |
|        |   | NOTE                | :   | Contents to be read with                                                             |
|        |   |                     |     | particular attention                                                                 |
|        |   | Remarks             | :   | Supplementary description of                                                         |
|        |   |                     |     | text                                                                                 |
|        |   | Numeric             |     |                                                                                      |
|        |   | representations     | :   | Binary number xxxx                                                                   |
|        |   |                     |     | or xxxxB                                                                             |
|        |   |                     |     | Decimal number xxxx                                                                  |
|        |   |                     |     | Hexadecimal number xxxxH                                                             |
|        |   |                     |     |                                                                                      |

Relevant Documents

 $\sim$ 

Device Documentation

| Product                        | uPD75336    | uPD75P336 |  |  |
|--------------------------------|-------------|-----------|--|--|
| Document                       |             |           |  |  |
| Data Sheet                     | IC-7972     | IC-8371   |  |  |
| User's Manual                  | This manual |           |  |  |
| Instruction Operation<br>Table | IEM-5516    |           |  |  |
| 75X Series<br>Selection Guide  | IF-151      |           |  |  |

■ 6427525 0094849 161 ■ - iv - Development Tool Documentation

|                  | Document Name                       | Document No.     |           |
|------------------|-------------------------------------|------------------|-----------|
| н<br>а           | IE-75000-R/IE-75001-R               | EEU-846          |           |
| r                | IE-75000-R-EM User's                | EEU-673          |           |
| w<br>a<br>r<br>e | EP-75336GC-R User's M               | EEU-691          |           |
|                  | EP-75336GK-R User's M               | EEU-837          |           |
|                  | PG-1500 User's Manual               | EEU-651          |           |
| S<br>O           | RA75X<br>Assembler Package          | Operation Volume | · EEU-731 |
| f<br>t           | User's Manual                       | Language Volume  | EEU-730   |
| w<br>a<br>r<br>e | PG-1500 Controller<br>User's Manual | EEU-704          |           |

Other Documentation

| Document Name                                                       | Document No. |
|---------------------------------------------------------------------|--------------|
| Package Manual                                                      | IEI-635      |
| Semiconductor Device Mounting Manual                                | IEI-616      |
| NEC Semiconductor Device Quality Standards                          | IEI-620      |
| NEC Semiconductor Device Reliability and<br>Quality Control         | IEM-5068     |
| Electrostatic Discharge (ESD) Testing                               | MEM-539      |
| Semiconductor Device Quality Assurance Guide                        | MEI-603      |
| Microcomputer Related Product Guide<br>- Other Manufacturers Volume | MEI-604      |

NOTE: The contents of the above documents are subject to change without notice. Please ensure that the latest versions are used for design work, etc.

■ 6427525 0094850 983 ■ - v -

#### CONTENTS

| CHAPTER 1. | OVERVIEW                                  | . 1-1 |
|------------|-------------------------------------------|-------|
| 1.1 F      | unction Outline                           | 1-3   |
|            | rdering Information and Quality Grade     |       |
|            | ifferences between uPD75336 and uPD75P336 |       |
|            | lock Diagram                              |       |
|            | in Configuration                          |       |
|            |                                           | 1 2   |
| CHAPTER 2. | PIN FUNCTIONS                             | 2-1   |
| 2.1 L      | ist of uPD75336 Pin Functions             | 2-1   |
|            | escription of Pin Functions               |       |
| 2.2.1      | P00 to P03 (PORTO), P10 to P13 (PORT1)    |       |
| 2.2.2      | P20 to P23 (PORT2), P30 to P33 (PORT3),   |       |
|            | P40 to P43 (PORT4), P50 to P53 (PORT5),   |       |
|            | P60 to P63 (PORT6), P70 to P73 (PORT7),   |       |
|            | P80 to P83 (PORT8)                        | 2-10  |
| 2.2.3      | BP0 to BP7                                | 2-11  |
| 2.2.4      | TIO, TI1                                  | 2-11  |
| 2.2.5      | PT00, PT01                                | 2-11  |
| 2.2.6      | PCL                                       | 2-12  |
| 2.2.7      | BUZ                                       | 2-12  |
| 2.2.8      | SCK, SO/SBO, SI/SB1                       | 2-12  |
| 2.2.9      | INT4                                      |       |
| 2.2.10     | INTO, INT1                                | 2-13  |
| 2.2.11     | INT2                                      | 2-14  |
| 2.2.12     | KRO to KR3, KR4 to KR7                    | 2-15  |
| 2.2.13     | S12 to S23, S24 to S31                    |       |
| 2.2.14     | COMO to COM3                              | 2-15  |
| 2.2.15     | $v_{LC0}$ to $v_{LC2}$                    |       |
| 2.2.16     | BIAS                                      |       |
| 2.2.17     | LCDCL                                     |       |
| 2.2.18     | SYNC                                      |       |
| 2.2.19     | ANO to AN5, AN6 & AN7                     | 2-16  |
| 2.2.20     | AV <sub>REF</sub>                         | 2-16  |
| 2.2.21     | AV <sub>SS</sub>                          | 2-16  |

- vi -6427525 0094851 81T 🎟

| 2.2.22 X1             | , X2                                        | 2-17 |
|-----------------------|---------------------------------------------|------|
| 2.2.23 XT             | 1, XT2                                      | 2-17 |
| 2.2.24 RE             | SET                                         | 2-18 |
| 2.2.25 MD             | 0 to MD3 (uPD75P336 Only)                   | 2-18 |
| 2.2.26 IC             | (uPD75P336 Only)                            | 2-18 |
| 2.2.27 V <sub>P</sub> | p (uPD75P336 Only)                          | 2-19 |
| 2.2.28 V <sub>D</sub> | D                                           | 2-19 |
| 2.2.29 V <sub>S</sub> | s ••••••••••••••••••••••••••••••••••••      | 2-19 |
| 2.3 Pin I             | nput/Output Circuits                        | 2-20 |
| 2.4 Recom             | mended Connection of Unused Pins            | 2-23 |
| 2.5 Mask              | Option Selection                            | 2-24 |
| •                     |                                             |      |
| CHAPTER 3. DA         | TA MEMORY OPERATION AND MEMORY MAP          | 3-1  |
|                       |                                             |      |
|                       | Memory Bank Configuration and Addressing    |      |
| Mode                  | • • • • • • • • • • • • • • • • • • • •     | 3-2  |
| 3.1.1 Da              | ta Memory Bank Configuration                | 3-2  |
|                       | ta Memory Addressing Mode                   |      |
|                       | al Register Bank Configuration              |      |
| 3.3 Memory            | y Mapped I/O                                | 3-27 |
| CHAPTER 4. IN         | TERNAL CPU FUNCTIONS                        | 4-1  |
| 4.1 Progra            | am Counter (PC)                             | 4-1  |
| -                     | am Memory (ROM)                             |      |
| -                     | Memory (RAM)                                |      |
|                       | al Register                                 |      |
|                       | ulator                                      |      |
|                       | Pointer (SP)                                |      |
|                       | am Status Word (PSW)                        |      |
| -                     | Select Register (BS)                        |      |
|                       |                                             |      |
| CHAPTER 5. PER        | RIPHERAL HARDWARE FUNCTIONS                 | 5-1  |
| 5.1 Digita            | al Input/Output Ports                       | 5-1  |
| 5.1.1 Typ             | pes, Features and Configurations of Digital |      |
| Ing                   | put/Output Ports                            | 5-4  |
| 5.1.2 Ing             | put/Output Mode Setting                     | 5-10 |
|                       | - <b>v</b> ii -                             |      |

🔲 6427525 0094852 756 📟

| 5.1.3          | Digital Input/Output Port Operation            |       |
|----------------|------------------------------------------------|-------|
|                | Instructions                                   | 5-12  |
| 5.1.4          | Digital Input/Output Port Operations           | 5-16  |
| 5.1.5          | On-Chip Pull-Up Resistor                       | 5-19  |
| 5.1.6          | Digital Input/Output Port Input/Output         |       |
|                | Timings                                        | 5-22  |
| 5.2            | Clock Generator                                | 5-25  |
| 5.2.1          | Clock Generator Configuration                  | 5-25  |
| 5.2.2          | Clock Generator Functions and Operations       | 5-27  |
| 5.2.3          | System Clock and CPU Clock Settings            | 5-38  |
| 5.2.4          | Clock Output Circuit                           | 5-42  |
| 5.3            | Basic Interval Timer                           | 5-46  |
| 5.3.1          | Basic Interval Timer Configuration             | 5-46  |
| 5.3.2          | Basic Interval Timer Mode Register (BTM)       | •     |
| 5.3.3          | Basic Interval Timer Operation                 |       |
| 5.3.4          | Basic Interval Timer Application Example       |       |
|                | Watch Timer                                    |       |
| 5.4.1          | Watch Timer Configuration                      |       |
| 5.4.2          | Clock Mode Register                            |       |
|                | Timer/Event Counter                            |       |
| 5.5.1          | Timer/Event Counter Configuration              | 5-57  |
| 5.5.2          | Timer/Event Counter Basic Configuration and    |       |
|                | Operation                                      | 5-59  |
| 5.5.3          | Timer/Event Counter Mode Registers (TMO,       |       |
|                | TM1)                                           | 5-60  |
| 5.5.4          | Timer/Event Counter Output Enable Flags (TOEO, |       |
|                | TOE1)                                          |       |
| 5.5.5          | Timer/Event Counter Operating Modes            |       |
| 5.5.6          | Timer/Event Counter Time Setting               |       |
| 5.5.7          | Timer/Event Counter Application Precautions    |       |
| 5.5.8          | Timer/Event Counter Applications               |       |
|                | Serial Interface                               |       |
| 5.6.1          | Serial Interface Functions                     |       |
| 5.6.2          | Serial Interface Configuration                 |       |
| 5.6.3<br>5.6.4 | Register Functions                             |       |
| 5.6.5          | Operation-Halted Mode                          |       |
|                | 3-Wire Serial I/O Mode Operation               |       |
| 5.6.6          | 2-Wire Serial I/O Mode Operation               | 5-105 |

### - viii -6427525 0094853 692 🎟

| 5.6.7   | ' SBI Mode Operation                                                       | 5-115 |
|---------|----------------------------------------------------------------------------|-------|
| 5.6.8   | SCK Pin Output Manipulation                                                | 5-158 |
| 5.7     | LCD Controller/Driver                                                      | 5-161 |
| 5.7.1   | LCD Controller/Driver Configuration                                        | 5-161 |
| 5.7.2   | LCD Controller/Driver Functions                                            | 5-163 |
| 5.7.3   | Display Mode Register                                                      | 5-165 |
| 5.7.4   | Display Control Register                                                   | 5-167 |
| 5.7.5   | Display Data Memory                                                        | 5-168 |
| 5.7.6   | Common Signal and Segment Signal                                           | 5-171 |
| 5.7.7   | $v_{ m LC0}^{}, v_{ m LC1}^{},$ and $v_{ m LC2}^{}$ Power Supplies for LCD |       |
|         | Drive                                                                      | 5-177 |
| 5.7.8   | Display Modes                                                              | 5-182 |
| 5.8     | A/D Converter                                                              | 5-199 |
| 5.8.1   | A/D Converter Configuration                                                | 5-199 |
| 5.8.2   | A/D Converter Operations                                                   | 5-204 |
| 5.8.3   | Standby Mode Precautions                                                   | 5-207 |
| 5.8.4   | Operating Precautions and Others                                           | 5-209 |
| 5.9     | Bit Sequential Buffer                                                      | 5-211 |
| CHAPTER | 6. INTERRUPT FUNCTIONS                                                     | 6-1   |
| 6.1     | Interrupt Control Circuit Configuration                                    | 6-1   |
| 6.2     | Interrupt Source Types and Vector Table                                    | 6-3   |
| 6.3     | Interrupt Control Circuit Hardware                                         | 6-6   |
| 6.4     | Interrupt Sequence                                                         | 6-21  |
| 6.5     | Multiple Interrupt Service Control                                         | 6-22  |
| 6.6     | Vector Address Sharing Interrupt Servicing                                 | 6-25  |
| 6.7     | Machine Cycles until Interrupt Servicing                                   | 6-28  |
| 6.8     | Effective Use of Interrupts                                                | 6-32  |
| 6.9     | Use of Interrupts                                                          | 6-34  |
| CHAPTER | 7. STANDBY FUNCTIONS                                                       | 7-1   |
| 7.1     | Standby Mode Setting and Operating Status                                  | 7-3   |
| 7.2     | Standby Mode Release                                                       | 7-6   |
| 7.3     | Operation after Standby Mode Release                                       | 7-9   |
| 7.4     | Use of Standby Mode                                                        | 7-10  |
|         |                                                                            |       |

- ix -■ 6427525 0094854 529 ■  $\mathbf{i}$ 

| CHAPTER 8.  | RESET FUNCTION                                    | 8-1   |
|-------------|---------------------------------------------------|-------|
| CHAPTER 9.  | PROM (PROGRAM MEMORY) WRITE AND VERIFY OPERATIONS | 9-1   |
| 9.1 Pr      | ogram Memory Write/Verify Operating Modes         | 9-2   |
| 9.2 Pr      | ogram Memory Write Procedure                      | 9-3   |
| 9.3 Pr      | ogram Memory Read Procedure                       | 9-5   |
| CHAPTER 10. | INSTRUCTION SET                                   | 10-1  |
| 10.1 Sp     | ecial Instructions                                | 10-2  |
| 10.1.1      | GETI Instruction                                  | 10-2  |
| 10.1.2      | Bit Manipulation Instructions                     | 10-3  |
| 10.1.3      | Stacked Instructions                              | 10-3  |
| 10.1.4      | Radix Adjustment Instructions                     | 10-4  |
| 10.1.5      | Skip Instructions and Machine Cycles Required     |       |
|             | for Skipping                                      | 10-6  |
|             | struction Set and Operations                      | 10-7  |
|             | struction Operation Codes                         |       |
|             | struction Functions and Use                       |       |
| 10.4.1      | Transfer Instructions                             |       |
| 10.4.2      | Table Referencing Instructions                    |       |
| 10.4.3      | Bit Transfer Instructions                         | 10-35 |
| 10.4.4      | Operation Instructions                            |       |
| 10.4.5      | Accumulator Manipulating Instructions             |       |
| 10.4.6      | Increment/Decrement Instructions                  | 10-47 |
| 10.4.7      | Compare Instructions                              | 10-49 |
| 10.4.8      | Carry Flag Manipulating Instructions              | 10-51 |
| 10.4.9      | Memory Bit Manipulating Instructions              |       |
| 10.4.10     | Branch Instructions                               | 10-56 |
| 10.4.11     | Subroutine/Stack Control Instructions             | 10-60 |
| 10.4.12     | Interrupt Control Instructions                    | 10-65 |
| 10.4.13     | Input/Output Instructions                         | 10-66 |
| 10.4.14     | CPU Control Instructions                          |       |
| 10.4.15     | Special Instructions                              | 10-69 |

- x -• 6427525 0094855 465 •

| APPENDIX   | Α.         |         |        |             |             |             | •           |               |             |     |
|------------|------------|---------|--------|-------------|-------------|-------------|-------------|---------------|-------------|-----|
|            |            | AND u   | PD7532 | 28          | • • • • • • | • • • • • • | ••••        | • • • • • •   | • • • • • • | A-1 |
| A.1        | Func       | tional  | l Diff | ference     | s           | ••••        | • • • • • • | • • • • • • • |             | A-1 |
| A.2        | Diff       | ference | es bet | ween u      | PD7533      | 86 and      | uPD75       | 328           |             |     |
|            | Inst       | ructio  | ons    | • • • • • • | • • • • • • | • • • • •   | • • • • • • |               | • • • • • • | A-3 |
|            |            |         |        |             |             |             |             |               |             |     |
| APPENDIX   | в.         | DEVEL   | OPMENT | TOOLS       | • • • • •   | ••••        | • • • • • • | • • • • • • • | • • • • •   | B-1 |
|            |            |         |        |             |             |             |             |               |             |     |
| APPENDIX   | c.         | MASK I  | ROM OR | DERING      | PROCE       | DURE        | • • • • • • | • • • • • • • | ••••        | C-1 |
|            |            |         |        |             |             |             |             |               |             |     |
| APPENDIX   | D.         | INSTRU  | JCTION | INDEX       | • • • • •   | • • • • •   | • • • • • • | • • • • • • • | • • • • •   | D-1 |
|            | <b>-</b> . |         |        | <i>.</i> –  | <b>.</b>    |             |             |               |             |     |
| D.1        | Inst       | ructio  | on Ind | ex (In      | Funct       | ional       | Order       | )             | • • • • •   | D-1 |
| <b>п</b> 2 | Inst       | motic   | n Tha  | ex (In      | Alsha       | botio       |             | ·             |             |     |
|            | 11150      | LUCLI   |        | er (III     | мтриа       | Dertce      | ar Orde     | 31)           | • • • • •   | D-3 |
| APPENDIX   | E.         | HARDWA  | RE IN  | DEX (AI     | lphabe      | tical       | Order       |               |             | E-1 |

### - xi -■ 6427525 0094856 3Tl ■

# Contents of Figures

| Figure<br>No. | Title                                             | Page |
|---------------|---------------------------------------------------|------|
| 3-1           | MBE = 0 Mode and MBE = 1 Mode Distinction         | 3-3  |
| 3-2           | Data Memory Configuration and Addressing Range in |      |
|               | Each Addressing Mode                              | 3-5  |
| 3-3           | Static RAM Address Updating Method                | 3-13 |
| 3-4           | Register Bank Usage                               | 3-23 |
| 3-5           | General Register Configuration (4-Bit             |      |
|               | Processing)                                       | 3-25 |
| 3-6           | General Register Configuration (8-Bit             |      |
|               | Processing)                                       | 3-26 |
| 3-7           | uPD75336 I/O Map                                  | 3-29 |
| 4-1           | Program Counter Configuration                     | 4-1  |
| 4-2           | Program Memory Map                                | 4-4  |
| 4-3           | Data Memory Map                                   | 4-5  |
| 4-4           | Display Data Memory Configuration                 | 4-10 |
| 4-5           | General Register Configuration                    | 4-13 |
| 4-6           | Register Pair Configuration                       | 4-13 |
| 4-7           | Accumulator                                       | 4-14 |
| 4-8           | Stack Pointer Configuration                       | 4-16 |
| 4-9           | Data Saved into Stack Memory                      | 4-16 |
| 4-10          | Data Restored from Stack Memory                   | 4-16 |
| 4-11          | Program Status Word Configuration                 | 4-17 |
| 4-12          | Bank Select Register Configuration                | 4-23 |
| 5-1           | Digital Port Data Memory Addresses                | 5-2  |
| 5-2           | Configurations of Ports 0 and 1                   | 5-6  |
| 5-3           | Configurations of Ports 3n and 6n (n = 0 to 3)    | 5-7  |
| 5-4           | Configurations of Ports 2 and 7                   | 5-7  |
| 5-5           | Configurations of Ports 4 and 5                   | 5-8  |
| 5-6           | Port 8 Configuration                              | 5-9  |
| 5-7           | Port Mode Register Formats                        | 5-11 |
| 5-8           | Pull-Up Resistor Specification Register Format    | 5-20 |
| 5-9           | Digital Input/Output Port Input/Output Timings    | 5-23 |

- xii -6427525 0094857 238 🖿

| Figure |
|--------|
| No.    |

| 5-10 | Pull-Up Resistor ON Timing by Software 5-           | 24  |
|------|-----------------------------------------------------|-----|
| 5-11 | Clock Generator Block Diagram                       | 26  |
| -12  | Processor Clock Control Register Format 5-          | 30  |
| -13  | System Clock Control Register Format 5-             | 31  |
| -14  | External Circuit of Main-System Clock Oscillator 5- | 33  |
| -15  | External Circuit of Subsystem Clock Oscillator 5-3  | 34  |
| -16  | Bad Examples of Resonator Connection Circuit 5-3    | 35  |
| -17  | System Clock and CPU Clock Switching 5-4            | 41  |
| -18  | Clock Output Circuit Configuration 5-4              | 43  |
| -19  | Clock Output Mode Register Format                   | 44  |
| -20  | Example of Application to Remote Controlled         |     |
|      | Output                                              | 45  |
| -21  | Basic Interval Timer Configuration                  | 46  |
| -22  | Basic Interval Timer Mode Register Format 5-4       | 48  |
| -23  | Watch Timer Block Diagram 5-5                       | 54  |
| -24  | Clock Mode Register Format 5-5                      | 55  |
| -25  | Timer/Event Counter Block Diagram                   | 58  |
| -26  | Count Operation Timings 5-6                         | 60  |
| -27  | Timer/Event Counter Mode Register Format (Channels  |     |
|      | 0 and 1) 5-6                                        | 61  |
| -28  | Timer/Event Counter Output Enable Flag Format       |     |
|      | (Channels 0, 1) 5-6                                 | 62  |
| -29  | Operation in Count Operating Mode                   | б4  |
| -30  | Count Register Clear Timing 5-6                     | 66  |
| -31  | SBI System Configuration Example 5-7                | 75  |
| -32  | Serial Interface Block Diagram 5-7                  | 76  |
| -33  | Serial Operating Mode Register (CSIM) Format 5-8    | 80  |
| -34  | Serial Bus Interface Control Register (SBIC)        |     |
|      | Format                                              | 85  |
| -35  | Configuration around Shift Register 5-9             | 90  |
| -36  | Example of 3-Wire Serial I/O System                 |     |
|      | Configuration 5-9                                   |     |
| -37  | 3-Wire Serial I/O Mode Timing                       |     |
| -38  | RELT & CMDT Operation                               |     |
| 5-39 | Transfer Bit Switching Circuit                      | 101 |

- xiii -• 6427525 0094858 174 🚥

| 5-40       Example of 2-Wire Serial I/O System<br>Configuration       5-         5-41       2-Wire Serial I/O Mode Timing       5-         5-42       RELT & CMDT Operation       5-         5-43       Example of SBI Serial Bus Configuration       5-         5-44       SBI Transfer Timing       5-         5-45       Bus Release Signal       5-         5-46       Command Signal       5-         5-47       Address       5-         5-48       Slave Selection by Address       5-         5-49       Command       5-         5-40       Command       5-         5-41       Command       5-         5-50       Data       5-         5-51       Acknowledge Signal       5-         5-52       Busy Signal & Ready Signal       5-         5-53       RELT, CMDT, RELD & CMDD Operation (Master)       5-         5-54       RELT, CMDT, RELD & CMDD Operation (Slave)       5-         5-55       ACKT Operation       5-         5-56       ACKE Operation       5-         5-57       ACKD Operation       5-         5-58       BSYE Operation       5-         5-59       Pin Configuration Diagram                                             | Figure<br>No. | Title                                   | Page              |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|-----------------------------------------|-------------------|
| 5-41       2-Wire Serial I/O Mode Timing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 5-40          | Example of 2-Wire Serial I/O System     |                   |
| 5-42       RELT & CMDT Operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |               | Configuration                           | 5-106             |
| 5-43       Example of SBI Serial Bus Configuration       5-         5-44       SBI Transfer Timing       5-         5-45       Bus Release Signal       5-         5-46       Command Signal       5-         5-47       Address       5-         5-48       Slave Selection by Address       5-         5-49       Command       5-         5-40       Command       5-         5-41       Slave Selection by Address       5-         5-42       Command       5-         5-43       Slave Selection by Address       5-         5-44       Slave Selection by Address       5-         5-45       Data       5-         5-50       Data       5-         5-51       Acknowledge Signal       5-         5-52       Busy Signal & Ready Signal       5-         5-53       RELT, CMDT, RELD & CMDD Operation (Master)       5-         5-54       RELT, CMDT, RELD & CMDD Operation (Slave)       5-         5-55       ACKT Operation       5-         5-56       ACKE Operation       5-         5-57       AcKD Operation Diagram       5-         5-58       BSYE Operation from Master Device to Slave       <                                              | 5-41          | 2-Wire Serial I/O Mode Timing           | 5-110             |
| 5-44       SBI Transfer Timing       5-         5-45       Bus Release Signal       5-         5-46       Command Signal       5-         5-47       Address       5-         5-48       Slave Selection by Address       5-         5-49       Command       5-         5-40       Data       5-         5-41       Slave Selection by Address       5-         5-42       Command       5-         5-43       Command       5-         5-44       Slave Selection by Address       5-         5-45       Renowledge Signal       5-         5-50       Data       5-         5-51       Acknowledge Signal       5-         5-52       Busy Signal & Ready Signal       5-         5-53       RELT, CMDT, RELD & CMDD Operation (Master)       5-         5-54       RELT, CMDT, RELD & CMDD Operation (Slave)       5-         5-55       ACKT Operation       5-         5-56       ACKE Operation       5-         5-57       AcKD Operation       5-         5-58       BSYE Operation       5-         5-59       Pin Configuration Diagram       5-         5-61 <td< td=""><td>5-42</td><td>RELT &amp; CMDT Operation</td><td>5-112</td></td<>            | 5-42          | RELT & CMDT Operation                   | 5-112             |
| 5-45       Bus Release Signal       5-         5-46       Command Signal       5-         5-47       Address       5-         5-48       Slave Selection by Address       5-         5-49       Command       5-         5-40       Command       5-         5-41       Slave Selection by Address       5-         5-42       Command       5-         5-43       Slave Selection by Address       5-         5-44       Slave Selection by Address       5-         5-50       Data       5-       5-         5-51       Acknowledge Signal       5-         5-52       Busy Signal & Ready Signal       5-         5-53       RELT, CMDT, RELD & CMDD Operation (Master)       5-         5-54       RELT, CMDT, RELD & CMDD Operation (Slave)       5-         5-55       ACKE Operation       5-         5-57       ACKD Operation       5-         5-58       BSYE Operation       5-         5-59       Pin Configuration Diagram       5-         5-61       Command Transmission from Master Device to Slave       5-         5-62       Data Transmission from Master Device to Slave       5-         5-64                                              | 5-43          | Example of SBI Serial Bus Configuration | 5-117             |
| 5-45       Bus Release Signal       5-         5-46       Command Signal       5-         5-47       Address       5-         5-48       Slave Selection by Address       5-         5-49       Command       5-         5-40       Command       5-         5-41       Slave Selection by Address       5-         5-42       Command       5-         5-43       Slave Selection by Address       5-         5-44       Slave Selection by Address       5-         5-50       Data       5-       5-         5-51       Acknowledge Signal       5-         5-52       Busy Signal & Ready Signal       5-         5-53       RELT, CMDT, RELD & CMDD Operation (Master)       5-         5-54       RELT, CMDT, RELD & CMDD Operation (Slave)       5-         5-55       ACKT Operation       5-         5-56       ACKE Operation       5-         5-57       ACKD Operation       5-         5-58       BSYE Operation       5-         5-59       Pin Configuration Diagram       5-         5-61       Command Transmission from Master Device to Slave       5-         5-62       Data Transmission fr                                                  | 5-44          |                                         |                   |
| 5-47       Address       5-         5-48       Slave Selection by Address       5-         5-49       Command       5-         5-50       Data       5-         5-51       Acknowledge Signal       5-         5-52       Busy Signal & Ready Signal       5-         5-53       RELT, CMDT, RELD & CMDD Operation (Master)       5-         5-54       RELT, CMDT, RELD & CMDD Operation (Slave)       5-         5-55       ACKT Operation       5-         5-56       ACKE Operation       5-         5-57       ACKD Operation       5-         5-58       BSYE Operation       5-         5-59       Pin Configuration Diagram       5-         5-50       Address Transmission from Master Device to Slave       5-         5-61       Command Transmission from Master Device to Slave       5-         5-62       Data Transmission from Master Device to Slave       5-         5-63       Data Transmission from Slave Device to Master       5-         5-64       Example of Serial Bus Configuration       5-1         5-65       READ Command Transfer Format       5-1         5-66       WRITE & END Command Transfer Format       5-1             | 5-45          |                                         |                   |
| 5-47       Address       5-         5-48       Slave Selection by Address       5-         5-49       Command       5-         5-50       Data       5-         5-51       Acknowledge Signal       5-         5-52       Busy Signal & Ready Signal       5-         5-53       RELT, CMDT, RELD & CMDD Operation (Master)       5-         5-54       RELT, CMDT, RELD & CMDD Operation (Slave)       5-         5-55       ACKT Operation       5-         5-56       ACKE Operation       5-         5-57       ACKD Operation       5-         5-58       BSYE Operation       5-         5-59       Pin Configuration Diagram       5-         5-60       Address Transmission from Master Device to Slave       5-         Device (WUP = 1)       5-1       5-1         5-61       Command Transmission from Master Device to Slave       5-1         5-63       Data Transmission from Slave Device to Master       5-1         5-64       Example of Serial Bus Configuration       5-1         5-65       READ Command Transfer Format       5-1         5-66       WRITE & END Command Transfer Format       5-1                                        | 5-46          | Command Signal                          | 5-121             |
| 5-48       Slave Selection by Address       5-         5-49       Command       5-         5-50       Data       5-         5-51       Acknowledge Signal       5-         5-52       Busy Signal & Ready Signal       5-         5-53       RELT, CMDT, RELD & CMDD Operation (Master)       5-         5-54       RELT, CMDT, RELD & CMDD Operation (Slave)       5-         5-55       ACKT Operation       5-         5-56       ACKE Operation       5-         5-57       ACKD Operation       5-         5-58       BSYE Operation       5-         5-59       Pin Configuration Diagram       5-         5-60       Address Transmission from Master Device to Slave       5-         Device (WUP = 1)       5-1       5-1         5-61       Command Transmission from Master Device to Slave       5-1         5-62       Data Transmission from Slave Device to Master       5-1         5-63       Data Transmission from Slave Device to Master       5-1         5-64       Example of Serial Bus Configuration       5-1         5-65       READ Command Transfer Format       5-1         5-66       WRITE & END Command Transfer Format       5-1 | 5-47          |                                         |                   |
| 5-49       Command       5-         5-50       Data       5-         5-51       Acknowledge Signal       5-         5-52       Busy Signal & Ready Signal       5-         5-53       RELT, CMDT, RELD & CMDD Operation (Master)       5-         5-54       RELT, CMDT, RELD & CMDD Operation (Slave)       5-         5-55       ACKT Operation       5-         5-56       ACKE Operation       5-         5-57       ACKD Operation       5-         5-58       BSYE Operation       5-         5-59       Pin Configuration Diagram       5-         5-50       Address Transmission from Master Device to Slave       5-         Device (WUP = 1)       5-1       5-1         5-61       Command Transmission from Master Device to Slave       5-1         5-62       Data Transmission from Slave Device to Master       5-1         5-63       Data Transmission from Slave Device to Master       5-1         5-64       Example of Serial Bus Configuration       5-1         5-65       READ Command Transfer Format       5-1         5-66       WRITE & END Command Transfer Format       5-1                                                        | 5-48          |                                         |                   |
| 5-50       Data       5-         5-51       Acknowledge Signal       5-         5-52       Busy Signal & Ready Signal       5-         5-53       RELT, CMDT, RELD & CMDD Operation (Master)       5-         5-54       RELT, CMDT, RELD & CMDD Operation (Slave)       5-         5-55       ACKT Operation       5-         5-56       ACKE Operation       5-         5-57       ACKD Operation       5-         5-58       BSYE Operation       5-         5-59       Pin Configuration Diagram       5-         5-50       Address Transmission from Master Device to Slave       5-         5-61       Command Transmission from Master Device to Slave       5-         5-62       Data Transmission from Master Device to Slave       5-1         5-63       Data Transmission from Slave Device to Slave       5-1         5-64       Example of Serial Bus Configuration       5-1         5-65       READ Command Transfer Format       5-1                                                                                                                                                                                                            | 5-49          |                                         |                   |
| 5-51       Acknowledge Signal                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 5-50          |                                         |                   |
| 5-52       Busy Signal & Ready Signal                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 5-51          |                                         |                   |
| 5-53       RELT, CMDT, RELD & CMDD Operation (Master)       5-         5-54       RELT, CMDT, RELD & CMDD Operation (Slave)       5-         5-55       ACKT Operation       5-         5-56       ACKE Operation       5-         5-57       ACKD Operation       5-         5-58       BSYE Operation       5-         5-59       Pin Configuration Diagram       5-         5-60       Address Transmission from Master Device to Slave       5-         5-61       Command Transmission from Master Device to Slave       5-1         5-62       Data Transmission from Master Device to Slave       5-1         5-63       Data Transmission from Slave Device to Master       5-1         5-64       Example of Serial Bus Configuration       5-1         5-65       READ Command Transfer Format       5-1                                                                                                                                                                                                                                                                                                                                                 | 5-52          |                                         |                   |
| 5-54       RELT, CMDT, RELD & CMDD Operation (Slave)       5         5-55       ACKT Operation       5         5-56       ACKE Operation       5         5-57       ACKD Operation       5         5-58       BSYE Operation       5         5-59       Pin Configuration Diagram       5         5-60       Address Transmission from Master Device to Slave       5         Device (WUP = 1)       5       5         5-61       Command Transmission from Master Device to Slave       5         Device       5       5         5-62       Data Transmission from Master Device to Slave       5         5-63       Data Transmission from Slave Device to Master       5         5-64       Example of Serial Bus Configuration       5         5-65       READ Command Transfer Format       51         5-66       WRITE & END Command Transfer Format       51                                                                                                                                                                                                                                                                                                | 5-53          |                                         |                   |
| <ul> <li>5-55 ACKT Operation</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 5-54          |                                         |                   |
| <ul> <li>5-56 ACKE Operation</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 5-55          |                                         |                   |
| <ul> <li>5-57 ACKD Operation</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 5-56          |                                         |                   |
| <ul> <li>5-58 BSYE Operation</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 5-57          |                                         |                   |
| <ul> <li>5-59 Pin Configuration Diagram</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 5-58          |                                         |                   |
| <ul> <li>5-60 Address Transmission from Master Device to Slave<br/>Device (WUP = 1)</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 5-59          |                                         |                   |
| Device (WUP = 1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 5-60          |                                         | 0 10)             |
| <ul> <li>5-61 Command Transmission from Master Device to Slave<br/>Device</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |               |                                         | 5-143             |
| Device                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 5-61          |                                         | 9-140             |
| <ul> <li>5-62 Data Transmission from Master Device to Slave<br/>Device</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |               |                                         | 5-144             |
| Device                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 5-62          |                                         | 0-1 <del>44</del> |
| <ul> <li>5-63 Data Transmission from Slave Device to Master<br/>Device</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |               |                                         | 5-145             |
| Device                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 5-63          |                                         | 2-142             |
| 5-64Example of Serial Bus Configuration5-15-65READ Command Transfer Format5-15-66WRITE & END Command Transfer Format5-1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |               |                                         | 5 146             |
| 5-65 READ Command Transfer Format                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 5-64          |                                         |                   |
| 5-66 WRITE & END Command Transfer Format                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |               |                                         |                   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |               |                                         |                   |
| Commune Itemater Putmat                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |               |                                         |                   |
| 5-68 STATUS Command Transfer Format                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |               |                                         |                   |

•

- xiv -■ 6427525 0094859 000 ■

-

| Figure |  |
|--------|--|
| No.    |  |

.

Page

-----

| 5-69 | STATUS Command Status Format                          |
|------|-------------------------------------------------------|
| 5-70 | RESET Command Transfer Format                         |
| 5-71 | CHGMST Command Transfer Format                        |
| 5-72 | Master & Slave Operation in Case of Error             |
|      | Generation                                            |
| 5-73 | SCK/P01 Pin Configuration 5-159                       |
| 5-74 | LCD Controller/Driver Block Diagram                   |
| 5-75 | Display Mode Register Format 5-166                    |
| 5-76 | Display Control Register Format                       |
| 5-77 | Data Memory Map 5-169                                 |
| 5-78 | Relations between Display Data Memory and Common      |
|      | and Segment Signals 5-170                             |
| 5-79 | Common Signal Waveform (Static)                       |
| 5-80 | Common Signal Waveform (1/2 Bias Method) 5-174        |
| 5-81 | Common Signal Waveform (1/3 Bias Method) 5-175        |
| 5-82 | Common and Segment Signal Voltages and Phases 5-176   |
| 5-83 | LCD Drive Power Supply Connection Examples            |
|      | (with On-Chip Split Resistors) 5-179                  |
| 5-84 | LCD Drive Power Supply Connection Examples            |
|      | (with External Split Resistors)                       |
| 5-85 | Static LCD Display Pattern and Electrode Wiring 5-183 |
| 5-86 | Static LCD Panel Wiring Example                       |
| 5-87 | Static LCD Drive Waveform Example                     |
| 5-88 | 2-Time Multiplexing LCD Display Parameter and         |
|      | Electrode Wiring 5-187                                |
| 5-89 | 2-Time Multiplexing LCD Panel Wiring Example 5-188    |
| 5-90 | 2-Time Multiplexing LCD Drive Waveform Example        |
|      | (1/2 Bias Method) 5-189                               |
| 5-91 | 3-Time Multiplexing LCD Display Pattern and           |
|      | Electrode Wiring 5-191                                |
| 5-92 | 3-Time Multiplexing LCD Panel Wiring Example 5-192    |
| 5-93 | 3-Time Multiplexing LCD Drive Waveform Example        |
|      | (1/2 Bias Method) 5-193                               |
| 5-94 | 3-Time Multiplexing LCD Drive Waveform Example        |
|      | (1/3 Bias Method) 5-194                               |
|      |                                                       |

-xv -• 6427525 0094860 822 🖿

| Figure<br>No. | Title                                               | Page  |
|---------------|-----------------------------------------------------|-------|
| 5-95          | 4-Time Multiplexing LCD Display Parameter and       |       |
|               | Electrode Wiring                                    | 5-196 |
| 5-96          | 4-Time Multiplexing LCD Panel Wiring Example        | 5-197 |
| 5-97          | 4-Time Multiplexing LCD Panel Waveform Example (1/3 | i     |
|               | Bias Method)                                        | 5-198 |
| 5-98          | A/D Converter Block Diagram                         | 5-200 |
| 5-99          | A/D Conversion Mode Register Format                 | 5-203 |
| 5-100         | A/D Conversion Timing Chart                         | 5-206 |
| 5-101         | Relations between Analog Input Voltages and A/D     |       |
|               | Conversion Results (Ideal Case)                     | 5-207 |
| 5-102         | Example of How to Decrease Power Consumption in     |       |
|               | Standby Mode                                        | 5-208 |
| 5-103         | Analog Input Pin Treatment                          | 5-209 |
| 5-104         | Bit Sequential Buffer Format                        | 5-211 |
|               |                                                     |       |
| 6-1           | Interrupt Control Circuit Block Diagram             |       |
| 6-2           | Interrupt Vector Table                              |       |
| 6-3           | Interrupt Priority Selection Register               |       |
| 6-4           | Configuration of INTO, INT1 and INT4                |       |
| 6-5           | Noise Elimination Circuit Input/Output Timing       |       |
| 6-6           | Edge Detection Mode Register Format                 |       |
| 6-7<br>6-8    | Configuration of INT2 and KRO to KR7                |       |
|               | Interrupt Service Sequence                          |       |
| 6-9           | Multiple Interrupts by High-Rank Specification      | 6-23  |
| 6-10          | Multiple Interrupts by Interrupt Status Flag        |       |
|               | Modification                                        | 6-24  |
| 7-1           | Standby Mode Release Operations                     | 7-6   |
| 8-1           | RESET Input Reset Operation                         | 8-1   |

- xvi -6427525 0094861 769 🛲

### Contents of Tables

| Table<br>No. | Title                                              | Page  |
|--------------|----------------------------------------------------|-------|
| 1-1          | Differences between uPD75336 and uPD75P336         | 1-6   |
| 2-1          | List of Digital Input/Output Port Pin Functions    | 2-1   |
| 2-2          | List of Pins Other than Port Pins                  | 2-5   |
| 2-3          | Recommended Connection of Unused Pins              | 2-23  |
| 2-4          | Mask Option Selection                              | 2-24  |
| 3-1          | Addressing Mode                                    | 3-6   |
| 3-2          | RBE, RBS and Register Banks Selected               | 3-21  |
| 3-3          | Recommended Register Bank Usage in Normal and      |       |
|              | Interrupt Routines                                 | 3-22  |
| 3-4          | Addressing Modes Applicable when Operating the     |       |
|              | Peripheral Hardware                                | 3-27  |
| 4-1          | PSW Flags Saved/Restored in Stack Operation        | 4-17  |
| 4-2          | Carry Flag Manipulation Instructions               | 4-18  |
| 4-3          | Interrupt Status Flag Specification Contents       | 4-20  |
| 5-1          | Types and Features of Digital I/O Ports            | 5-4   |
| 5-2          | Table of Input/Output Pin Operation Instructions   | 5-14  |
| 5-3          | Input/Output Port Operations                       | 5-18  |
| 5-4          | On-Chip Pull-Up Resistor Specification Method      | 5-21  |
| 5-5          | Maximum Time Required for System Clock and CPU     |       |
|              | Clock Switching                                    | 5-39  |
| 5-6          | Differences between Timer/Event Counter Channel 0  |       |
|              | and Channel 1                                      | 5-57  |
| 5-7          | Resolution and Maximum Set Time (with $f_X = 4.19$ |       |
|              | MHz)                                               | 5-66  |
| 5-8          | Serial Clock Selection and Use (In 3-Wire Serial   |       |
|              | I/O Mode)                                          | 5-100 |
| 5-9          | Serial Clock Selection and Use (In 2-Wire Serial   |       |
|              | I/O Mode)                                          | 5-112 |
| 5-10         | Serial Clock Selection and Use (In SBI Mode)       | 5-131 |

- xvii -■ 6427525 0094862 6T5 ■

| Table |
|-------|
| No.   |

| 5-11 | Various Signals in SBI Mode                         |
|------|-----------------------------------------------------|
| 5-12 | Maximum Number of Pixels Displayed                  |
| 5-13 | COM Signals 5-172                                   |
| 5-14 | LCD Drive Voltage (Static)                          |
| 5-15 | LCD Drive Voltage (1/2 Bias Method) 5-173           |
| 5-16 | LCD Drive Voltage (1/3 Bias Method) 5-173           |
| 5-17 | LCD Drive Power Supply Values                       |
| 5-18 | Select and Non-Select Voltages (COMO)               |
| 5-19 | Select and Non-Select Voltages (COMO, COM1) 5-186   |
| 5-20 | Select and Non-Select Voltages (COMO, 1, 2) 5-190   |
| 5-21 | Select and Non-Select Voltages (COMO to COM3) 5-195 |
| 5-22 | SCC and PCC Settings 5-206                          |
|      |                                                     |
| 6-1  | Interrupt Source Types 6-3                          |
| 6-2  | Interrupt Request Flag Setting Signals              |
| 6-3  | IST1/IST0 Interrupt Servicing Status                |
| 6-4  | Shared Interrupt Discrimination                     |
|      |                                                     |
| 7-1  | Operating Status in Standby Mode                    |
| 7-2  | Wait Time Selection by BTM                          |
|      |                                                     |
| 8-1  | Hardware Status after Reset                         |
|      |                                                     |
| 9-1  | Pin for Using Program Memory Write/Verify           |
|      | Operating Modes                                     |
| 9-2  | Operating Modes                                     |
|      |                                                     |



#### CHAPTER 1. OVERVIEW

The uPD75336 and uPD75P336 are 4-bit single-chip microcomputer 75X series products capable of data processing equal to an 8-bit microcomputer.

The uPD75336 features expanded ROM and RAM capacity compared with the uPD75328, low-voltage operation of the A/D converter and enhanced 8-bit data processing.

The uPD75P336 is a product in which the on-chip mask ROM of uPD75336 is replaced with a one-time programmable PROM. It is most suitable for preproduction and short-run production for system development.

The uPD75336 and uPD75P336 have the following features:

- . uPD75328 upward compatible
- . Instruction execution time variable function which is useful for high-speed operations and power saving.
- . On-chip A/D converter with 8-bit resolution (successive approximation): 8 channels
- . On-chip LCD controller/driver
- . Improved timer functions: 4 channels
- . Improved 8-bit data processing
- . Ultra compact package (80-pin plastic TQFP (fine pitch) (□12 mm))
- . The uPD75P336 can operate over the same power supply voltage range as the uPD75336 mask product :  $V_{\rm DD}$  = 2.7 to 6.0 V

Since the uPD75336 has LCD display and A/D conversion functions and can operate at high-speeds with low power consumption, it can be applied in the following fields:

- . Cameras
- . VCR integrated cameras
- . Air conditioners
- . Sphygmomanometers

#### 1-1 ■ 6427525 0094864 478 ■

Through the adoption of a compact package, the uPD75336 can be used to control ultra-small devices.

Remarks: This manual describes the uPD75336 as a representative type.

Readers using this manual for the uPD75P336 should refer to "How to Read" described in "PREFACE".



# 1.1 FUNCTION OUTLINE

| Item                                                                                                |         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |          |                                 |                                                                                                   |  |
|-----------------------------------------------------------------------------------------------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|---------------------------------|---------------------------------------------------------------------------------------------------|--|
| Instruction execution time                                                                          |         | When main-system clock is selected:<br>0.95, 1.91, 3.81, 15.3 us (when operated at 4.19<br>MHz)<br>When subsystem clock is selected:<br>122 us (when operated at 32.768 kHz)                                                                                                                                                                                                                                                                                                 |          |                                 |                                                                                                   |  |
| On-chip                                                                                             | ROM     | 16256 x 8 bits                                                                                                                                                                                                                                                                                                                                                                                                                                                               |          |                                 |                                                                                                   |  |
| memory                                                                                              | RAM     | 768 x 4 bits                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |          |                                 |                                                                                                   |  |
| General reg                                                                                         | gister  | . 4-bit manipulation: 8 x 4 banks<br>. 8-bit manipulation: 4 x 4 banks                                                                                                                                                                                                                                                                                                                                                                                                       |          |                                 |                                                                                                   |  |
| I/O lines                                                                                           | the ICD | 44<br>lines                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 8 lines  | CMOS input pin                  | On-chip pull-up                                                                                   |  |
| [Includes the LCD<br>drive dual-function<br>pin but not includes<br>the LCD drive<br>dedicated pin] |         | lines                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 20 lines | CMOS input/<br>output pin       | resistor specifi-<br>able by software<br>(except POO)                                             |  |
|                                                                                                     |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 8 lines  | CMOS output pin                 | Dual-function<br>segment pin                                                                      |  |
|                                                                                                     |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 8 lines  | N-ch open-drain<br>input/output | 10 V withstand<br>voltage. The<br>pull-up resistor<br>specifiable by<br>using the mask<br>option. |  |
| LCD controller/driver                                                                               |         | <ul> <li>LCD drive output pin <ul> <li>Segment output pin: 20 (CMOS output dual-function pin: 8)</li> <li>Common output pin: 4</li> </ul> </li> <li>Number of segment selections: 12/16/20 segments</li> <li>Display mode selection <ul> <li>Static</li> <li>1/2 duty, 1/2 bias</li> <li>1/3 duty, 1/2 bias</li> <li>1/3 duty, 1/3 bias</li> <li>1/4 duty, 1/3 bias</li> </ul> </li> <li>LCD drive voltage supply split resistor may be integrated (mask option).</li> </ul> |          |                                 |                                                                                                   |  |

(to be continued)

1-3 ■ 6427525 0094866 240 ■

(cont'd)

| Item                       | Function                                                                                                                                                                                                                                                    |  |  |  |
|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| A/D converter              | <pre>On-chip 8-bit resolution A/D converter (successive<br/>approximation)<br/>. 8-channel analog input<br/>. Low-voltage operation capability:<br/>V<sub>DD</sub> = 2.7 to 6.0 V<br/>. A/D conversion speed: 40.1 us (when operated at<br/>4.19 MHz)</pre> |  |  |  |
| Timer                      | 4<br>channels { . 8-bit timer/event counter x 2 channels<br>. 8-bit basic interval timer<br>. Watch timer: 0.5 sec time interval<br>generation and buzzer<br>output capability<br>(2 kHz, 4 kHz, 32 kHz)                                                    |  |  |  |
| Serial interface           | . NEC standard serial bus interface (SBI)<br>. Clock synchronous serial interface                                                                                                                                                                           |  |  |  |
| Bit sequential buffer      | Special bit manipulation memory: 16 bits                                                                                                                                                                                                                    |  |  |  |
| Clock output (PCL)         | $\Phi$ , 524 kHz, 262 kHz, 65.5 kHz (when operated at 4.19 MHz)                                                                                                                                                                                             |  |  |  |
| Buzzer output (BUZ)        | 2 kHz, 4 kHz, 32 kHz (when main-system or subsystem clock operates)                                                                                                                                                                                         |  |  |  |
| Vectored interrupt         | . External: 3<br>. Internal: 4                                                                                                                                                                                                                              |  |  |  |
| Test input                 | . External: 1<br>. Internal: 1                                                                                                                                                                                                                              |  |  |  |
| 8-bit data processing      | Transfer, add/subtract, increment/decrement and compare                                                                                                                                                                                                     |  |  |  |
| System clock<br>oscillator | <ul> <li>Ceramic/crystal oscillator for main-system clock<br/>oscillation: 4.194304 MHz</li> <li>Crystal oscillator for subsystem clock<br/>oscillation: 32.768 kHz</li> </ul>                                                                              |  |  |  |
| Standby                    | STOP/HALT mode                                                                                                                                                                                                                                              |  |  |  |
| Operating voltage          | $V_{\rm DD} = 2.7 \text{ to } 6.0 \text{ V}$                                                                                                                                                                                                                |  |  |  |
| Package                    | 80-pin plastic QFP ( ] 14 mm)<br>80-pin plastic TQFP (fine pitch) ( ] 12 mm)                                                                                                                                                                                |  |  |  |

1-4 ■ 6427525 0094867 187 ■

#### 1.2 ORDERING INFORMATION AND QUALITY GRADE

#### (1) Ordering Information

| Ordering Code      | Package                      | Program Memory |
|--------------------|------------------------------|----------------|
| uPD75336GC-xxx-3B9 | 80-pin plastic QFP ([]14 mm) | Mask ROM       |
| uPD75336GK-xxx-BE9 | 80-pin plastic TQFP          | Mask ROM       |
|                    | (fine pitch) ([]12 mm)       |                |
| uPD75P336GC-3B9    | 80-pin plastic QFP ([]14 mm) | One-time PROM  |
| uPD75P336GK-BE9    | 80-pin plastic TQFP          | One-time PROM  |
|                    | (fine pitch) ([12 mm)        |                |

Remarks: xxx is the ROM code number.

(2) Quality Grade

| Ordering Code      | Package                      | Quality Grade |
|--------------------|------------------------------|---------------|
| uPD75336GC-xxx-3B9 | 80-pin plastic QFP ([]14 mm) | Standard      |
| uPD75336GK-xxx-BE9 | 80-pin plastic TQFP          | Standard      |
|                    | (fine pitch) ([12 mm)        |               |
| uPD75P336GC-3B9    | 80-pin plastic QFP ([]14 mm) | Standard      |
| uPD75P336GK-BE9    | 80-pin plastic TQFP          | Standard      |
|                    | (fine pitch) ([12 mm)        |               |

Remarks: xxx is the ROM code number.

Please refer to "Quality grade on NEC Semiconductor Devices" (Document number IEI-1209) published by NEC Corporation to know the specification of quality grade on the devices and its recommended applications.

### 1.3 DIFFERENCES BETWEEN uPD75336 AND uPD75P336

In the uPD75P336, the program memory of the on-chip mask ROM uPD75336 is replaced with one-time PROM that can be written to only once. The differences between the uPD75336 and the uPD75P336 are shown below. Please take careful note of these differences when moving from application system debugging and preproduction using onetime PROM, to volume production using the mask ROM product.

Table 1-1 Differences between uPD75336 and uPD75P336

| Item                                              |                | uPD75336                                                                                                             | uPD75P336                                               |  |
|---------------------------------------------------|----------------|----------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------|--|
| Program memory                                    |                | . Mask ROM<br>. 16256 x 8 bits<br>. 0000H to 3F7FH                                                                   | . One-time PROM<br>. 16256 x 8 bits<br>. 0000H to 3F7FH |  |
| Data memory                                       |                | 768 x 4 bits                                                                                                         | 768 x 4 bits                                            |  |
| Pull-up resi<br>4 and 5                           | ister of ports | Mask option                                                                                                          | None                                                    |  |
| Split resistor for LCD<br>drive power supply      |                |                                                                                                                      |                                                         |  |
| Feedback resister for subsystem clock oscillation |                | Mask option                                                                                                          | On chip                                                 |  |
| Pin<br>connection                                 | Nos. 50 to 53  | P30 to P33                                                                                                           | P30/MD0 to P33/MD3                                      |  |
|                                                   | No. 69         | IC                                                                                                                   | V <sub>PP</sub>                                         |  |
| Electrical s                                      | pecifications  | Different consumption current, etc. See<br>the Electrical Specifications section in<br>the respective Data Sheets.   |                                                         |  |
| Operating vo                                      | ltage range    | $V_{DD} = 2.7$ to 6.0 V                                                                                              |                                                         |  |
| Packages                                          |                | . 80-pin plastic QFP ( ] 14 mm)<br>. 80-pin plastic TQFP (fine pitch) ( ] 12 mm)                                     |                                                         |  |
| Others                                            |                | As the circuit scale, mask layout, etc.,<br>are different, noise resistance, noise<br>emission, etc., are different. |                                                         |  |

1-6 ■ 6427525 0094869 T5T ■ NOTE: Noise resistance and noise emission are different for PROM and mask ROM. When investigating the replacement of the PROM product with the mask ROM product in the transition from preproduction to volume production, thorough evaluation must be carried out with the mask ROM CS product (not the ES product).



This Material Copyrighted By Its Respective Manufacturer



1-8 6427525 0094871 608 🖿

This Material Copyrighted By Its Respective Manufacturer

1.4

BLOCK DIAGRAM



\*1: IC pin: Internally Connected. Connect directly to  $V_{DD}$ . 2: In normal operation, connect  $V_{PP}$  directly to  $V_{DD}$ .

1-9 ■ 6427525 0094872 544 ■

This Material Copyrighted By Its Respective Manufacturer

Pin Name

| P00 to 03        | : PortO                 | SB0, 1          | : Serial Bus 0, 1             |
|------------------|-------------------------|-----------------|-------------------------------|
| P10 to 13        | : Port1                 | RESET           | : Reset Input                 |
| P20 to 23        | : Port2                 | S12 to 31       | : Segment Output 12 to 31     |
| P30 to 33        | : Port3                 | COMO to 3       | : Common Output 0 to 3        |
| P40 to 43        | : Port4                 | $V_{LCO}$ to 2  | : LCD Power Supply 0 to 2     |
| P50 to 53        | : Port5                 | BIAS            | : LCD Power Supply Bias       |
| P60 to 63        | : Port6                 |                 | Control                       |
| P70 to 73        | : Port7                 | LCDCL           | : LCD Clock                   |
| P80 to 83        | : Port8                 | SYNC            | : LCD Synchronization         |
| BPO to 7         | : Bit Port 0 to 7       | TIO, 1          | : Timer Input 0, 1            |
| KRO to 7         | : Key Return 0 to 7     | PT00, 1         | : Programmable Timer Output   |
| AVREF            | : Analog Reference      |                 | 0, 1                          |
| AVSS             | : Analog Ground         | BUZ             | : Buzzer Clock                |
| ANO to 7         | : Analog Input 0 to 7   | PCL             | : Programmable Clock          |
| SCK              | : Serial Clock          | INTO, 1, 4      | : External Vectored Interrupt |
|                  |                         |                 | 0, 1, 4                       |
| SI               | : Serial Input          | INT2            | : External Test Input 2       |
| SO               | : Serial Output         | X1, 2           | : Main System Clock           |
| (MDO to 3        | : Mode Seloction)       |                 | Oscillation 1, 2              |
| (V <sub>PP</sub> | : Programming/Verifying | XT1, 2          | : Subsystem Clock             |
|                  | Power Supply)           |                 | Oscillation 1, 2              |
|                  |                         | IC              | : Internally Connected        |
|                  |                         | v <sub>DD</sub> | : Positive Power Supply       |
|                  |                         | V <sub>SS</sub> | : Ground                      |
|                  |                         |                 |                               |

Remarks: uPD75P336 in parentheses



### CHAPTER 2. PIN FUNCTIONS

# 2.1 LIST OF uPD75336 PIN FUNCTIONS

Table 2-1 List of Digital Input/Output Port Pin Functions

| Pin Name | Input/<br>Output | Dual-<br>Function<br>Pin |                                 | Function                                                                | 8-<br>Bit<br>I/0 | When<br>Reset | Ou<br>Ci<br>T | put/<br>tput<br>rcuit<br>ype<br>*1 |
|----------|------------------|--------------------------|---------------------------------|-------------------------------------------------------------------------|------------------|---------------|---------------|------------------------------------|
| P00      | Input            | INT4                     |                                 | it input port                                                           | x                | Input         |               | B                                  |
| P01      | Input/<br>output | SCK                      | On-o                            | (PORTO).<br>On-chip pull-up<br>resistor specifiable in                  |                  |               | F             | - A                                |
| P02      | Input/<br>output | SO/SBO                   |                                 | it units by software<br>P01 to P03.                                     |                  |               | F             | - B                                |
| P03      | Input/<br>output | SI/SB1                   |                                 |                                                                         |                  |               | M             | - C                                |
| P10      | Input            | INTO                     |                                 | Noise elimination<br>function available<br>4-bit input port<br>(PORT1). | x                | Input         | B             | - C                                |
| P11      |                  | INT1                     | -<br> <br>  ,, , , ,            |                                                                         |                  |               |               |                                    |
| P12      |                  | INT2                     | (POR                            |                                                                         |                  |               |               |                                    |
| P13      |                  | TIO                      | resi<br>4-bi                    | hip pull-up<br>stor specifiable in<br>t units by software<br>this port. |                  |               |               |                                    |
| P20      | Input/           | PT00                     |                                 | t_input/output port                                                     | x                | Input         | E -           | В                                  |
| P21      | output           | PT01                     | On−c                            | (PORT2).<br>On-chip pull-up                                             |                  |               |               |                                    |
| P22      |                  | PCL                      | 4-bi                            | stor specifiable in<br>t units by software                              |                  |               |               |                                    |
| P23      |                  | BUZ                      | IOr                             | this port.                                                              |                  |               |               |                                    |
| P30 *2   | Input/<br>output | LCDCL *4<br>(MDO)        | inpu                            | rammable 4-bit<br>t/output port                                         | x                | Input         | E -           | B                                  |
| P31 *2   |                  | SYNC *4<br>(MD1)         | able<br>On-ch<br>resis<br>4-bit | t/output specifi-<br>bit by bit.                                        |                  |               |               |                                    |
| P32 *2   |                  | (MD2) *4                 |                                 | hip pull-up<br>stor specifiable in<br>t units by software               |                  |               |               |                                    |
| P33 *2   |                  | (MD3) *4                 |                                 | t units by software this port.                                          |                  |               |               |                                    |

(to be continued)

2-1 ■ 6427525 0094874 317 ■

# Table 2-1 List of Digital Input/Output Port Pin Functions (cont'd)

| Pin          | Name | Input/<br>Output |           | Function                                                                                                                                                                  | 8-<br>Bit<br>I/0 | When<br>Reset                                                                        | Input/<br>Output<br>Circuit<br>Type<br>*1 |
|--------------|------|------------------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|--------------------------------------------------------------------------------------|-------------------------------------------|
| P40<br>P43   |      | Input/<br>output |           | N-ch open-drain 4-bit<br>input/output port<br>(PORT4).<br>On-chip pull-up<br>resistor specifiable<br>bit-wise (mask option).<br>*3<br>10 V resistance with<br>open-drain  | O                | High<br>level<br>(with an<br>on-chip<br>pull-up<br>resistor)<br>or high<br>impedance | М<br>(М - А)<br>*4                        |
| P50<br>P53   |      | Input/<br>output |           | N-ch open-drain 4-bit<br>input/output port<br>(PORT5).<br>On-chip pull-up<br>resistor specifiable<br>bit-wise (mask option).<br>*3<br>10 V resistance with<br>open-drain. | 0                | High<br>level<br>(with an<br>on-chip<br>pull-up<br>resistor)<br>or high<br>impedance | M<br>(M - A)<br>*4                        |
| P60          |      | Input/<br>output | KRO       | Programmable 4-bit                                                                                                                                                        | 0                | Input                                                                                | (F) - A                                   |
| P61          |      | σαιραι           | KR1       | input/output port<br>(PORT6).                                                                                                                                             |                  |                                                                                      |                                           |
| P62          |      |                  | KR2       | Input/output specifi-<br>able bit-wise.                                                                                                                                   |                  |                                                                                      |                                           |
| Р63          |      |                  | KR3       | On-chip pull-up<br>resistor specifiable in<br>4-bit units by software<br>for this port.                                                                                   |                  |                                                                                      |                                           |
| P70          |      | Input/           | KR4       | 4-bit input/output port                                                                                                                                                   | ŀ                | Input                                                                                | (F) - A                                   |
| P71          |      |                  | KR5       | (PORT7).<br>On-chip pull-up                                                                                                                                               |                  |                                                                                      |                                           |
| P <u>7</u> 2 |      |                  | KR6 4-bit | resistor specifiable in<br>4-bit units by software                                                                                                                        |                  |                                                                                      |                                           |
| P73          |      |                  | KR7       | for this port.                                                                                                                                                            |                  |                                                                                      |                                           |

(to be continued)

-----

2-2 • 6427525 0094875 253 •

# Table 2-1 List of Digital Input/Output Port Pin Functions (cont'd)

| Pin Name      | Input/<br>Output | Dual-<br>Function<br>Pin | Function                                                             | 8-<br>Bit<br>I/O | When<br>Reset | Input/<br>Output<br>Circuit<br>Type<br>*1 |
|---------------|------------------|--------------------------|----------------------------------------------------------------------|------------------|---------------|-------------------------------------------|
| P80 to<br>P83 | Input/<br>output | TI1                      | 4-bit input/output port<br>(PORT8)                                   | x                | Input         | <b>Е</b> - е                              |
|               | -                |                          | On-chip pull-up                                                      |                  |               | E - B                                     |
|               |                  | ANG                      | resistor specifiable in<br>4-bit units by software<br>for this port. |                  |               | Y - B                                     |
|               |                  | AN7                      |                                                                      |                  |               |                                           |
| BPO           | Output           | S24                      | 1-bit output port (BIT<br>PORT)                                      | х                | *5            | G - C                                     |
| BP1           |                  | S25                      | Also serves as a                                                     |                  |               |                                           |
| BP2           |                  | S26                      | segment output pin.                                                  |                  |               |                                           |
| BP3           |                  | S27                      |                                                                      |                  |               |                                           |
| BP4           | Output           | S28                      |                                                                      |                  |               |                                           |
| BP5           |                  | S29                      |                                                                      |                  |               |                                           |
| BP6           |                  | S30                      |                                                                      |                  |               |                                           |
| BP7           |                  | S31                      |                                                                      |                  |               |                                           |

\*1: Circled circuits have a Schmitt trigger input.

- 2: Can directly drive LEDs.
- 3: uPD75P336 has no on-chip pull-up resistor by mask option.
- 4: uPD75P336 in parentheses
- 5:  $V_{LC1}$  is selected as an input source for BPO to BP7. The output level varies depending on BPO to BP7 and the  $V_{LC1}$  external circuit. An example is shown on the next page.

2-3 🔳 6427525 0094876 19T 📕

Example: Since BPO to BP7 are interconnected through the uPD75336 as shown below, BPO to BP7 output levels are determined by the values of  $R_1$ ,  $R_2$  and  $R_3$ .





# Table 2-2 List of Pins Other than Port Pins

| Pin Name      | Input/<br>Output | Dual-<br>Function<br>Pin | Function                                                                                               |                                                              | When<br>Reset | Input/<br>Output<br>Circuit<br>Type<br>*1 |
|---------------|------------------|--------------------------|--------------------------------------------------------------------------------------------------------|--------------------------------------------------------------|---------------|-------------------------------------------|
| TIO           | Input            | P13                      | External event pulse                                                                                   |                                                              | Input         | B-c                                       |
| TI1           |                  | P80                      | for timer/event cour                                                                                   | iter                                                         |               | <b>Е</b> -Е                               |
| PT00          | Output           | P20                      | Timer/event counter                                                                                    | output                                                       | Input         | E - B                                     |
| PT01          |                  | P21                      |                                                                                                        |                                                              |               |                                           |
| PCL           | Output           | P22                      | Clock output                                                                                           |                                                              | Input         | Е-В                                       |
| BUZ           | Output           | P23                      |                                                                                                        | Frequency output (for<br>buzzer or system clock<br>trimming) |               | E - B                                     |
| SCK           | Input/<br>output | P01                      | Serial clock input/output                                                                              |                                                              | Input         | (F) - A                                   |
| SO/SBO        | Input/<br>output | P02                      | Serial data output<br>Serial bus input/out                                                             | Serial data output<br>Serial bus input/output                |               | <b>(F)</b> – В                            |
| SI/SB1        | Input/<br>output | P03                      | Serial data input<br>Serial bus input/out                                                              | put                                                          | Input         | (M) - C                                   |
| INT4          | Input            | P00                      | Edge-detected vectored<br>interrupt input (valid for<br>detection of both rising<br>and falling edges) |                                                              | Input         | B                                         |
| INTO          | Input            | P10                      | Edge-detected                                                                                          | Clocked                                                      | Input         | <u></u> В-с                               |
| INT1          |                  | P11                      | vectored interrupt<br>input (detected<br>edge selection<br>enabled)                                    | Asyn-<br>chro-<br>nous                                       |               |                                           |
| INT2          | Input            | P12                      | Edge-detected<br>vectored interrupt<br>input (detected<br>edge selection<br>enabled)                   | Asyn-<br>chro-<br>nous                                       | Input         | ® - c                                     |
| KRO to<br>KR3 | Input            | P60 to<br>P63            | Parallel falling edge detec-<br>tion testable input                                                    |                                                              | Input         | (F) - A                                   |
| KR4 to<br>KR7 | Input            | P70 to<br>P73            | Parallel falling edge detec-<br>tion testable input                                                    |                                                              | Input         | (F) - A                                   |

(to be continued)

2-5 ■ 6427525 0094878 T62 ■

# Table 2-2 List of Pins Other than Port Pins (cont'd)

| Pin Name                                | Input/<br>Output | Dual-<br>Function<br>Pin | Function                                                                                                                                               | When<br>Reset | Input/<br>Output<br>Circuit<br>Type<br>*1 |
|-----------------------------------------|------------------|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|-------------------------------------------|
| S12 to<br>S23                           | Output           |                          | Segment signal output                                                                                                                                  | *3            | G - A                                     |
| S24 to<br>S31                           | Output           | BPO to<br>BP7            | Segment signal output                                                                                                                                  | *3            | G - C                                     |
| COMO to<br>COM3                         | Output           |                          | Common signal output                                                                                                                                   | *3            | G - B                                     |
| V <sub>LCO</sub> to<br>V <sub>LC2</sub> | Input            |                          | LCD drive power<br>On-chip split resistor<br>(mask option) *4                                                                                          |               |                                           |
| BIAS                                    | Output           |                          | External split resistor<br>cut output                                                                                                                  | *5            |                                           |
| LCDCL *2                                | Output           | P30                      | Clock output for<br>externally extended driver<br>drive                                                                                                | Input         | E - B                                     |
| SYNC *2                                 | Output           | P31                      | Clock output for<br>externally extended driver<br>synchronization                                                                                      | Input         | Е-В                                       |
| ANO to<br>AN5                           | Input            |                          | A/D converter analog signal input                                                                                                                      | Input .       | Y                                         |
| an6                                     |                  | P82                      |                                                                                                                                                        |               | Y - B                                     |
| AN7                                     |                  | P83 .                    |                                                                                                                                                        |               |                                           |
| AV <sub>REF</sub>                       | Input            |                          | A/D converter reference<br>voltage input                                                                                                               |               | Z                                         |
| AV <sub>SS</sub>                        | Input            |                          | A/D converter reference GND potential                                                                                                                  |               | Z                                         |
| X1<br>X2                                | Input            |                          | Crystal/ceramic connection<br>pins for main-system clock<br>oscillation. External clock<br>is input to X1 and its<br>inverted phase is input to<br>X2. |               |                                           |

(to be continued)

2-6 🖬 6427525 0094879 9T9 🖿

# Table 2-2 List of Pins Other than Port Pins (cont'd)

| Pin Name        | Input/<br>Output | Dual-<br>Function<br>Pin | Function                                                                                                                                                                                                                  | When<br>Reset | Input/<br>Output<br>Circuit<br>Type<br>*1 |
|-----------------|------------------|--------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|-------------------------------------------|
| XT1             | Input            |                          | Crystal connection pins for subsystem clock oscillation.                                                                                                                                                                  |               |                                           |
| XT2 *6          |                  |                          | External clock is input to<br>XT1 and XT2 is left open.<br>XT1 can also be used as a<br>1-bit input (test) pin.                                                                                                           |               |                                           |
| RESET           | Input            |                          | System reset input                                                                                                                                                                                                        |               | B                                         |
| MDO to<br>MD3   |                  | P30 to<br>P33            | Only incorporated in<br>uPD75P336.<br>Mode selection for program<br>memory (PROM) write/verify.                                                                                                                           | Input         | E - B                                     |
| IC              |                  |                          | Only incorporated in<br>uPD75336.<br>Internally Connected.<br>Connect directly to V <sub>DD</sub> .                                                                                                                       |               |                                           |
| V <sub>PP</sub> |                  |                          | Only incorporated in<br>uPD75P336.<br>Program voltage application<br>for program memory (PROM)<br>write/verify<br>Connect directly to V <sub>DD</sub> for<br>normal operation.<br>Apply +12.5 V for PROM<br>write/verify. |               |                                           |
| V <sub>DD</sub> |                  |                          | Positive power                                                                                                                                                                                                            |               |                                           |
| v <sub>SS</sub> |                  |                          | GND potential                                                                                                                                                                                                             |               |                                           |

2-7 ■ 6427525 0094880 610 ■

- \*1: Circled circuits have a Schmitt trigger input.
  - 2: Pins reserved for future system expansion. Currently used as P30 and P31 pins only.
  - 3: The following  $V_{LCX}$  is selected as an input source for each display output. S12 to S31:  $V_{LC1}$ , COMO to COM2:  $V_{LC2}$ , COM3:  $V_{LC0}$ Each display output level varies depending on each display output and  $V_{LCX}$  external circuit.
  - 4: uPD75P336 does not incorporate a split resistor by mask option.
  - 5: When a split resistor is incorporated ... Low level When a split resistor is not incorporated ... High impedance
- 6: When no subsystem clock is used, refer to Section 5.2.2 (5).



2.2 DESCRIPTION OF PIN FUNCTIONS

2.2.1 POO TO PO3 (PORTO) ... INT4, SCK, SO/SBO, AND SI/SB1 DUAL-FUNCTION INPUTS P10 TO P13 (PORT1) ... INTO, 1, 2 AND TIO DUAL-FUNCTION INPUTS

4-bit input port: Port 0 and port 1 input pins

Ports 0 and 1 have the following functions in addition to the input port functions.

- . Port 0: Vectored interrupt input (INT4) Serial interface input/output (SCK, SO/SBO, SI/SB1)
- . Port 1: Vectored interrupt inputs (INTO, INT1) Edge-detected test input (INT2) External event pulse inputs to the timer/event counter (TIO, TI1)

The pin statuses of ports 0 and 1 can always be input irrespective of dual-function pin operations.

P00/INT4, P01/SCK, P02/S0/SB0, P03/SI/SB1 inputs of port 0 and each pin of port 1 are Schmitt trigger inputs to prevent errors due to noise. P10 is equipped with a noise eliminator (refer to Section 6.3 (3) "INT0, INT1 and INT4 hardware" for details).

An on-chip pull-up resistor can be specified by the software for port 0 (PO1 to PO3) as a 3-bit unit or for port 1 (P10 to P13) as a 4-bit unit. This specification can be made by operating pull-up resistor specification register group A.

When the RESET signal is generated, all pins are set to the input port mode.

# 2-9 🖬 6427525 0094882 493 🎟

2.2.2 P20 TO P23 (PORT2) ... PTOO, PTO1, PCL AND BUZ DUAL-FUNCTION INPUTS/OUTPUTS P30 TO P33 (PORT3) ... LCDCL AND SYNC DUAL-FUNCTION INPUTS/OUTPUTS P40 TO P43 (PORT4). P50 TO P53 (PORT5) ... N-ch OPEN-DRAIN MIDDLE-VOLTAGE (10 V) HIGH-CURRENT OUTPUT P60 TO P63 (PORT6), P70 TO P73 (PORT7), P80 TO P83 (PORT8) ... TI1, AN6 AND AN7 DUAL-FUNCTION INPUTS/OUTPUTS 4-bit input/output port with output latch: Ports 2 to 8 input/output pin Port n (n = 2, 3, 6, 7) carries out the following functions in addition to the input/output port functions. . Port 2 : Timer/event counter output (PTOO, PTO1) Clock output (PCL) Any frequency output (BUZ) . Port 3 : LCD externally extended driver drive clock (LCDCL) LCD externally extended driver synchronizing clock (SYNC) . Ports 6 and 7: Key interrupt inputs (KRO to KR3, KR4 to KR7)

Port 3 is a high-current output and can directly drive LEDs.

Ports 4 and 5 are N-ch open-drain middle-voltage (10 V) and high-current outputs and can directly drive LEDs.

The input/output mode of each port is selected using the port mode register. Ports 2, 4, 5, 7 and 8 can be specified in 4-bit units and ports 3 and 6 can be specified in bit units.

2-10 ■ 6427525 0094883 32T ■ An on-chip pull-up resistor can be specified in 4-bit units by software for ports 2, 3, 6, 7 and 8 using the pull-up resistor specification registers (POGA, POGB). An on-chip pull-up resistor can be specified bit-wise by mask option for ports 4 and 5 of the uPD75336.

8-bit unit input/output is possible for ports 4 and 5 in pairs or ports 6 and 7 in pairs. When RESET signal is generated, ports 2, 3, 6, 7 and 8 are set to the input mode (output high impedance) and ports 4 and 5 become high level (when a pull-up resistor is incorporated) or high impedance.

### 2.2.3 BPO TO BP7 ... CD CONTROLLER/DRIVER SEGMENT SIGNAL OUTPUT (S24 TO S31) DUAL-FUNCTION OUTPUT

1-bit output port with output latch: Output pin of bit ports 0 to 7. Also serve as LCD controller/driver segment signal output pins (S24 to S31). Use this port for CMOS load drive.

2.2.4 TIO ... PORT 1 DUAL-FUNCTION INPUT TI1 ... PORT 8 DUAL-FUNCTION INPUT

> External event pulse input pins of programmable timer/ event counters 0 and 1.

TIO and TI1 are Schmitt trigger inputs.

2.2.5 PTOO, PTO1 ... PORT 2 DUAL-FUNCTION OUTPUTS

Output pins of programmable timer/event counters 0 and 1. Generate square wave pulses. When a programmable timer/ event counter signal is output, the output latch is cleared to "0" and port 2 bit of the port mode register is set to output mode "1".

The timer start instruction clears the output to "0".

2-11 ■ 6427525 0094884 266 ■

#### 2.2.6 PCL ... PORT 2 DUAL-FUNCTION OUTPUT

Programmable clock output pin. Used to supply clocks to the peripheral LSIs (such as a slave microcomputer and an A/D converter). When the RESET signal is generated, the clock mode register (CLOM) is cleared to "0", clock output is disabled and this pin is set to the normal port operating mode.

#### 2.2.7 BUZ ... PORT 2 DUAL-FUNCTION OUTPUT

Frequency output pin. Used to generate buzzer sound or trim the system clock oscillator frequency by generating a frequency (2 kHz, 4 kHz, 32 kHz). Also serves as the P23 pin and is only valid when bit 7 (WM7) of the clock mode register (WM) is set to "1".

When the  $\overline{\text{RESET}}$  signal is generated, WM7 is cleared to "0" and this pin is set to the normal port operating mode.

# 2.2.8 SCK, SO/SBO, SI/SB1 ... PORT 0 DUAL-FUNCTION 3-STATE INPUTS/OUTPUTS

Input/output pins for the serial interface. Each pin operates according to the setting of the serial operating mode register (CSIM).

When the  $\overline{\text{RESET}}$  signal is generated, the serial interface stops operating and becomes an input port.

Each pin is a Schmitt trigger input.



#### 2.2.9 INT4 ... PORT O DUAL-FUNCTION INPUT

External vectored interrupt input pin with both active rising and falling edges. When a signal input to this pin changes from low to high or vice versa, the interrupt request flag is set.

INT4 is an asynchronous input and is acknowledged irrespective of the CPU operation clock when a signal having a specified high-level or low-level width is input.

INT4 can also be used to release the STOP mode and HALT mode. It also serves as a Schmitt trigger input.

2.2.10 INTO, INT1 ... PORT 1 DUAL-FUNCTION INPUTS

Edge-detected vectored interrupt input pins. INTO has a noise elimination function. The detected edge can be selected using the edge detection mode registers (IMO, IM1).

(1) INTO (IMO bits 0 and 1)

- (a) Rising edge active
- (b) Falling edge active
- (c) Both rising and falling edge active
- (d) External interrupt signal input disabled

(2) INT1 (IM1 bit 0)

- (a) Rising edge active
- (b) Falling edge active

2 - 136427525 0094886 039 💻

INTO has a noise elimination function. The sampling clock for noise elimination can be changed at two levels. The width of an acknowledgeable signal varies depending on the CPU operation clock.

INT1 is an asynchronous input and is acknowledged irrespective of the CPU operation clock if there is an input having the specified high-level width.

When the  $\overrightarrow{\text{RESET}}$  signal is generated, IMO and IM1 are cleared to "O" and rising edge active is selected.

INT1 can also be used to release the STOP mode and HALT mode, but INTO cannot.

INTO and INT1 are Schmitt trigger inputs.

2.2.11 INT2 ... PORT 1 DUAL-FUNCTION INPUT

External test input pin with both rising and falling edge active. When INT2 is selected by the edge-detection mode register (IM2) or a signal input to this pin changes from low to high, the internal test flag (IRQ2) is set.

INT2 is an asynchronous input and is acknowledged irrespective of the CPU operation clock if there is an input having the specified high-level width.

When the  $\overline{\text{RESET}}$  signal is generated, IM2 is cleared to "0" and the test flag (IRQ2) is set by INT2 pin rising edge input.

INT2 can also be used to release the STOP mode and HALT mode. It is a Schmitt-triggered input.

#### 2-14 ■ 6427525 0094887 T75 ■

2.2.12 KRO TO KR3 ... PORT 6 DUAL-FUNCTION INPUTS KR4 TO KR7 ... PORT 7 DUAL-FUNCTION INPUTS

Key interrupt input pins. KRO to KR7 are parallel falling edge detected interrupt input pins.

The interrupt format can be specified in accordance with the edge-detection mode register (IM2).

When the  $\overrightarrow{\text{RESET}}$  signal is generated, input mode is set for ports 6 and 7.

2.2.13 S12 TO S23 ... OUTPUTS S24 TO S31 ... BIT PORTS 0 TO 7 DUAL-FUNCTION OUTPUTS

> Segment signal output pins capable of directly driving the LCD segment pin (front electrode). They execute 2- or 3time multiplexing based on the static, 1/2 bias method or 3- to 4-time multiplexing based on the 1/3 bias method.

> S12 to S23 are segment special-purpose output pins and S24 to S31 also serve as bit ports 0 to 7 output pins. They are switched for use by the display mode register (LCDM).

2.2.14 COMO TO COM3 ... OUTPUTS

Common signal output pin capable of directly driving the LCD common pin (rear electrode). They generate common signals when 2-time multiplexing (COMO, 1 output) or 3time multiplexing (COMO, 1, 2 outputs) is executed based on the static (COMO, 1, 2 and 3 outputs), 1/2 bias method, or 3-time multiplexing (COMO, 1, 2 outputs) or 4-time multiplexing (COMO, 1, 2, 3 outputs) is executed based on the 1/3 bias method.

> 2-15 ■ 6427525 0094888 901 ■

# 2.2.15 $V_{LCO}$ to $V_{LC2}$

LCD drive power supply pins. The uPD75336 can have an onchip dividing resistor so as to supply LCD drive power in accordance with each bias method to the  $V_{\rm LCO}$  to  $V_{\rm LC2}$  pins without the use of an external split resistor (mask option).

#### 2.2.16 BIAS

Split resistor cut output pin. Connected to the  $V_{\rm LCO}$  pin to cope with various LCD drive voltages in order to change the resistor division ratio. With an external resistor connected, this pin is used together with the  $V_{\rm LCO}$  to  $V_{\rm LC2}$  pins and  $V_{\rm SS}$  pin for fine adjustment of the LCD drive power voltage value.

2.2.17 LCDCL

LCD externally extended driver drive clock output pin

#### 2.2.18 SYNC

LCD externally extended drive cyclic clock output pin

#### 2.2.19 ANO TO AN5

AN6 & AN7 ... PORT 8 DUAL-FUNCTION INPUTS

8 analog signal input pins for the A/D converter

#### 2.2.20 AVREE

A/D converter reference voltage input pin

#### 2.2.21 AV<sub>SS</sub>

A/D converter GND pin. It should always be set the same voltage as  $\rm V_{SS}.$ 

#### 2-16 ■ 6427525 0094889 848 ■

2.2.22 X1, X2

Crystal/ceramic connection pins for main-system clock oscillation

External clocks can also be input to these pins.

(a) Crystal/ceramic oscillation (b) External clock



#### 2.2.23 XT1, XT2

Crystal connection pins for subsystem clock oscillation.

External clocks can also be input to these pins.

(a) Crystal oscillation

(b) External clock



Remarks: When no subsystem clock is used, refer to Section 5.2.2 (5).

2-17 ■ 6427525 0094890 56T ■

#### 2.2.24 RESET

Low-level active reset input pin.

RESET input is an asynchronous input. When a signal having the specified low-level width is input irrespective of the operation clock, the  $\overrightarrow{\text{RESET}}$  signal is generated and a system reset is applied with priority over all other operations.

In addition to normal CPU initialize/start operations, this pin is used to release the STOP mode and HALT mode.

**RESET** input is a Schmitt trigger input.

2.2.25 MDO TO MD3 (uPD75P336 ONLY)

Only the uPD75P336 incorporates MD0 to MD3 pins.

This pin is used to select the mode for write/verify for the program memory (one-time PROM).

2.2.26 IC (uPD75336 ONLY)

The IC (Internally Connected) pin is a pin for setting the test mode in order to test the uPD75336 when shipped by NEC. In normal operation, the IC pin should be connected directly to the  $V_{\rm DD}$  pin, and the wiring length should be kept as short as possible.

The customer's program may not function normally if a potential difference arises between the IC pin and the  $V_{\rm DD}$  pin when the wiring between the IC pin and  $V_{\rm DD}$  pin is long, or external noise is applied to the IC pin.

2-18 ■ 6427525 0094891 4T6 ■ o Connect the IC pin directly to the  ${\tt V}_{\sf DD}$  pin.



2.2.27  $V_{\rm PP}$  (uPD75P336 ONLY)

Program voltage input pin for program memory (one-time PROM) write/verify.

Connect this pin directly to  $\boldsymbol{V}_{\text{DD}}$  for normal operation.

2.2.28 V<sub>DD</sub>

Positive power supply pin.

2.2.29 V<sub>SS</sub>

GND potential



#### 2.3 PIN INPUT/OUTPUT CIRCUITS

The input/output circuits of the uPD75336 pins are schematically shown below.



2-20



2-21



#### 2.4 RECOMMENDED CONNECTION OF UNUSED PINS

#### Table 2-3 Recommended Connection of Unused Pins

| Pin                              | Recommended Connection                                                                                   |
|----------------------------------|----------------------------------------------------------------------------------------------------------|
| P00/INT4                         | Connect to V <sub>SS</sub> .                                                                             |
| P01/SCK                          | Connect to $V_{SS}$ or $V_{DD}$ .                                                                        |
| P02/S0/SB0                       |                                                                                                          |
| P03/SI/SB1                       |                                                                                                          |
| P10/INTO to P12/INT2             | Connect to V <sub>SS</sub> .                                                                             |
| P13/TI0                          | _ **                                                                                                     |
| P20/PT00                         | Input status : Connect to V <sub>SS</sub> or V <sub>DD</sub> .<br>Output status: Leave open.             |
| P21/PT01                         | output status. Leave Open.                                                                               |
| P22/PCL                          |                                                                                                          |
| P23/BUZ                          |                                                                                                          |
| P30/P33<br>(P30/MD0 to P33/MD3)* |                                                                                                          |
| P40 to P43                       |                                                                                                          |
| P50 to P53                       |                                                                                                          |
| P60 to P63                       |                                                                                                          |
| P70 to P73                       |                                                                                                          |
| P80, P81                         |                                                                                                          |
| P82/AN6, P83/AN7                 |                                                                                                          |
| S12 to S23                       | Leave open.                                                                                              |
| S24/BPO to S31/BP7               |                                                                                                          |
| COMO to COM3                     |                                                                                                          |
| $v_{LC0}$ to $v_{LC2}$           | Connect to V <sub>SS</sub> .                                                                             |
| BIAS                             | Only when all $V_{LC0}$ to $V_{LC2}$ are not used, connect to $V_{SS}$ . In all other cases, leave open. |
|                                  | (to be continued)                                                                                        |

🖿 6427525 0094896 T88 📟

2-23

# Table 2-3 Recommended Connection of Unused Pins (cont'd)

| Pin                    | Recommended Connection                          |
|------------------------|-------------------------------------------------|
| XTI                    | Connect to V <sub>SS</sub> or V <sub>DD</sub> . |
| XT2                    | Leave open.                                     |
| ANO to AN5             | Connect to V <sub>SS</sub> or V <sub>DD</sub> . |
| IC (V <sub>PP</sub> )* | Connect directly to V <sub>DD</sub> .           |

\* : Pins only for uPD75P336 in parentheses

#### 2.5 MASK OPTION SELECTION

The following mask options are available for the pins (uPD75336 only).

| Pin                                           | Mask Option |                                                                                    |   |                                                                                 |  |
|-----------------------------------------------|-------------|------------------------------------------------------------------------------------|---|---------------------------------------------------------------------------------|--|
| P40 to P43,<br>P50 to P53                     | 1           | Without pull-up<br>resistor<br>(Specifiable<br>bit-wise)                           | 2 | With pull-up<br>resistor<br>(Specifiable<br>bit-wise)                           |  |
| BIAS,<br>V <sub>LCO</sub> to V <sub>LC2</sub> | 1           | Without split<br>resistor for LCD<br>drive power supply<br>(Specify in 4<br>units) | 2 | With split<br>resistor for LCD<br>drive power supply<br>(Specify in 4<br>units) |  |
| XT1, XT2                                      | 1           | With feedback<br>resistor<br>(When subsystem<br>clock is used)                     | 2 | Without feedback<br>resistor<br>(When subsystem<br>clock is not used)           |  |

Table 2-4 Mask Option Selection

### ■ 6427525 0094897 914 ■ 2-24

#### CHAPTER 3. DATA MEMORY OPERATION AND MEMORY MAP

The 75X architecture employed for the uPD75336 has the following features:

- . On-chip RAM with a maximum capacity of 4K words x 4 bits (12bit address)
- . Peripheral hardware extendibility

To achieve these excellent features, the following methods are employed.

- .(1) Data memory bank configuration
  - (2) Memory mapped I/O

Each feature is described in detail below.

#### ■ 6427525 0094898 850 ■ 3-1

#### 3.1 DATA MEMORY BANK CONFIGURATION AND ADDRESSING MODE

#### 3.1.1 DATA MEMORY BANK CONFIGURATION

The uPD75336 incorporates static RAM in addresses 000H to 2FFH of the data memory space, of which the 20 x 4 bits in addresses 1ECH to 1FFH are used as display data memory. Peripheral hardware (input/output ports, timers, etc.) is allocated to addresses F80H to FFFH.

For addressing the 12-bit address (4K words x 4 bits) data memory space, the uPD75336 has a memory bank configuration in which the least significant 8-bit address is directly or indirectly specified by an instruction and the most significant 4-bit address is specified by a memory bank (MB).

To specify the MB, the following hardware is incorporated:

Memory bank enable flag (MBE)Memory bank select register (MBS)

The MBS is a register to select the memory bank and can set 0, 1, 2 and 15 of the memory bank. The MBE is a flag to determine whether the memory bank selected by the MBS should be validated or not. As shown in Figure 3-1, when the MBE is 0, the memory bank (MB) to be specified is fixed irrespective of the MBS. When the MBE is 1, the data memory space can be expanded by switching the memory bank by setting the MBS.

For data memory space addressing, MBE = 1 is normally set and the data memory of the memory bank specified by the MBS is operated. Programming can be carried out efficiently by using the MBE = 0 or MBE = 1 mode for each program operation.

#### ■ 6427525 0094899 797 ■ 3-2

|                 | Applicable Program Operation                                              | Effects                                  |
|-----------------|---------------------------------------------------------------------------|------------------------------------------|
| MBE = 0<br>mode | o Interrupt servicing                                                     | MBS save/restore<br>becomes unnecessary. |
|                 | o Repetition of on-chip<br>hardware operation and<br>static RAM operation | MBS change becomes unnecessary.          |
|                 | o Subroutine operation                                                    | MBS save/restore<br>becomes unnecessary. |
| MBE = 1<br>mode | o Normal program operation                                                |                                          |

Figure 3-1 MBE = 0 Mode and MBE = 1 Mode Distinction



<Main Program>

Remarks: ----- when MBE = 1; ----- when MBE = 0

Since the MBE is automatically saved/restored in subroutine processing, it can be changed freely in that processing. The MBE is also automatically saved/restored in interrupt servicing, and in addition, the MBE undergoing interrupt servicing can be specified upon interrupt servicing startup by setting the interrupt vector table. Thus, interrupt servicing can be carried out at high-speeds.

> ■ 6427525 0094900 239 ■ 3-3

When changing the MBS in subroutine processing or interrupt servicing, save/restore it by the PUSH/POP instruction.

Set the MBE by the SET1/CLR1 instruction. Set the MBS by the SEL instruction.

Example 1: Clear the MBE and fix the memory bank.

CLR1 MBE; MBE  $\leftarrow 0$ 

2: Select memory bank 1.

SET1 MBE; MBE ← 1 SEL MB1; MBS ← 1

3.1.2 DATA MEMORY ADDRESSING MODE

In the 75X series architecture employed for the uPD75336, seven types of addressing modes shown in Figure 3-2 and Table 3-1 are available for efficient addressing for each bit length of data used for data memory space processing so that programming can be carried out efficiently.

#### ° ■ 6427525 0094901 175 ■ 3-4



# Figure 3-2 Data Memory Configuration and Addressing Range in Each Addressing Mode

- : don't care



# Table 3-1 Addressing Mode

| Addressing Mode                          | Identifier   | Address to be Specified                                                                                                                                                                                                  |
|------------------------------------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1-bit direct<br>addressing               | mem.bit      | Bit indicated by bit of the address indicated<br>by MB and mem<br>When MBE = 0, $MB = 0$ if mem = 00H to 7FH.<br>MB = 15 if mem = 80H to FFH.<br>When MBE = 1, MB = MBS                                                  |
| 4-bit direct<br>addressing               | nen          | Address indicated by MB and mem.<br>When MBE = 0, $MB = 0$ if mem = 00H to 7FH.<br>MB = 15 if mem = 80H to FFH.<br>When MBE = 1, MB = MBS                                                                                |
| 8-bit direct<br>addressing               |              | Address indicated by MB and mem (even address).<br>When MBE = 0, $MB = 0$ if mem = 00H to 7FH.<br>MB = 15 if mem = 80H to FFH<br>When MBE = 1, MB = MBS                                                                  |
| 4-bit register<br>indirect<br>addressing | @HL          | Address indicated by MB and HL<br>where MB = MBE·MBS                                                                                                                                                                     |
|                                          | @HL+<br>@HL- | Address indicated by MB and HL where MB =<br>MBE·MBS.<br>HL+ automatically increments L register after<br>addressing.<br>HL- automatically decrements L register after<br>addressing.                                    |
|                                          | @DE          | Address indicated by DE of memory bank 0                                                                                                                                                                                 |
|                                          | @DL          | Address indicated by DL of memory bank 0                                                                                                                                                                                 |
| 8-bit register<br>indirect<br>addressing | @HL          | Address indicated by MB and HL where MB =<br>MBE·MBS (Bit 0 of L register is ignored)                                                                                                                                    |
| Bit manipula-<br>tion<br>addressing      | fmem.bit     | Bit indicated by bit of the address indicated<br>by fmem<br>where fmem = {FBOH to FBFH (interrupt-related<br>hardware)<br>FFOH to FFFH (I/O port)                                                                        |
|                                          | pmen.@L      | Bit indicated by the most significant 2 bits of<br>the L register of the address indicated by the<br>most significant 10 bits of pmem and the least<br>significant 2 bits of the L register<br>where pmem = FCOH to FFFH |

(to be continued)

3-6 • 🖬 6427525 0094903 T48 🎟

#### Table 3-1 Addressing Mode (cont'd)

| Addressing Mode                               | Identifier | Address to be Specified                                                                                                    |
|-----------------------------------------------|------------|----------------------------------------------------------------------------------------------------------------------------|
| Bit<br>manipulation<br>addressing<br>(cont'd) | @H+mem.bit | Bit indicated by bit of the address indicated<br>by MB, H and the least significant 4 bits of<br>mem<br>where MB = MBE·MBS |
| Stack<br>addressing                           |            | Address indicated by SP of memory bank 0                                                                                   |

(1) 1-bit direct addressing (mem.bit)

In this addressing mode each bit of the whole data memory space is directly specified by an instruction operand.

In the MBE = 0 mode the memory bank (MB) to be specified is fixed to MB = 0 when the address specified by the operand is 000H to 07FH and MB = 15 when the address is F80H to FFFH. Thus, in the MBE = 0 mode both the data area 000H to 07FH and the peripheral hardware area F80H to FFFH can be addressed.

In the MBE = 1 mode MB = MBS is set and the data memory space to be specified can be expanded.

This addressing mode can be applied to four instructions; bit set/reset instructions (SET1/CLR1) and bit test instructions (SKT/SKF).

■ 64275250094904984 ■ 3-7

Example: Set FLAG1, reset FLAG2 and test whether FLAG3 is 0.

FLAG1 EQU O3FH.1; Bit 1 at address 3FH FLAG2 EQU 087H.2; Bit 2 at address 87H FLAG3 EQU OA7H.0; Bit 0 at address A7H SET1 ; MBE + 1 MBE ; MBS + 0 SEL MBO SET1 FLAG1 ; FLAG1 + 1 CLR1 FLAG2 ; FLAG2 + 0 SKF FLAG3; FLAG3 = 0?

(2) 4-bit direct addressing (mem)

In this address mode the entire data memory space is directly specified in 4-bit units by an instruction operand.

As is the case with the 1-bit direct addressing mode, the specifiable areas are fixed to the data area 000H to 07FH and the peripheral hardware area F80H to FFFH in the MBE = 0 mode. In the MBE = 1 mode, MB = MBS and the data memory space to be specified is expanded to the entire available space.

This addressing mode is applied to the MOV, XCH, INCS, IN and OUT instructions.

Example 1: Enter port 4 and store it in "DATA1".

DATA1 EQU 5FH ; "DATA1" at address 5FH CLR1 MBE ; MBE + 0 IN A, PORT4; A + PORT4 MOV DATA1, A; (DATA1) + A

■ 6427525 0094905 810 ■ 3-8 Example 2: Generate "BUFF" data to port 8.

| BUFF | EQU  | 11AH ;    | "BUFF" at address     |
|------|------|-----------|-----------------------|
|      |      |           | 11AH                  |
|      | SET1 | MBE ;     | MBE + 1               |
|      | SEL  | MB1 ;     | MBS + 1               |
|      | MOV  | A, BUFF ; | $A \leftarrow (BUFF)$ |
|      | SEL  | MB15 ;    | MBS + 15              |
|      | OUT  | PORT8, A; | PORT8 + A             |

NOTE: When data related to an input/output port is stored in the static RAM of bank 1 as in this example, program efficiency is decreased. As in the example 1, programming can be carried out without changing MBS if input/output port related data is stored at addresses 000H to 07FH of bank 0.

(3) 8-bit direct addressing (mem)

In this addressing mode the entire data memory space is directly specified by an instruction operand in 8bit units.

Addresses which can be specified by an operand are even addresses. 4-bit data of the address specified by an operand and 4-bit data of the address plus one undergo 8-bit processing in pairs with the 8-bit accumulator (XA register pair).

The memory bank to be specified is the same as with 4-bit direct addressing.

This addressing mode is applied to the MOV, XCH, IN and OUT instructions.

■ 6427525 0094906 757 ■ 3-9 Example 1: Transfer 8-bit data at ports 4 and 5 to addresses 20H and 21H and generate the data previously placed at addresses 20H and 21H from ports 6 and 7.

| DATA | EQU  | 020H       |                                 |
|------|------|------------|---------------------------------|
|      | CLR1 | MBE ;      | MBE + 0                         |
|      | IN   | XA, PORT4; | XA + Ports 5 and 4              |
|      | XCH  | XA, DATA ; | $XA \leftrightarrow (21H, 20H)$ |
|      | OUT  | PORT6, XA; | Ports 7 and 6 + XA              |

2: Fetch 8-bit data input to the serial interface shift register (SIO) and simultaneously set transfer data.

| SEL | MB15    | ; | MBS +                | 15  |
|-----|---------|---|----------------------|-----|
| XCH | XA, SIO | ; | $XA \leftrightarrow$ | SIO |

(4) 4-bit register indirect addressing (@rpa)

In this addressing mode the data memory space is indirectly specified in 4-bit units using the data pointer (general register pair) specified by an instruction operand.

Three types of data pointers are available. They are the HL register pair which can specify the entire data memory space by specifying MB = MBE·MBS, the DE and DL register pairs which are always fixed to memory bank 0 irrespective of MBE and MBS specification. Programming can be performed efficiently by selecting the appropriate data pointer depending on the data memory bank to be used.

When the HL register pair is specified, the auto increment and auto decrement modes are available to add one to or subtract one from the L register, respectively, simultaneously when an instruction is executed. The program steps can be decreased by using these modes.

Example: Transfer 50H to 57H data to 110H to 117H.

| DATA1 | EQU  | 57H                  |                     |
|-------|------|----------------------|---------------------|
| DATA2 | EQU  | 117H                 |                     |
|       | SET1 | MBE ;                | MBE + 1             |
|       | SEL  | MB1 ;                | MBS + 1             |
|       | MOV  | D, #DATA1 SHR 4 ;    | D + 5               |
|       | MOV  | HL, #DATA2 AND OFFH; | HL + 17H            |
| LOOP: | MOV  | A, @DL ;             | A + (DL)            |
|       | XCH  | A, @HL- ;            | $A \leftrightarrow$ |
|       |      |                      | (HL),               |
|       |      |                      | L + L - 1           |
|       | BR   | LOOP                 |                     |

The addressing mode with the HL register pair used as the data pointer is widely applied for data transfer, operations, comparison, input/output, etc. The addressing mode using the DE and DL register pairs is applied to the MOV and XCH instructions.

When used with a general register or the register pair increment and decrement instructions, the addresses in the data memory space can be freely updated in this addressing mode as shown in Figure 3-2.

> ■ 6427525 0094908 52T ■ 3-11

Example 1: Compare 50H to 57H data with 110H to 117H data.

2: Clear data memory OOH to FFH to "O".

|       | CLR1 | RBE              |
|-------|------|------------------|
|       | CLR1 | MBE              |
|       | MOV  | ХА, #ООН         |
|       | MOV  | HL, #04H         |
| LOOP: | MOV  | (HL, A; (HL) + A |
|       | INCS | HL ; HL + HL + 1 |
|       | BR   | LOOP             |

#### ■ 6427525 0094909 466 ■ 3-12



Figure 3-3 Static RAM Address Updating Method

(5) 8-bit register indirect addressing (@HL)

In this addressing mode the entire data memory space is indirectly specified in 8-bit units using the data pointer (HL register pair).

4-bit data of address with bit 0 of data pointer (bit 0 of L register) and 4-bit data of the address plus one undergo 8-bit processing in pairs with the 8-bit accumulator (XA register).

As is the case with the HL register specified in the 4-bit register indirect addressing mode, the memory bank to be specified is MB = MBS·MBS.

This addressing mode is applied to the MOV, XCH and SKE instructions.

■ 6427525 0094910 188 ■ 3-13 Example 1: Check if the count register (TO) value of timer/event counter 0 is equal to data at addresses 30H and 31H.

2: Clear data memory OOH to FFH to 0.

|       | CLR1 | RBE                            |
|-------|------|--------------------------------|
|       | CLR1 | MBE                            |
|       | MOV  | ХА, #ООН                       |
|       | MOV  | HL, #04H                       |
| LOOP: | MOV  | $GHL, XA ; (HL) \leftarrow XA$ |
|       | INCS | HL                             |
|       | INCS | HL                             |
|       | BR   | LOOP                           |



#### (6) Bit manipulation addressing

In this addressing mode bit manipulation (including Boolean processing and bit transfer) is carried out for each bit in all data memory spaces.

The 1-bit direct addressing mode can only be applied to the bit set, bit reset and bit test instructions. In contrast, in this addressing mode a wide variety of bit manipulations can be performed, such as Boolean processing by AND1, OR1 and XOR1 instructions, bit transfer by the MOV1 instruction and test & reset by the SKTCLR instruction.

The following three bit manipulation addressing methods are available for use depending on the data memory address to be used.

(a) Specific address bit direct addressing (fmem.bit)

> In this addressing mode hardware which frequently requires bit manipulation irrespective of memory bank setting can be used. Such hardware includes input/output ports and interrupt related flags among peripheral hardware. Thus, this mode can be applied to data memory addresses FFOH to FFFH with input/output ports mapped and FBOH to FBFH with interrupt related hardware mapped. Hardware in these two data memory areas can perform bit manipulation freely by direct addressing irrespective of MBS and MBE settings.

■ 6427525 0094912 T50 ■ 3-15 Example 1: Generate inverted PO2 in input from the P33 pin.

MOV1 CY, PORT0.2 NOT1 CY MOV1 PORT3.3, CY

2: Test the timer 0 interrupt request flag (IRQTO). If it has been set, clear the request flag and reset P63.

SKTCLRIRQTO ; IRQTO = 1?BRNO ; NOCLR1PORT6.3; YES

3: When both P30 and P41 are 1, reset P53.



| MOV1 | CY, PORT3.0  | ; CY + P30                      |
|------|--------------|---------------------------------|
| AND1 | CY, PORT4.1; | ; CY A P41                      |
| NOT1 | CY           | ; $CY \leftarrow \overline{CY}$ |
| MOV1 | PORT5.3, CY; | ; P53 + CY                      |

(b) Specific address bit register indirect addressing (pmem.@L)

> In this addressing mode the bits of input/output ports among peripheral hardware are indirectly specified using a register and are manipulated continuously. This addressing mode can be applied to the FCOH to FFFH data memory addresses. In addition to input/output ports, a bit-manipulated memory (refer to Section 5.9 "Bit Sequential Buffer") for efficient use of this mode is also included.

3-16 🖬 6427525 0094913 997 🎟

In this addressing mode the most significant 10bit address of the data memory address 12 bits is directly specified by an operand and the least significant 2-bit address and the bit address are indirectly specified using the L register. Thus, 16 bits (4 ports) can be continuously manipulated by L register specification.

This addressing mode also enables bit operation to be executed irrespective of MBE and MBS settings.







Example 2: When P30 is high, transfer 16-bit serial data input from P31 to the bit sequential buffer (BSB).

MOV L, #0 LOOP: SKT PORT3.0 ; P30 = 1?BR LOOP MOV1 CY, PORT3.1; CY + P31MOV1 BSBO.QL, CY; BSB bits  $(L_1 \text{ and }$  $L_0$ ) + CY WAIT: SKF PORT3.0 ; P30 = 0?WAIT BR INCS L ; L + L + 1BR LOOP

(c) Specific 1-bit direct addressing (@H+mem.bit)

In this addressing mode bit manipulation can be performed for each bit of the entire data memory space.

In this addressing mode the most significant 4bit address of the data memory address of the memory bank specified by MB = MBE·MBS is indirectly specified using the H register and the least significant 4-bit address and the bit address are directly specified by an operand. In this addressing mode a wide variety of bit manipulations can be performed for each bit of the entire data memory.

3 - 186427525 009491576T 🎟

Example: When bit 3 (FLAG1) at address 30H and bit 0 (FLAG2) at address 31H are both 0 or 1, reset bit 2 (FLAG3) at address 32H.

FLAG1 - FLAG3

| FLAG1 | EQU  | 30H.3                   |
|-------|------|-------------------------|
| FLAG2 | EQU  | 31H.O                   |
| FLAG3 | EQU  | 32H.2                   |
|       | SEL  | мво                     |
|       | MOV  | H, #FLAG1 SHR 6         |
|       | MOV1 | CY, $@H+FLAG1$ ; CY $+$ |
|       |      | FLAG1                   |
|       | XOR1 | CY, @H+FLAG2 ; CY + CY  |
|       |      | ₩ FLAG2                 |
|       | MOV1 | @H+FLAG3, CY ; FLAG3 +  |
|       |      | СҮ                      |

(7) Stack addressing

In this addressing mode save/restore operations are carried out in interrupt servicing or subroutine processing.

In this addressing mode the address indicated by the stack pointer (8 bits) of data memory bank 0 is specified.

This addressing mode is also applied to register save/restore operations by the PUSH/POP instruction in addition to operations in interrupt servicing and subroutine processing.

> 3-19 ■ 6427525 0094916 6T6 ■

Example 1: Save/restore the register in subroutine processing.

SUB PUSH XA PUSH HL PUSH BS; MBS and RBS save : POP BS POP HL POP XA RET

2: Transfer HL register pair contents to the DE register pair.

PUSH HL POP DE; DE + HL

3: Branch to the address indicated by the [XABC] register.

| RET  | ;  | Branch | to | address | XABC |
|------|----|--------|----|---------|------|
| PUSH | XA |        |    |         |      |
| PUSH | BC |        |    |         |      |

.



### 3.2 GENERAL REGISTER BANK CONFIGURATION

The uPD75336 incorporates four register banks, each bank consisting of eight general registers, X, A, B, C, D, E, H and L. These general register are mapped onto addresses 00H to 1FH of memory bank 0 of the data memory (see Figure 3-5). A register bank enabled flag (RBE) and a register bank select register (RBS) are incorporated to specify the general registers. RBS is a register which selects the register bank and RBE is a flag which determines if the register bank selected by RBS should be validated or not.

The register bank (RB) which becomes valid for instruction execution is represented as

 $RB = RBE \cdot RBS$ 

| RBE        | RBS     |                |   | Register Bank |                 |  |  |
|------------|---------|----------------|---|---------------|-----------------|--|--|
|            | 3 2 1 0 | Register ballk |   |               |                 |  |  |
| 0          | 0       | 0              | x | x             | Fixed to bank 0 |  |  |
| 1          | 0       | 0              | 0 | 0             | Bank 0 selected |  |  |
|            |         |                | 0 | 1             | Bank 1 selected |  |  |
|            |         |                | 1 | 0             | Bank 2 selected |  |  |
|            |         |                | 1 | 1             | Bank 3 selected |  |  |
| Fixed to 0 |         |                |   |               |                 |  |  |

Table 3-2 RBE, RBS and Register Banks Selected

x: Don't care

3-21 ■ 6427525 0094918 479 ■

Since RBE is automatically saved/restored in subroutine processing, it can be freely set in subroutine processing. In interrupt servicing, RBE is also automatically saved/restored, and when interrupt servicing starts, RBE undergoing interrupt servicing can be simultaneously set by interrupt vectored table setting. As shown in Table 3-3, interrupt servicing can be carried out at high speeds by using the appropriate register bank for normal processing and interrupt servicing. In single interrupt servicing, it is not necessary to save/restore general registers. In double interrupt servicing, only RBS is saved/restored

# Table 3-3 Recommended Register Bank Usage in Normal and Interrupt Routines

| Normal operation                         | RBE = 1 is set and register banks 2 and 3 are used.                                                             |
|------------------------------------------|-----------------------------------------------------------------------------------------------------------------|
| Single interrupt servicing               | RBE = 0 is set and register bank 0 is used.                                                                     |
| Double interrupt<br>servicing            | <pre>RBE = 1 is set and register bank 1 is used.<br/>(AT the same time, RBS must be saved/<br/>restored.)</pre> |
| Triple or more<br>interrupt<br>servicing | Register is saved/restored by PUSH and POP.                                                                     |

### ■ 6427525 0094919 305 ■ 3-22

Figure 3-4 Register Bank Usage



Remarks: — when RB = 2, — when RB = 0, ---- when RB = 1.

When changing RBS in subrouting processing or interrupt servicing, save/restore RBS by the PUSH/POP instruction.

RBE is set by the SET1/CLR1 instruction. RBS is set by the SEL instruction.

Example: SET1 RBE; RBE + 1 CLR1 RBE; RBE + 0 SEL RB0; RBS + 0 SEL RB3; RBS + 3

<Main Program>

The general register area incorporated in the uPD75336 can be used not only as 4-bit registers but also as 8-bit registers with register pairs. Programming using a general register as the core unit can be performed by transfer, operation, compare and increment/decrement instructions having functions equal to an 8-bit microcomputer.

> ■ 6427525 0094920 027 ■ 3-23

### (1) When used as 4-bit registers

When the general register area is used as 4-bit registers, a total of eight general registers, X, A, B, C, D, E, H and L specified by RB = RBE·RBS, can be used as shown in Figure 3-5. Among these registers, the A register plays an important role as a 4-bit accumulator for 4-bit data transfers, operations and comparisons. The other general registers can transfer, compare and increment/ decrement data with the accumulator.

### (2) When used as 8-bit registers

When the general register area is used as 8-bit registers, a total of eight 8-bit registers can be used as shown in Figure 3-5. They are register pairs XA, BC, DC and HL, of the register bank specified by RB = RBE·RBS, and register pairs XA', BC', DC' and HL', of the register bank with bit 0 of register bank (RB) inverted. The XA register pair plays an important role as an 8-bit accumulator for 8-bit data transfers, operations, and comparisons. Other register pairs can transfer, calculate, compare and increment/decrement data with the accumulator. The HL register pair functions mainly as a data pointer. The DE register pair functions as an auxiliary data pointer.

Example 1: INCS HL ; HL - HL + 1, skip when HL = OOH ADDS XA, BC ; XA - XA + BC, skip on carry SUBC DE', XA ; DE' - DE' - XA - CY MOV XA, XA' ; XA - XA' MOVT XA, @PCDE; XA - (PC 13 to PC 8 + DE) ROM, table reference SKE XA, BC ; skip when XA = BC 3-24

🖬 6427525 0094921 T63 🎟

Example 2: Check if the count register (TO) value of timer/event counter 0 is greater than the BC' register pair value. If not, wait until the TO value becomes greater than the BC' register pair value.

|     | CLR1 | MBE      |                     |
|-----|------|----------|---------------------|
| NO: | MOV  | XA, TO ; | count register read |
|     | SUBS | XA, BC'; | $XA \geq BC?$       |
|     | BR   | YES ;    | YES                 |
|     | BR   | NO ;     | NO                  |

Figure 3-5 General Register Configuration (4-Bit Processing)

| X                               | 01H | A   | оон | Ī                     |  |
|---------------------------------|-----|-----|-----|-----------------------|--|
| н                               | 03Н | L   | 02H | Register Bank O       |  |
| D                               | 05H | Е   | 04H | $(RBE \cdot RBS = 0)$ |  |
| В                               | 07H | С   | 06Н |                       |  |
| X                               | 09H | A   | 08H |                       |  |
| Н                               | овн | L   | OAH | Register Bank 1       |  |
| D                               | ODH | E   | осн | $(RBE \cdot RBS = 1)$ |  |
| В                               | OFH | С   | OEH |                       |  |
| x                               | 11H | А   | 10H |                       |  |
| Н                               | 13H | L   | 12H | Register Bank 2       |  |
| D                               | 15H | E   | 14H | (RBE $\cdot$ RBS=2)   |  |
| В                               | 17H | С   | 16H |                       |  |
| x                               | 19H | A   | 18H |                       |  |
| Н                               | 1BH | L   | 1AH | Register Bank 3       |  |
| D                               | 1DH | E   | 1CH | $(RBE \cdot RBS = 3)$ |  |
| В                               | 1FH | . C | 1EH |                       |  |
| ы 6427525 0094922 9TT ы<br>3-25 |     |     |     |                       |  |

# Figure 3-6 General Register Configuration (8-Bit Processing)

|                 |           | When RBE RBS | = 0  | When | RBERBS | - 1 |
|-----------------|-----------|--------------|------|------|--------|-----|
| _               |           | XA           | 00Н  |      | XA′    | оон |
| Register Bank O | er Bank O | HL           | ·02H |      | HL.'   | 02H |
|                 | DE        | 04H          |      | DE'  | 04H    |     |
|                 | BC        | 06H          |      | BC'  | оен    |     |
| Register Bank 1 | •         | XA'          | 08H  |      | XA     | 08Н |
|                 | er Bank 1 | HL'          | OAH  |      | HIL.   | OAH |
|                 |           | DE'          | осн  |      | DE     | осн |
|                 |           | BC           | OEH  |      | BC     | ОЕН |

When RBE RBS = 2 When RBE RBS = 3

| -               |     |     |     | <br> |     |
|-----------------|-----|-----|-----|------|-----|
| Register Bank 2 | XA  | 10H | XA' | 10H  |     |
|                 | HL  | 12H | HL' | 12H  |     |
|                 | DE  | 14H | DE  | 14H  |     |
| -               |     | BC  | 16H | BC   | 16H |
| Register Bank 3 | XA' | 18H | XA  | 18H  |     |
|                 | HĽ  | 1AH | HL  | 1AH  |     |
|                 | DE  | 1CH | DE  | 1СН  |     |
|                 |     | BC  | 1EH | BC   | 1EH |



#### 3.3 MEMORY MAPPED I/O

As shown in Figure 3-7, the uPD75336 employs memory mapped I/O with the peripheral hardware including input/output ports and timers mapped onto addresses F80H to FFFH in the data memory space. Thus, there are no special instructions to control the peripheral hardware and all operations are controlled by memory manipulation instructions. (Some hardware control mnemonics are available to make the program easy to understand.)

When operating the peripheral hardware, the addressing modes listed in Table 3-4 can be used.

The display data memory mapped onto addresses 1ECH to 1FFH is manipulated by specifying memory bank 1.

|                            | Applicable Addressing Mode                                                     | Applicable Hardware                                       |
|----------------------------|--------------------------------------------------------------------------------|-----------------------------------------------------------|
| Bit<br>manipu-<br>lation   | Specify by direct addressing<br>mem.bit with MBE = 0 or (MBE = 1,<br>MBS = 15) | All hardware<br>devices enabled for<br>bit manipulation   |
|                            | Specify by direct addressing<br>fmem.bit irrespective of MBE and<br>MBS        | ISTO, IST1, MBE,<br>RBE, IEXXX, IRQXXX,<br>PORTn.X        |
|                            | Specify by indirect addressing<br>pmem.@L irrespective of MBE and<br>MBS       | BSBn.x<br>PORTn.x                                         |
| 4-bit<br>manipu-<br>lation | Specify by direct addressing mem<br>with MBE = 0 or (MBE = 1, MBS =<br>15)     | All hardware<br>devices enabled for<br>4-bit manipulation |
|                            | Specify by register indirect<br>addressing @HL with (MBE = 1, MBS<br>= 15)     |                                                           |

Table 3-4 Addressing Modes Applicable when Operating the Peripheral Hardware

(to be continued)

■ 6427525 0094924 772 ■ 3-27

# Table 3-4 Addressing Modes Applicable when Operating the Peripheral Hardware (cont'd)

|                            | Applicable Addressing Mode                                                                                    | Applicable Hardware                                       |
|----------------------------|---------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------|
| 8-bit<br>manipu-<br>lation | Specify by direct addressing mem<br>with MBE = 0 or (MBE = 1, MBS =<br>15) (mem is an even address)           | All hardware<br>devices enabled for<br>8-bit manipulation |
|                            | Specify by register indirect<br>addressing @HL with MBE = 1 and<br>MBS = 15 (L register contents are<br>even) |                                                           |

| Example: | CLR1   | MBE       | ; | MBE = 0                       |
|----------|--------|-----------|---|-------------------------------|
|          | SET1   | TM0.3     | ; | Timer O start                 |
|          | EI     | IEO       | ; | INTO enabled                  |
|          | DI     | IEI1      | ; | INT1 disabled                 |
|          | SKTCLR | IRQ2      | ; | INT2 request flag test, clear |
|          | SET1   | PORT4.@L  | ; | Port 4 set                    |
|          | IN     | A, PORTO  | ; | A + Port 0                    |
|          | OUT    | PORT4, XA | ; | Ports 5 and 4 + XA            |
|          |        |           |   |                               |

Figure 3-7 shows the uPD75336 I/O map.

In the figure, each item has the following meaning:

. Symbol .. Name indicating the on-chip hardware address Can be described in the instruction operand column.

. R/W ..... Indicates whether the corresponding hardware is enabled for read/write.

R/W: Read/write enabled

- R : Read only
- W : Write only

■ 6427525 0094925 609 ■ 3-28 . No. of manipulable bits

- ..... Indicates the number of applicable bits before operating the corresponding hardware
  - o: Bit manipulation enabled in the units specified in the column (1-, 4- and 8-bit)
  - A: Only limited number of bits enabled for manipulation. For manipulable bits, refer to the remarks column.
  - -: Bit manipulation disabled in the units specified in the column (1-, 4- and 8-bit)
- . Bit manipulation addressing

..... Indicates the applicable bit manipulation addressing before operating the corresponding hardware

| Ad-         | Hardy             | ware Na              | ne (Sym | bol) | R/W | Man | o. o<br>ipul<br>Bits | able      | Bit<br>Manipu-<br>lation          | Remarks              |  |  |
|-------------|-------------------|----------------------|---------|------|-----|-----|----------------------|-----------|-----------------------------------|----------------------|--|--|
| dress       | b3                | b2                   | b1      | ъО   |     | [-  | 4-<br>Bit            | 8-<br>Bit | Address-<br>ing                   |                      |  |  |
| F80H        | Stack 1           | pointer              | (SP)    |      | R/W | -   | 1                    | 0         |                                   | Bit 0 is fixed to 0. |  |  |
|             |                   |                      |         |      | -   | -   |                      |           |                                   |                      |  |  |
| F85H        |                   | interval<br>er (BTM) | mode    | W    | ۵   | ο   | -                    | mem.bit   | Only bit 3 is<br>bit-manipulable. |                      |  |  |
| F86н        | Basic i           | interval             | t timer | (BT) | R   | -   | -                    | ο         |                                   |                      |  |  |
|             |                   |                      |         |      |     |     |                      |           |                                   |                      |  |  |
| <b>F8CH</b> | Display<br>(LCDM) | 7 mode 1             |         | Ŵ    | ۵   | -   | 0                    | mem.bit   | Only bit 3 is<br>bit-manipulable. |                      |  |  |
|             |                   |                      |         |      | -   |     |                      |           |                                   |                      |  |  |
| F8EH        | Display<br>(LCDC) | / contro             | ster    | W    | -   | 0   | -                    |           |                                   |                      |  |  |

(to be continued)

■ 6427525 0094926 545 ■ 3-29

Figure 3-7 uPD75336 I/O Map (cont'd)

| Ad-   | Hardy   | ware Nam | ne (Syml | pol) | R/W      | Man       | Bits      |           | nipulable<br>Bits              |    | Bit<br>Manipu-<br>lation | Remarks |  |
|-------|---------|----------|----------|------|----------|-----------|-----------|-----------|--------------------------------|----|--------------------------|---------|--|
| dress | b3      | ъ2       | b1       | ъо   |          | 1-<br>Bit | 4-<br>Bit | 8-<br>Bit | Address-                       |    |                          |         |  |
| F98H  | Clock I | ode reg  | (WM)     | R/W  | △<br>(R) | -         | 0<br>(W)  | mem.bit   | Only bit 3 is<br>bit-testable. | *1 |                          |         |  |
|       |         |          |          |      |          | -         | -         |           |                                |    |                          |         |  |

|                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | •                                                      | 1                                                      |                                                        |
|--------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------|--------------------------------------------------------|--------------------------------------------------------|
| Timer/event counter 0 mode<br>register (TMO)     | W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0                                                      | mem.bit                                                | Only bit 3 is<br>bit-manipulable.                      |
|                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                        |                                                        |                                                        |
| T0E0*2                                           | Ŵ                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | -                                                      | mem.bit                                                |                                                        |
| Timer/event counter 0 count<br>register (T0)     | R                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0                                                      |                                                        |                                                        |
| Timer/event counter 0<br>modulo register (TMODO) | W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0                                                      |                                                        |                                                        |
| Timer/event counter 1 mode<br>register (TM1)     | W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Δ                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0                                                      | mem.bit                                                | Only bit 3 is<br>bit-manipulable.                      |
|                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                        |                                                        |                                                        |
| T0E1*2                                           | W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | -                                                      | mem.bit                                                |                                                        |
| Timer/event counter 1 count<br>register (T1)     | R                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0                                                      |                                                        |                                                        |
| Timer/event counter 1<br>modulo register (TMOD1) | W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | ο                                                      |                                                        |                                                        |
| IST1 ISTO MBE RBE<br>Program status word (PSW)   | R/W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 0<br>(R/W)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 0<br>(R/W)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 0<br>(R)                                               | fmem.bit                                               | Bit 8 is bit-<br>manipulable only<br>for R.            |
| CY SK2 SK1 SK0                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | _                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                        |                                                        |                                                        |
| Interrupt priority select<br>register (IPS)      | W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | ο                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | -                                                      |                                                        | Only bit 3 is<br>manipulated by<br>EI/DI instruction.  |
|                                                  | TOEO*2         Timer/event counter 0 count         register (T0)         Timer/event counter 0         modulo register (TMODO)         Timer/event counter 1 mode         register (TM1)         TOE1*2         Timer/event counter 1 mode         register (TM1)         TOE1*2         Timer/event counter 1 count         register (T1)         Timer/event counter 1 modulo register (TMOD1)         IST1       IST0         MBE       RBE         Program status word (PSW)         CY       SK2         Interrupt priority select | TOEO*2       W         Timer/event counter 0 count       R         register (TO)       W         Timer/event counter 0       W         modulo register (TMODO)       W         Timer/event counter 1 mode       W         register (TM1)       W         TOE1*2       W         Timer/event counter 1 mode       W         Timer/event counter 1 count       R         register (T1)       W         Timer/event counter 1 mode       W         Timer/event counter 1       W         Timer/event counter 1       W         Timer/event counter 1       W         Togram status word (PSW)       R/W         Program status word (PSW)       K         CY       SK2       SK1       SK0         Interrupt priority select       W | -       -         TOEO*2       W       o         Timer/event counter 0 count       R       -         register (TO)       W       -         Timer/event counter 0       W       -         modulo register (TMODO)       W       -         Timer/event counter 1 mode       W       Δ         register (TM1)       -       -         TOE1*2       W       O         Timer/event counter 1 count       R       -         ToE1*2       W       O         Timer/event counter 1 count       R       -         register (T1)       W       O         Timer/event counter 1       W       -         Total Program status wor | $\begin{array}{c c c c c c c c c c c c c c c c c c c $ | $\begin{array}{c c c c c c c c c c c c c c c c c c c $ | $\begin{array}{c c c c c c c c c c c c c c c c c c c $ |

(to be continued)

3-30 ■ 6427525 0094927 481 ■

# Figure 3-7 uPD75336 I/O Map (cont'd)

| Ad-          | Hardw              | vare Na | ne (Symi      | <b>bo</b> 1) | R/W | Man: | o. o:<br>ipula<br>Bits |           | Bit<br>Manipu-<br>lation     |                                    |  |
|--------------|--------------------|---------|---------------|--------------|-----|------|------------------------|-----------|------------------------------|------------------------------------|--|
| dress        | b3                 | b2      | b1            | ъО           |     | -    |                        | 8-<br>Bit | Address-                     |                                    |  |
| FB3H         | Process<br>registe |         | ck cont:<br>) | rol          | W   | -    | 0                      | -         |                              | *3                                 |  |
| <b>F</b> B4H | INTO mo            | ode reg | IMO)          | W            | -   | o    | -                      |           | Bit 2 is fixed to 0.         |                                    |  |
| FB5H         | INT1 mc            | de reg  | ister (       | IM1)         | W   | -    | 0                      |           |                              | Bits 3, 2 and 1<br>are fixed to 0. |  |
| <b>FB6</b> H | INT2 mo            | ode reg | IM2)          | W            | -   | 0    | -                      |           | Bits 3 and 2 are fixed to 0. |                                    |  |
| FB7H         | System<br>registe  |         | control<br>)  |              | W   | 0    | -                      |           | fmem.bit                     | Bits 2 and 1 are fixed to 0.       |  |
| FB8H         | IE4                | IRQ4    | IEBT          | IRQBT        | R/W | 0    | 0                      | -         | fmem.bit                     |                                    |  |
| FBAH         |                    |         | IEW           | IRQW         | R/W | 0    | 0                      |           |                              |                                    |  |
| FBCH         | IET1               | IRQT1   | IETO          | IRQTO        | R/W | 0    | 0                      | -         |                              |                                    |  |
| FBDH         | IECSI IRQCSI       |         |               |              | R/W | 0    | 0                      |           |                              |                                    |  |
| FBEH         | IE1 IRQ1 IEO IRQO  |         |               |              | R/W | ο    | 0                      | -         |                              |                                    |  |
| FBFH         | IE2 IRQ2           |         |               |              |     | 0    | 0                      |           |                              |                                    |  |

| FCOH        | Bit sequential buffer 0<br>(BSBO) | R/W | 0 | 0 | 0 | mem.bit<br>pmem.@L |  |
|-------------|-----------------------------------|-----|---|---|---|--------------------|--|
| FC1H        | Bit sequential buffer 1<br>(BSB1) | R/W | 0 | 0 |   |                    |  |
| FC2H        | Bit sequential buffer 2<br>(BSB2) | R/W | 0 | 0 | 0 |                    |  |
| <b>FC3H</b> | Bit sequential buffer 3<br>(BSB3) | R/W | 0 | 0 |   |                    |  |

(to be continued)

■ 6427525 0094928 318 **■** 

3-31

Figure 3-7 uPD75336 I/O Map (cont'd)

| Ad-   | ļ                                                    | vare Na                                              | me (Symi | pol)   | R/W             | Man | o. o<br>ipula<br>Bits | able      | Bit<br>Manipu-<br>lation | Remarks |
|-------|------------------------------------------------------|------------------------------------------------------|----------|--------|-----------------|-----|-----------------------|-----------|--------------------------|---------|
| dress | b3                                                   | b2                                                   | b1       | ъО     |                 | 1-  | 4-<br>Bit             | 8-<br>Bit | Address-<br>ing          |         |
| FDOH  | Clock (<br>(CLOM)                                    | output i                                             | mode reg | gister | W               | -   | 0                     | -         |                          |         |
| FD8H  | SOC<br>A/D cor<br>registe                            |                                                      |          | R/W    | △<br>(R)<br>(₩) | -   | 0<br>(W)              | mem.bit   | EOC (R)<br>SOC (W)*4     |         |
|       |                                                      |                                                      |          |        | -               | -   |                       |           |                          |         |
| FDAH  | SA regi                                              | ster (S                                              | SA)      |        | R               | -   | -                     | 0         |                          |         |
|       |                                                      |                                                      |          |        |                 | -   | -                     |           |                          |         |
| FDCH  |                                                      | Pull-up resistor specifica-<br>tion register group A |          |        |                 |     | -                     | 0         | ······                   |         |
|       | (POGA)                                               | L                                                    |          | -      | -               |     |                       |           |                          |         |
| FDEH  | Pull-up resistor specifica-<br>tion register group B |                                                      |          |        |                 | -   | -                     | 0         |                          |         |
|       | (POGB)                                               |                                                      | -        | -      |                 |     |                       |           |                          |         |

| FEOH   |                   | operat<br>er (CSI | ion mod | e      | R/W | -               | - | 0<br>(W) |         |                                                |
|--------|-------------------|-------------------|---------|--------|-----|-----------------|---|----------|---------|------------------------------------------------|
| FE1H   | CSIE              |                   | WUP     | 1      |     | △<br>(R)<br>(₩) | 0 | (#)      | mem.bit | Bits 3, 2 and 1<br>are bit-<br>manipulable. *4 |
| FE2H   | CMDD              |                   |         |        |     |                 |   |          | mem.bit | R/W depends on                                 |
| r Bell | SBI co            | ntrol r           | egister | (SBIC) | R/W | 0               | _ | _        | mem.Dit | the bit.                                       |
| FE3H   | BSYE              | ACKD              | ACKE    | ACKT   |     | 0               | - |          |         |                                                |
| FE4H   | Serial<br>(SIO)   | R/W               | -       | 1      | 0   |                 |   |          |         |                                                |
|        | (010)             |                   |         | -      | 1   |                 |   |          |         |                                                |
| FE6H   | Slave (SVA)       | W                 | -       | -      | 0   |                 |   |          |         |                                                |
|        |                   |                   | -       | -      |     |                 |   |          |         |                                                |
| FE8H   | Port mo<br>(PMGA) | W                 | -       | -      | 0   |                 |   |          |         |                                                |
| ×      | (IFIGA)           |                   |         | -      | -   |                 |   |          |         |                                                |

(to be continued)

■ 6427525 0094929 254 ■ 3-32

Figure 3-7 uPD75336 I/O Map (cont'd)

| Ad-   | Hardy  | ware Na                    | me (Sym | bol)      | R/W       |           |                 |   | Bit<br>Opera-<br>tion | Remarks |
|-------|--------|----------------------------|---------|-----------|-----------|-----------|-----------------|---|-----------------------|---------|
| dress | b3     |                            |         | 1-<br>Bit | 4-<br>Bit | 8-<br>Bit | Address-<br>ing |   |                       |         |
| FECH  |        | Port mode register group B |         |           |           |           | -               | 0 |                       |         |
|       | (PMGB) | (PMGB)                     |         |           |           |           | -               |   |                       |         |
| FEEH  |        | ode reg                    | ister g | roup C    | W         | -         | -               | 0 |                       |         |
|       | (PMGC) |                            |         |           |           | -         | -               |   |                       |         |

| FFOH       | Port 0 | (PORTO         | )   |     | R   | ο | 0 | -       | fmem.bit<br>pmem.@L |  |
|------------|--------|----------------|-----|-----|-----|---|---|---------|---------------------|--|
| FF1H       | Port 1 | (PORT1         |     | R   | 0   | 0 |   | P=0=+0= |                     |  |
| FF2H       | Port 2 | (PORT2         |     | R/W | 0   | 0 | - |         |                     |  |
| FF3H       | Port 3 | (PORT3         |     | R/W | 0   | 0 |   |         |                     |  |
| FF4H       | Port 4 |                | R/W | 0   | 0   | 0 |   |         |                     |  |
| FF5H       | Port 5 | Port 5 (PORT5) |     |     |     | 0 | 0 |         |                     |  |
| FF6H<br>*5 | KR3    | KR2            | KR1 | KRO | R/W | 0 | 0 | 0       |                     |  |
|            | Port 6 | (PORT6         | )   |     |     |   |   |         |                     |  |
| FF7H<br>*5 | KR7    | KR6            | KR5 | KR4 | R/W | ο | 0 |         |                     |  |
| C          | Port 7 |                |     |     |     |   |   |         |                     |  |
| FF8H       | Port 8 |                | R/W | 0   | 0   | - |   |         |                     |  |

■ 6427525 0094930 T76 ■ 3-33

- \*1: 1-bit manipulation is available only for R and 8-bit manipulation is available only for W.
- 2: TOE0, 1: Timer/event counter 0 or 1 output enable flag
- 3: Bits 2 and 3 may manipulate during STOP/HALT instruction execution.
- 4: 1-bit manipulation differ with R/W bit-wise.8-bit manipulation is available only for R.
- 5: KRO to KR7 may only be read. For 4-bit parallel input, specify them with PORT6 or PORT7.
- Remarks 1: IExxx is the interrupt enable flag.
  - 2: IRQxxx is the interrupt request flag.
  - 3: IME is the interrupt master enable flag.



#### CHAPTER 4. INTERNAL CPU FUNCTIONS

#### 4.1 PROGRAM COUNTER (PC) ... 14 BITS

This is a 14-bit binary counter to hold the program memory address information.

Figure 4-1 Program Counter Configuration

| PC13 | PC12 | PC11 | PC10 | PC9 | PC8 | PC7 | PC6 | PC5 | PC4 | PC3 | PC2 | PC1 | PCO | PC |
|------|------|------|------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|----|
|------|------|------|------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|----|

The program counter is normally incremented automatically in accordance with the number of bytes of an instruction each time the instruction is executed.

When a branch instruction (BR, BRCB) is executed, immediate data indicating the branch destination address and the register pair contents is loaded into all or some bits of the PC.

When a subroutine call instruction (CALL, CALLF) is executed or a vectored interrupt is generated, the PC contents (the return address which has already been incremented to fetch the next instruction) are saved into the stack memory (the data memory specified by the stack pointer) and then each jump destination address is loaded.

When a return instruction (RET, RETS, RETI) is executed, the stack memory contents are set in the PC.

When the RESET signal is generated, the least significant 6 bits at address 0000H of the program memory are set to PC13 to PC8 and the contents at address 0001H are set to PC7 to PC0 and the program is initialized. Therefore, the program can be started at any desired address.

> 4-1 ■ 6427525 0094932 849 ■

### 4.2 PROGRAM MEMORY (ROM) ... 16256 WORDS x 8 BITS

This is a mask programmable ROM, with a configuration of 16256 words x 8 bits, which is used to store programs, interrupt vector tables, GETI instruction reference tables, table data, etc.

The program memory is addressed by the program counter. Table data can be referred to by the table reference instruction (MOVT).

The branch address range available for branch and subroutine call instructions is shown in Figure 4-2. In addition to these instructions, the BR PCDE, BR PCXA instructions can branch to the address with only the least significant 8 bits of the PC changed.

The program memory addresses are 0000H to 3F7F and the following addresses are especially assigned. (All areas except 0000H and 0001H can be used as normal program memory.)

. Addresses 0000H to 0001H

Vector address table for writing the program start address for  $\overline{\text{RESET}}$  and the RBE and MBE set values. (Can be reset and started at any desired address.)

. Addresses 0002H to 000DH

Vector address table for writing the program start address to be set by each vectored interrupt and the RBE and MBE set values. (Interrupt servicing can be started at any desired address.)

. Addresses 0020H to 007FH

Table area to be referred to by GETI instruction.\*

\*: The GETI instruction is an instruction which implements any 2-byte/3-byte instruction with one byte. It enables the number of program bytes to be decreased.

# 🖬 6427525 0094934 611 페 4-3

Figure 4-2 Program Memory Map



Remarks: In all cases other than those listed above, a branch to the address with only the least significant 8 bits of the PC changed is enabled by BR PCDE and BR PCXA instructions. ■ 6427525 0094935 558 ■ 4-4

### 4.3 DATA MEMORY (RAM) ... 768 WORDS x 4 BITS

The data memory consists of a data area and a peripheral hardware area as shown in Figure 4-3.

The data memory has a bank configuration, each bank consisting of 256 words x 4 bits. The following memory banks are available:

- . Memory banks 0, 1 and 2 (data area)
- . Memory bank 15 (peripheral hardware area)



Figure 4-3 Data Memory Map



#### (1) Data area

The uPD75336 data area has a static RAM (768 words x 4 bits) configuration. The data area is used to store processing data and is manipulated by memory manipulation instructions.

The static RAM is mapped in memory banks 0, 1 and 2 (256 words x 4 bits each). Bank 0 is intended for mapping as a data area. It can also be used as a general register area (000H to 007H) and a stack area (000H to 0FFH). Bank 1 can also be used as a data area and a display data memory area. Bank 2 can only be used as a data area.

One address of the static RAM consists of 4 bits. However, the static RAM can be manipulated in 8-bit units by 8-bit memory manipulation instructions or bit-wise units by bit manipulation instructions. In the case of 8-bit manipulation instructions, specify an even address.

. General register area

This area can be manipulated by general register manipulation instructions or memory manipulation instructions.

There are 4-bank registers, each bank consisting of eight 4-bit registers. The section which is not used for general registers can be used as a data area or a stack area.

. Stack area

#### . Display data memory area

The area which is not used for display purposes can be used as a normal data area. This area can be manipulated bit-wise or in 4-bit units using memory manipulation instructions. It cannot be manipulated in 8-bit units (refer to Figure 4-4 "Display Data Memory Configuration" for details).

(2) Peripheral hardware area

This area is mapped onto addresses F80H to FFFH of memory bank 15. As is the case with the static RAM, the peripheral hardware area is manipulated by memory manipulation instructions. It should be noted that the peripheral hardware has different manipulable bit units for each address. The addresses for which no peripheral hardware has been allocated cannot be accessed because no data memory is incorporated (refer to Figure 3-7 "uPD75336 I/O Map").

For the procedure for using a specific area of data memory, refer to the following sections.

- . General register area ... Section 4.4 "General Register"
- . Stack memory area ... Section 4.6 "Stack Pointer"
- . Display data memory ... Section 5.7.5 "Display Data Memory"
- . Peripheral hardware ... Chapter 5. "Peripheral Hardware Functions"

■ 6427525 0094938 267 ■ 4-7 The memory bank is specified by the 4-bit memory bank select register (MBS) (MBS = 0, 1, 15) when bank specification is enabled by the memory bank enable flag (MBE) (MBE = 1). If bank specification is disabled (MBS = 0), bank 0 or 15 is automatically specified according to the current addressing mode. Addresses in the bank are set by 8-bit immediate data or register pairs.

For details of memory bank selection and addressing, refer to Section 3.1 "Data Memory Bank Configuration and Addressing Mode".

When reset, the data memory is indeterminate. Thus, be sure to initialize it to "0" at the beginning of the program (RAM clear). Otherwise, bugs may be generated.



Example: Clear the RAM at addresses 000H to 2FFH.

|        | STE1 | RBE                                   |
|--------|------|---------------------------------------|
|        | SEL  | RBO                                   |
|        | SET1 | MBE                                   |
|        | SEL  | мво                                   |
|        | MOV  | ха, #ООН                              |
|        | MOV  | HL, #04H                              |
| RAMCO: | MOV  | <pre>@HL, A ; 04H to FFH clear*</pre> |
|        | INCS | HL ; HL $+$ HL $+$ 1                  |
|        | BR   | RAMCO                                 |
|        | SEL  | MB1                                   |
| RAMC1: | MOV  | @HL, A ; 100H to 1FFH clear           |
|        | INCS | HL ; HL $\leftarrow$ HL + 1           |
|        | BR   | RAMC1                                 |
| RAMC2: | MOV  | @HL, A ; 200H to 2FFH clear           |
|        | INCS | HL ; HL + HL + 1                      |
|        | BR   | RAMC2                                 |
|        |      |                                       |

\*: Do not clear data memory 000H to 003H because it is used as general registers XA and HL.

### **6**427525 0094940 915 **m** 4-9

Figure 4-4 Display Data Memory Configuration



The display data memory is manipulated bit-wise or in 4-bit units.

NOTE: The display data memory cannot be manipulated in 8-bit units.

#### 6427525 0094941 851 📟 4-10

Example: Clear 1ECH to 1FFH display data memory.

|       | SET1 | MBE                                     |
|-------|------|-----------------------------------------|
|       | SEL  | MB1                                     |
|       | MOV  | HL. #OECH                               |
|       | MOV  | А, #ООН                                 |
| LOOP: | MOV  | <pre>@HL. A ; Display data memory</pre> |
|       |      | is cleared to "0"                       |
|       |      | in 4-bit units at                       |
|       |      | one time.                               |
|       | INCS | HL                                      |
|       |      |                                         |

BR LOOP

■ 6427525 0094942 798 ■ 4-11

# 4.4 GENERAL REGISTER ... 8 x 4 BITS x 4 BANKS

The general registers are mapped onto special addresses of the data memory. There are 4-banks of registers, each bank consisting of eight 4-bit registers (B, C, D, E, H, L, X, A).

The register bank (RB) which becomes valid for instruction execution is given as

 $RB = RBE \cdot RBS$  (RBS = 0 to 3)

Each general register is manipulated as a 4-bit unit. BC, DE, HL and XA form register pairs and are used for 8bit manipulation. In addition to DE and HL, DL also makes up a pair and these three pairs can be used as data pointers.

In 8-bit unit manipulation, the register pairs of the register bank with register bank (RB) bit 0 inverted (0  $\leftrightarrow$  1, 2  $\leftrightarrow$  3) can be used as BC', DE', HL' and XA' in addition to BC, DE, HL and XA (refer to Section 3.2 "General Register Bank Configuration").

The general register area can be accessed by address specification as normal RAM whether or not it is used as registers.



#### Figure 4-5 General

Register Configuration

#### Configuration





1 Bank

# ■ 6427525 0094944 560 **■** 4-13

#### 4.5 ACCUMULATOR

In the uPD75336, the A register and XA register pair function as an accumulator. 4-bit data processing instructions are executed mainly by the A register and 8bit data processing instructions are executed mainly by the XA register pair.

In execution of a bit manipulation instruction, the carry flag (CY) functions as a bit accumulator.







#### 4.6 STACK POINTER (SP) ... 8 BITS

In the uPD75336, the static RAM is used as a stack memory (LIFO type) and the 8-bit register which holds the start address information in the stack area is the stack pointer (SP).

The stack area is located at addresses 000H to OFFH of memory bank 0 irrespective of MBE and MBS settings.

The SP is decremented before a data write (save) to the stack memory and incremented after a data read (restore) from the stack memory.

The data saved/restored by each stack operation is shown in Figures 4-9 and 4-10.

The SP is mapped in the data memory space and can be read and written by 8-bit memory manipulation instructions.

"O" is always written to SPO.

It is recommended to set the SP initial value to OOH and use the SP from the most significant address (OFFH) of data memory bank 0 as a stack area.

When the  $\overline{\text{RESET}}$  signal is generated, SP contents become indeterminate. Thus, be sure to initialize the SP at the beginning of the program.

Example: SP initialization

SEL MB15 ; or CLR1 MBE MOV XA, #OOH MOV SP, XA ; SP + OOH

> ■ 6427525 0094946 333 ■ 4-15

#### Figure 4-8 Stack Pointer Configuration





PUSH Instruction

CALL and CALLF Instructions

Interrupt





POP Instruction

SP ~ Lower Half of Register Pair Upper Half of Register Pair SP+1 SP+2 RET and RETS Instructions



**RETI Instruction** 

|       | Stack             |  |
|-------|-------------------|--|
| sp,⇒  | PC11-PC8          |  |
| SP+ 1 | MBE REE PC13 PC12 |  |
| SP+ 2 | PC3-FC0           |  |
| SP+3  | PC7-PC4           |  |
| SP+4  | ISTI ISTO MBE RBE |  |
| SP+5  | CY SK2 SK1 SK0    |  |
| \$₽+6 |                   |  |
|       |                   |  |

■ 6427525 0094947 27T ■ 4-16

#### 4.7 PROGRAM STATUS WORD (PSW) ... 8 BITS

The program status word (PSW) consists of various types of flags closely related to processor operation.

The PSW is mapped onto addresses FBOH and FB1H in the data memory space and the 4 bits at address FBOH can be manipulated by a memory manipulation instruction. Normal data memory manipulation instructions cannot be used on address FB1H.

Figure 4-11 Program Status Word Configuration



Part or all of the PSW is saved/restored to the stack memory when a subroutine call instruction or hardware interrupt is executed. PSW flags which are manipulated for stack operation are shown in Table 4-1.

Table 4-1 PSW Flags Saved/Restored in Stack Operation

|         |                                            | Flag Saved/Restored   |
|---------|--------------------------------------------|-----------------------|
| Save    | During CALL/CALLF<br>instruction execution | MBE and RBE saved     |
|         | Upon hardware interruption                 | All PSW bits saved    |
| Restore | During RET/RETS<br>instruction execution   | MBE and RBE restored  |
|         | During RETI instruction<br>execution       | All PSW bits restored |

4-17 ■ 6427525 0094948 106 ■

#### (1) Carry flag (CY)

The carry flag is a 1-bit flag used to store overflow or underflow generation information when a carry operation instruction (ADDC, SUBC) is executed.

It has a bit accumulator function for executing Boolean algebraic operations with the data memory specified by the bit address and storing the result.

Carry flag manipulation is carried out using a special instruction irrespective of other PSW bits.

When the RESET signal is generated, the carry flag becomes indeterminate.

|                                                      | Instruction<br>(Mnemonic)                                     | Carry Flag Operation and<br>Processing                                                         |
|------------------------------------------------------|---------------------------------------------------------------|------------------------------------------------------------------------------------------------|
| Carry flag<br>manipulation<br>special<br>instruction | SET1 CY<br>CLR1 CY<br>NOT1 CY<br>SKT CY                       | CY set to "1"<br>CY cleared to "0"<br>CY contents inverted<br>Skip if CY contents is "1"       |
| Bit transfer<br>instruction                          | MOV1 <u>*1</u> CY<br>MOV1 CY, <u>*1</u>                       | CY contents transferred to the<br>specified bit<br>Specified bit contents<br>transferred to CY |
| Bit Boolean<br>instruction                           | AND1 CY, <b>*1</b><br>OR1 CY, <b>*1</b><br>XOR1 CY, <b>*1</b> | Specified bit contents ANDed/<br>ORed/XORed with CY contents and<br>the results set in CY      |
| Interrupt<br>servicing                               | During interrupt<br>execution                                 | Parallel save of other PSW bits<br>and 8 bits to the stack memory                              |
|                                                      | RETI                                                          | Restore from the stack memory<br>in parallel with other PSW bits                               |

Table 4-2 Carry Flag Manipulation Instructions

■ 6427525 0094949 042 ■ 4-18 Remarks: [\*1] indicates the following bit addressing operations.

- . fmem.bit
- . pmem.@L
- . @H+mem.bit

Example: AND bit 3 at address 3FH with P33 and generate the result to P50.

MOV H, #3H ; set the most significant 4-bit address in the H register MOV1 CY, @H+OFH.3; CY + 3FH bit 3 AND1 CY, PORT3.3 ; CY + CY A P33 MOV1 PORT5.0, CY ; P50 + CY

(2) Skip flags (SK2, SK1, SK0)

These skip flags are used to store the skipped state and are automatically set/reset when the CPU executes an instruction.

The user cannot directly manipulate the skip flags as operands.

(3) Interrupt status flags (IST1, IST0)

The interrupt status flags are 2-bit flags used to store the status of the processing currently being executed.

■ 6427525 0094950 864 ■ 4-19

Table 4-3 Interrupt Status Flag Specification Contents

| ISTI | IST0 | Status of<br>Processing<br>being<br>Executed | Processing Contents and<br>Interrupt Control                                 |
|------|------|----------------------------------------------|------------------------------------------------------------------------------|
| 0    | 0    | Status O                                     | Normal program being executed.<br>All interrupts acknowledgeable             |
| 0    | 1    | Status 1                                     | Low or high interrupt being executed.<br>Only high interrupt acknowledgeable |
| 1    | 0    | Status 2                                     | High interrupt being executed.<br>All interrupts non-acknowledgeable         |
| 1    | 1    |                                              | Setting prohibited                                                           |

The interrupt priority control circuit (see Figure 6-1) identifies the flag contents and executes multiple interrupt control.

If an interrupt is acknowledged, the IST1 and IST0 contents are saved to the stack memory as part of the PSW and are automatically changed to the status higher by one level and the values prior to interruption by the RETI instruction are restored.

The interrupt status flag can be manipulated by a memory manipulation instruction and the processing status being executed can be changed by program control.

NOTE: Before manipulating the interrupt status flag, be sure to disable interruption by executing a DI instruction, and then enable interruption by executing an EI instruction after the manipulation.

■ 6427525 0094951 7TO ■ 4-20 (4) Memory bank enable flag (MBE)

This is a 1-bit flag used to specify the mode to generate the address information of the most significant 4 bits of the 12 bits of the data memory address.

The MBE can be set/reset at any time by a bit manipulation instruction irrespective of the memory bank setting.

When this flag is set to "1", the data memory address space is expanded depending on the memory bank select register (MBS) contents and the entire data memory space becomes addressable.

When this flag is reset to "0", the data memory address space is fixed irrespective of the MBS setting (see Figure 3-2).

When the  $\overline{\text{RESET}}$  signal is generated, the bit 7 contents at address 0 of the program memory are set and the MBE flag is automatically initialized.

In vectored interrupt servicing, the bit 7 contents of the corresponding vector address table are set and the MBE status in interrupt servicing is automatically set.

Normally, set MBE = 0 for interrupt servicing and use the static RAM of memory bank 0.

(5) Register bank enable flag (RBE)

This is a 1-bit flag used to determine whether or not the general register bank configuration should be expanded.

> ■ 6427525 0094952 637 ■ 4-21

RBE can be set/reset at any time by a bit manipulation instruction irrespective of the memory bank setting.

When this flag is set to "1", one general register can be selected from register banks 0 to 3 depending on the register bank select register (RBS) contents.

When this flag is reset to "0", register bank 0 is selected as a general register irrespective of the register bank select register (RBS) contents.

When the  $\overline{\text{RESET}}$  signal is generated, the bit 6 contents at address 0 of the program memory are set and the RBE flag is automatically initialized.

When a vectored interrupt is generated, the bit 6 contents of the corresponding vector address table are set and the RBE status in interrupt servicing is automatically set. Normally, set RBE = 0 for interrupt servicing. Use register bank 0 for 4-bit operations and register banks 0 and 1 for 8-bit operations.

#### ■ 6427525 0094953 573 ■ 4-22

#### 4.8 BANK SELECT REGISTER (BS)

The bank select register (BS) consists of a register bank select register (RBS) and a memory bank select register (MBS). RBS and MBS are used to specify the register bank and the memory bank to be used, respectively.

RBS and MBS are set by the SEL RBn and SEL MBn instructions, respectively.

BS can be saved/restored to the stack area as an 8-bit unit by the PUSH BS/POP BS instruction.

Figure 4-12 Bank Select Register Configuration

| ł    |      |      |      |   |    |      |      | Symbol |
|------|------|------|------|---|----|------|------|--------|
| •    | — м  | BS   |      | - | RI | 3S — |      |        |
| MBS3 | MBS2 | MBS1 | MBSO | 0 | 0  | RBS1 | RBSO | BS     |

(1) Memory bank select register (MBS)

The memory bank select register is a 4-bit register used to store the most significant 4-bit address information of the data memory address (12 bits); the memory bank to be accessed is specified by the MBS contents. In the uPD75336, only banks 0, 1, 2 and 15 can be specified.

MBS is set by the SEL MBn instruction (n = 0, 1, 2, 15).

The address range for MBE and MBS setting is shown in Figure 3-2.

When the  $\overline{\text{RESET}}$  signal is generated, MBS is initialized to "0".

■ 6427525 0094954 40T ■ 4-23 (2) Register bank select register (RBS)

The register bank select register is used to specify the register bank for use as general registers and can set banks 0 to 3.

RBS is set by the SEL RBn instruction (n = 0 to 3).

When the  $\overline{\text{RESET}}$  signal is generated, RBS is initialized to "0".

#### ■ 6427525 0094955 346 ■ 4-24

This Material Copyrighted By Its Respective Manufacturer

~ A%

### CHAPTER 5. PERIPHERAL HARDWARE FUNCTIONS

#### 5.1 DIGITAL INPUT/OUTPUT PORTS

The uPD75336 employs memory mapped I/O and all input/ output ports are mapped onto the data memory space.

Bit 0 at 1F8H to 1FFH functions as an output latch for port outputs 0 to 7(BP0 to BP7).

BPO to BP7 are switched in 4-bit units by bits 6 and 7 of the display mode register (LCDM) between segment output and bit port output (refer to Figure 5-75 "Display Mode Register Format").

Bits at 1F8H to 1FFH which are not used as a bit port output latch can be used as display memory or static RAM. Each address can be operated bit-wise or in 4-bit units. 8-bit unit operation is not possible.



Figure 5-1 Digital Port Data Memory Addresses

| Address       | 3        | 2   | 1   | 0   |        |
|---------------|----------|-----|-----|-----|--------|
| FFOH          | P03      | P02 | P01 | POO | PORTO  |
| FF1H          | P13      | P12 | P11 | P10 | PORT 1 |
| FF2H          | P23      | P22 | P21 | P20 | PORT 2 |
| FFЗH          | P33      | P32 | P31 | P30 | PORT 3 |
| FF4H          | P43      | P42 | P41 | P40 | PORT 4 |
| FF5H          | P53      | P52 | P51 | P50 | PORT 5 |
| FF6H          | P63      | P62 | P61 | P60 | PORT 6 |
| FF7H          | P73      | P72 | P71 | P70 | PORT 7 |
| FF8H          | P83      | P82 | P81 | P80 | PORT 8 |
|               |          |     | [   |     | -      |
| 1F8H          |          |     |     | BPO |        |
| 1F9H          | <u> </u> |     |     | BP1 |        |
| 1FAH          |          |     |     | BP2 |        |
| 1 <b>F</b> BH |          |     |     | BP3 |        |
| 1FCH          |          | _   |     | BP4 |        |
| 1FDH          |          |     |     | BP5 |        |
| 1FEH          |          | —   |     | BP6 |        |
| 1FFH          |          |     |     | BP7 |        |

Remarks: Ports marked with --- can be used as data memory or display memory.

Input/output port operation instructions are listed in Table 5-1. As ports 4 to 7, a variety of control operations ranging from 4-bit input/output to 8-bit input/ output and bit manipulations can be carried out.

BPO to BP7 are bit-wise output ports.

#### 🔳 6427525 0094957 ll9 📕 5-2

Example 1: Test P13 status and generate different values at PORT4 and PORT5 depending on the test results.

> SKT PORT1,3 ; Skip if PORT1 bit 3 is 1. MOV XA, #18H ; XA + 18H MOV XA, #14H ; XA + 14H SEL MB15 ; Or CLR1 MBE OUT PORT4, XA; Ports 5 and 4 + XA2: SET1 PORT4.@L; Bit specified by L register

at ports 4 to 7 is set to "1".

3: Generate 1 to BPO.

| SET1 | MBE  |                             |
|------|------|-----------------------------|
| SEL  | MB1; | Memory bank 1 is selected . |
| SET1 | BPO; | BPO + 1                     |

■ 6427525 0094958 055 ■ 5-3

# 5.1.1 TYPES, FEATURES AND CONFIGURATIONS OF DIGITAL INPUT/OUTPUT PORTS

Table 5-1 gives a list of digital input/output ports.

Figures 5-2 to 5-6 show port configurations.

Table 5-1 Types and Features of Digital I/O Ports

| Port             | Function                  | Operation/Feature                                                                                                        | Remarks                                                               |
|------------------|---------------------------|--------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------|
| (Symbol)         |                           |                                                                                                                          | Remains                                                               |
| PORTO            | 4-bit input               | Reading or testing<br>possible irrespective<br>of dual-function pin<br>operating mode                                    | Also serve <u>s as</u> a pin<br>for INT4, SCK, SO/<br>SBO and SI/SB1. |
| PORT1            |                           | operating mode                                                                                                           | Also serves as a pin<br>for INTO to INT2 and<br>TIO.                  |
| PORT3*           | 4-bit<br>input/<br>output | Settable bit-wise to<br>the input or output<br>mode                                                                      | Also serves as a pin<br>for LCDCL and SYNC.                           |
| PORT6            | Cutput                    |                                                                                                                          | Also serves as a pin<br>for KRO to KR3.                               |
| PORT2            |                           | Settable in 4-bit<br>units to the input or<br>output mode. Ports 6<br>and 7 can input/output                             | Also serves as a pin<br>for PTOO, PTO1, PCL<br>and BUZ.               |
| PORT7            |                           | 8-bit data as a pair.                                                                                                    | Also serves as a pin<br>for KR4 to KR7.                               |
| PORT8            |                           |                                                                                                                          | Also serves as a pin<br>for TI1, AN6 and<br>AN7.                      |
| PORT4*<br>PORT5* | drain with                | Settable in 4-bit<br>units to the input or<br>output mode.<br>Ports 4 and 5 can<br>input/output 8-bit<br>data as a pair. | On-chip pull-up<br>resistor specifiable<br>bit-wise by mask<br>option |
| BPO to<br>BP7    | 1-bit<br>output           | Bit-wise data output.<br>Switchable with LCD<br>drive segment outputs<br>S24 to S31 by<br>software.                      |                                                                       |

5-4 • 6427525 0094959 T91 •

\*: Can directly drive LEDs.

P10 also serves as an external vectored interrupt input pin. It is an input with a noise eliminator (refer to Section 6.3 "Interrupt Control Circuit Hardware" for details).

BPO to BP7 also serve as LCD drive segment outputs (S24 to S31) and are switched in 4- or 8-bit units by bits 6 and 7 of the display mode register (LCDM). BPO to BP7 are bitwise output ports which generate bit 0 data at addresses 1F8H to 1FFH of the display data memory (refer to Section 5.7.5 "Display Data Memory").

BPO to BP7 have much smaller drive capabilities than other ports. Thus, they should be used to drive a CMOS load.

When  $\overline{\text{RESET}}$  signal is generated, the output latch of ports 2 to 8 is cleared, the output buffer is turned OFF and the input mode is set. Refer to Table 2-1 for the BPO to BP7 statuses in  $\overline{\text{RESET}}$  input.

6427525 0094960 703 🖬 5-5











Figure 5-4 Configurations of Ports 2 and 7









## ■ 6427525 0094964 359 ■ 5-9

.

.

#### 5.1.2 INPUT/OUTPUT MODE SETTING

The input/output mode of each input/output port is set by the port mode register as shown in Figure 5-7 on the next page. Input/output can be specified bit-wise for ports 3 and 6 by port mode register group A (PMGA). Input/output is specified in 4-bit units by the port mode register group B (PMGB) for ports 2, 4, 5 and 7 and by port mode register group (PMGC) for port 8.

When the bit of the corresponding port mode register is "0" or "1", each port functions as an input or output port, respectively.

When the output mode is selected by port mode register setting, the output latch contents are simultaneously output to the output pin. Thus, it is necessary to rewrite the output latch contents to the necessary value before setting the output mode.

Port mode register groups A, B and C each are set by an 8-bit memory manipulation instruction.

When the RESET signal is generated, all bits of each port mode register are cleared to "0". Thus, the output buffer is turned OFF and all ports are set to the input mode.

Example: Use P30, P31, P62 and P63 as input pins and P32, P33, P60 and P61 as output pins.

> CLR1 MBE ; Or SEL MB15 MOV XA, #3CH MOV PMGA, XA

6427525 0094965 295 **5**-10

Figure 5-7 Port Mode Register Formats



# 5.1.3 DIGITAL INPUT/OUTPUT PORT OPERATION INSTRUCTIONS

The on-chip input/output ports of the uPD75336 are all mapped onto the data memory space, and thus, all data memory manipulation instructions can be used. Table 5-2 lists the data memory manipulation instructions apparently effective for input/output pin operations and their application ranges.

(1) Bit manipulation instructions

Specific address bit direct addressing (fmem.bit) and specific address bit register indirect addressing (pmem.@L) can be used for digital input/output ports PORTO to PORT8. Thus, port bit manipulation can be carried out freely irrespective of MBE and MBS settings.

Example: OR P50 with P41 and generate the result to P61.

SET1 CY ; CY + 1
AND1 CY, PORT5.0; CY + CY ^ P50
OR1 CY, PORT4.1; CY + CY \/ P41
SKT CY
BR CLRP
SET1 PORT6.1 ; P61 + 1
:
:
CLRP: CLR1 PORT6.1 ; P61 + 0

(2) 4-bit manipulation instructions

In addition to IN/OUT instructions, all 4-bit memory manipulation instructions including MOV, XCH, ADDS and INCS can be used. It is necessary to select memory bank 15 prior to instruction execution.

> ■ 6427525 0094967 068 ■ 5-12

Example 1: Generate accumulator contents to port 3.

SEL MB15 ; Or CLR1 MBE OUT PORT3, A

2: Add the accumulator value to the data output to port 5 and generate the sum.

SET1 MBE SEL MB15 MOV HL, #PORT5 ADDS A, @HL ; A + A + PORT5 NOP MOV @HL, A ; PORT5 + A

3: Check if port 4 data is greater than the accumulator value.

| SET1 | MBE        |   |           |
|------|------------|---|-----------|
| SEL  | MB15       |   |           |
| MOV  | HL, #PORT4 | L |           |
| SUBS | A, @HL     | ; | A < PORT4 |
| BR   | NO         | ; | NO        |
|      |            | : | YES       |

(3) 8-bit manipulation instructions

IN/OUT, MOV, XCH and SKE instructions can be used for ports 4, 5, 6 and 7 which can perform 8-bit manipulation. As is the case with 4-bit manipulation, it is necessary to preselect memory bank 15.

> ■ 6427525 0094968 TT4 ■ 5-13

Example: Generate BC register pair data to the output port specified by 8-bit data input from ports 4 and 5.

SET1 MBE SEL MB15 IN XA, PORT4; XA + Ports 5 and 4 MOV HL, XA ; HL + XA MOV XA, BC ; XA + BC MOV @HL, XA ; Port (L) + XA

Table 5-2 Table of Input/Output Pin Operation Instructions

| PORT                 | PORT<br>0 | PORT<br>1 | PORT<br>2   | PORT<br>3 | PORT<br>4 | PORT<br>5 | PORT<br>6 | PORT<br>7 | PORT<br>8 | Bit Port<br>O to 7   |
|----------------------|-----------|-----------|-------------|-----------|-----------|-----------|-----------|-----------|-----------|----------------------|
| IN A, PORTn *1       |           |           | <b>.</b>    | ·····     | 0         | <u>.</u>  | ·         | <b></b>   | I         | MOV A, mem<br>*3, *4 |
| IN XA, PORTn *1      |           | _         | _           |           | c         | 5         | c         | )         | -         |                      |
| OUT PORTn, A *1      | -         | -         |             |           |           | 0         |           |           |           | MOV mem, A<br>*3, *4 |
| OUT PORTn, XA *1     | _         | _         | -           | -         | c         | þ         | Ċ         | >         | -         |                      |
| SET1 PORTn.bit       | -         | -         |             |           |           | 0         |           |           |           | SET1 BPn *3          |
| SET1 PORTn.@L *2     | -         | -         |             |           |           | 0         |           | <u>.</u>  |           |                      |
| CLR1 PORTn.bit       | -         | -         |             |           |           | 0         |           |           |           | CLR1 BPn *3          |
| CLR1 PORTn.@L *2     | -         | -         |             |           |           | 0         |           |           |           |                      |
| SKT PORTn.bit        |           |           |             |           | 0         |           |           |           |           | SKT BPn *3           |
| SKT PORTn.@L *2      |           |           |             |           | 0         |           |           |           |           |                      |
| SKF PORTn.bit        |           |           |             |           | 0         |           |           |           |           | SKF BPn *3           |
| SKF PORTn.@L *2      |           |           | <del></del> |           | 0         |           | ·         |           |           |                      |
| MOV1 CY, PORTn.bit   |           |           |             |           | 0         |           |           |           |           |                      |
| MOV1 CY, PORTn.@L *2 |           |           |             |           | 0         | ,         |           | _         |           |                      |
| MOV1 PORTn.bit, CY   | -         | -         |             |           |           | 0         |           |           |           |                      |

(to be continued)

5-14 5-14 🖬 6427525 0094969 930 🎟

| PORT                 | PORT<br>O | PORT<br>1 | PORT<br>2 | port<br>3 | PORT<br>4 | PORT<br>5 | PORT<br>6 | PORT<br>7 | PORT<br>8 | Bit Port<br>O to 7             |
|----------------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|--------------------------------|
| MOV1 PORTn.@L, CY *2 | -         | -         |           |           |           | 0         |           |           |           |                                |
| AND1 CY, PORTn.bit   |           | <u></u>   |           |           | 0         |           |           |           |           | AND1 CY,<br>@H + BPn<br>*3, *5 |
| AND1 CY, PORTn.@L *2 |           |           |           |           | 0         |           |           |           |           |                                |
| OR1 CY, PORTn.bit    |           |           |           |           | 0         |           |           |           |           | OR1 CY,<br>@H + BPn<br>*3, *5  |
| OR1 CY, PORTn.@L *2  |           |           |           |           | 0         |           |           |           |           | ·                              |
| XOR1 CY, PORTn.bit   |           |           |           |           | 0         |           |           |           |           | XOR1 CY,<br>@H + BPn<br>*3, *5 |
| XOR1 CY, PORTn.@L *2 |           |           |           |           | 0         |           |           | -         |           |                                |

# Table 5-2 Table of Input/Output Pin Operation Instructions (cont'd)

- \*1: Preset MBE = 0 or (MBE = 1, MBS = 15) before execution.
  - 2: Specify the least significant 2 bits of the address and the bit address indirectly using the L register.
  - 3: Preset (MBE = 1, MBS = 1) before execution.
  - 4: Bit n of accumulator A corresponds to BPn.
  - 5: Write FH to H register.

#### 6427525 0094970 652 M 5-15

#### 5.1.4 DIGITAL INPUT/OUTPUT PORT OPERATIONS

When a data memory manipulation instruction is executed for a digital input/output port, port and pin operations differ depending on the input/output mode setting (refer to Table 5-3).

As is clear from the input/output port configuration, this is because the data fetched into the internal bus becomes individual pin data in the input mode and output latch data in the output mode.

(1) Operations in the input mode

- Pin data is input when a test instruction such as the SKT instruction, a bit input instruction by MOV1 instruction or an instruction which fetches port data into the internal bus in 4- or 8-bit units (IN, OUT, operation and compare instructions) is executed.
- Accumulator data is latched into the output latch when an instruction which transfers accumulator contents to the port in 4- or 8-bit units (OUT and MOV instructions) is executed. The output buffer remains OFF.
- . When the XCH instruction is executed, individual pin data is input to the accumulator and accumulator data is latched into the output latch. The output buffer remains OFF.
- . When the INCS instruction is executed, individual pin data (4 bits) plus one is latched into the output latch. The output buffer remains OFF.

6427525 0094971 599 MM 5-16

- . When an instruction, such as the SET1, CLR1, MOV1 or SKTCLR instruction, which rewrites the data memory bit by bit is executed, the output latch of the specified bit can be rewritten as specified by the instruction. In this case, the output latch contents of the other bits become indeterminate.
- (2) Operations in the output mode
  - . Output latch contents are input when a test instruction, a bit input instruction or an instruction which fetches port data into the internal bus in 4- or 8-bit units is executed.
  - . When an instruction to transfer accumulator contents in 4- or 8-bit units is executed, output latch data is rewritten and is simultaneously output from the pin.
  - . When the XCH instruction is executed, output latch contents are transferred to the accumulator, and the accumulator contents are latched into the output latch and are output from the pin.
  - . When the INCS instruction is executed, output latch contents plus one are latched into the output latch and are output from the pin.
  - . When a bit output instruction is executed, the bit of the specified output latch is rewritten and is output from the pin.

■ 6427525 0094972 425 ■ 5-17

# Table 5-3 Input/Output Port Operations

| Instr | uction to | Port and Pir          | n Operations          |  |  |
|-------|-----------|-----------------------|-----------------------|--|--|
| be E  | Executed  | Input Mode            | Output Mode           |  |  |
| SKT   | *         | Pin data test         | Output latch data     |  |  |
| SKF   | *         |                       | test                  |  |  |
| MOV1  | CY, 🗶     | Pin data transfer to  | Output latch data     |  |  |
|       |           | СҮ                    | transfer to CY        |  |  |
| AND1  | CY, 📩     | Operation between pin | Operation between     |  |  |
| OR1   | CY, 💌     | data and CY           | output latch data and |  |  |
| XOR1  | CY, 💌     |                       | СҮ                    |  |  |
| IN    | A, PORTn  | Pin data transfer to  | Output latch data     |  |  |
| IN    | XA, PORTn | accumulator           | transfer to           |  |  |
| MOV   | A, @HL    |                       | accumulator           |  |  |
| MOV   | XA, @HL   |                       |                       |  |  |
| ADDS  | A, @HL    | Operation between pin | Operation between     |  |  |
| ADDC  | A, @HL    | data and accumulator  | output latch data and |  |  |
| SUBS  | A, QHL    |                       | accumulator           |  |  |
| SUBC  | A, @HL    |                       |                       |  |  |
| AND   | A, QHL    |                       |                       |  |  |
| OR    | A, QHL    | •                     |                       |  |  |
| XOR   | A, @HL    |                       |                       |  |  |
| SKE   | A, @HL    | Pin data and          | Output latch data and |  |  |
| SKE   | XA, @HL   | accumulator compare   | accumulator compare   |  |  |
| OUT   | PORTn, A  | Accumulator data      | Accumulator data      |  |  |
| OUT   | PORTn, XA | transfer to output    | transfer to output    |  |  |
| MOV   | @HL, A    | latch (with output    | latch and output from |  |  |
| MOV   | QHL, XA   | buffer set to OFF)    | pin                   |  |  |

(to be continued)

■ 6427525 0094973 361 ■ 5-18

#### Table 5-3 Input/Output Port Operations (cont'd)

| Instruction to                 |                                            | Port and Pin                                                                                                                            | Operations                                               |
|--------------------------------|--------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------|
| be E                           | xecuted                                    | Input Mode                                                                                                                              | Output Mode                                              |
| XCH<br>XCH<br>XCH<br>XCH       | A, PORTn<br>XA, PORTn<br>A, @HL<br>XA, @HL | Pin data transfer to<br>accumulator and<br>accumulator data<br>transfer to output<br>latch (with output<br>buffer set to OFF)           | Data exchange between<br>output latch and<br>accumulator |
| INCS<br>INCS                   | PORTn<br>@HL                               | Latch of pin data plus<br>one to output latch                                                                                           | Output latch contents plus one                           |
| SET1<br>CLR1<br>MOV1<br>SKTCLR | *<br>*<br>*, cy<br>*                       | Specified bit output<br>latch rewritten as<br>specified by instruc-<br>tion but all other bit<br>output latches<br>remain indeterminate | Output pin status<br>change by instruction               |

\*: Indicates two addressing modes, PORTn.bit and PORTn.@L.

#### 5.1.5 ON-CHIP PULL-UP RESISTOR

A pull-up resistor can be incorporated in each port of the uPD75336 (except P00 and BP0 to BP7). Pull-up resistor incorporation in the pin can be specified by software or mask option.

Pull-up register incorporation is specified by pull-up register specification register group A(POGA) and B(POGB).

On-chip pull-up resistor specification for ports 3 and 6 is only valid for pins specified for the input mode. The pins specified for the output mode have no on-chip pull-up resistors irrespective of POGA setting.

#### 5-19 6427525 0094974 2TA

Figure 5-8 Pull-Up Resistor Specification Register Format



|   | Specification Contents             |  |  |  |  |  |  |
|---|------------------------------------|--|--|--|--|--|--|
| 0 | Pull-up resistor not incorporated. |  |  |  |  |  |  |
| 1 | Pull-up resistor incorporated.     |  |  |  |  |  |  |

NOTE: The uPD75P336 does not incorporate pull-up resistors by mask option.



Table 5-4 On-Chip Pull-Up Resistor Specification Method

| Port         | (Pin | Nan | ne)  | Specification Method                                            | Special<br>Bit |
|--------------|------|-----|------|-----------------------------------------------------------------|----------------|
| Port 0<br>*1 | (P01 | to  | P03) | On-chip resistor specification by software in 3-bit units       | POGA.0         |
| Port 1       | (P10 | to  | P13) | On-chip resistor specification by software in 4-bit units       | POGA.1         |
| Port 2       | (P20 | to  | P23) | SOITWATE IN 4-DIT UNITS                                         | POGA.2         |
| Port 3       | (P30 | to  | P33) |                                                                 | POGA.3         |
| Port 6       | (P60 | to  | P63) |                                                                 | POGA.6         |
| Port 7       | (P70 | to  | P73) |                                                                 | POGA.7         |
| Port 8       | (P80 | to  | P83) |                                                                 | POGB.0         |
| Port 4       | (P40 | to  | P43) | On-chip resistor specification by mask option in 1-bit units *2 |                |
| Port 5       | (P50 | to  | P53) | mask option in 1-bit units 2                                    |                |

- \*1: No pull-up resistor can be incorporated in the POO pin.
  - 2: The uPD75P336 can incorporate no pull-up resistor in ports 4 and 5.

Pull-up resistor usage is switched by the pull-up resistor specification register (POGA, POGB) setting using the following timing.



After the on-chip pull-up resistor has been specified by rewriting POGA and POGB, execute an NOP instruction and an input/output instruction in that order, taking into account the external load capacity.

Example: Enter after specifying on-chip pull-up resistor for port 1.

5.1.6 DIGITAL INPUT/OUTPUT PORT INPUT/OUTPUT TIMINGS

Data is output to the output latch and pin data or output latch data is fetched into the internal bus using the timings shown in Figure 5-9.

ON timings when on-chip pull-up resistor is specified by software are shown in Figure 5-10.



Figure 5-9 Digital Input/Output Port Input/Output Timings

(a) When data is fetched by 1-machine cycle instruction

|                          | 1 Machine Cycle          |  |  |  |  |  |  |
|--------------------------|--------------------------|--|--|--|--|--|--|
| Instruction<br>Execution | Operation<br>Instruction |  |  |  |  |  |  |

Input Timing

(b) When data is fetched by 2-machine cycle instruction

|                                    | 2 Machine Cycles |      |                |                                                 |       |          |        |             |       |     |      |      |     |
|------------------------------------|------------------|------|----------------|-------------------------------------------------|-------|----------|--------|-------------|-------|-----|------|------|-----|
| -<br>Instruction<br>Execution      |                  |      | T              | Opera                                           | tion  |          | ructio | ו ו<br>• מו |       |     | 1    | 1    | · - |
| Input Timing                       | •                |      |                |                                                 |       |          |        | <b></b>     |       |     |      |      |     |
| (c) What                           | en               | data | is             | latch                                           | ed k  | oy 1     | -mac   | chine       | сус   | cle | inst | ruct | ion |
| -<br>Instruction<br>Execution<br>- |                  |      | Opera<br>Insti | ation<br>fuction                                |       |          |        | I           |       |     |      |      |     |
| Output Latch<br>(Output Pin)       |                  |      |                | <u>- 10 _ 10 _ 10 _ 10 _ 10 _ 10 _ 10 _ 10 </u> |       | $\times$ |        |             |       |     |      |      |     |
| (đ) Wh                             | en               | data | is             | latch                                           | ned 1 | ру 2     | -mac   | chine       | e cyc | cle | inst | ruct | ion |
| Instruction<br>Execution           |                  |      | I              | Oper                                            | ation | Inst     | ructi  | •           | 1     |     | (    | 1    | -   |
|                                    |                  |      |                |                                                 |       |          |        |             |       | ~   |      |      | _   |
| Output Latch<br>(Output Pin)       |                  |      |                |                                                 |       |          |        |             |       | >   |      |      | _   |
|                                    |                  |      |                |                                                 |       |          |        |             |       |     |      |      |     |
|                                    |                  |      |                |                                                 |       |          |        |             |       |     |      |      |     |
|                                    |                  |      |                |                                                 |       |          |        |             |       |     |      |      |     |

■ 6427525 0094978 943 ■ 5-23

Figure 5-10 Pull-Up Resistor ON Timing by Software



2 Machine Cycles



#### 5.2 CLOCK GENERATOR

The clock generator supplies the CPU and peripheral hardware with various types of clocks and controls the CPU operation mode.

#### 5.2.1 CLOCK GENERATOR CONFIGURATION

The clock generator is configured as shown in Figure 5-11.

# ■ 6427525 0094980 5T1 ■ 5-25





5-26 5-26 6427525 0094981 438 🎟

#### 5.2.2 CLOCK GENERATOR FUNCTIONS AND OPERATIONS

The clock generator generates the following clocks and controls the CPU operating modes including standby mode.

- . Main-system clock f<sub>X</sub>
- . Subsystem clock f<sub>XT</sub>
- . CPU clock ¢
- . Clock to peripheral hardware

The following clock generator operations are determined by the processor clock control register (PCC) and the system clock control register (SCC):

- (a) When the RESET signal is generated, the lowest speed mode (15.3 us/4.19 MHz) of the main-system clock is selected (PCC = 0, SCC = 0).
- (b) One of the four-level CPU clocks can be selected by setting the PCC with the main-system clock selected (0.95 us, 1.91 us, 3.81 us and 15.3 us/4.19 MHz).
- (c) Two standby modes, the STOP and HALT modes, are available with the main-system clock selected.
- (d) The clock generator can be operated at a super lowspeed with low power consumption (122 us/32.768 kHz) by selecting the subsystem clock with SCC. In this case, the PCC set value has no effect on the CPU clock.
- (e) Main-system clock oscillation can be stopped by SCC with the subsystem clock selected. The HALT mode can also be used but the STOP mode cannot be used. (Subsystem clock oscillation cannot be stopped.)

6427525 0094982 374 M

- (f) Divided main-system clocks are supplied to the peripheral hardware. Subsystem clocks can be directly supplied to the watch timer. Therefore, the clock function, the LCD control function executed by the clock from the watch timer, and the buzzer output function can be continued even in the standby status.
- (g) When a subsystem clock is selected as the count clock of the watch timer, the watch timer and the LCD controller can continue to operate normally. However, because the other hardware devices operate with main-system clock, they cannot be used if the main-system clock is stopped.
- (1) Processor clock control register (PCC)

The PCC is a 4-bit register used to select the CPU clock  $\phi$  with the least significant 2 bits and to control the CPU operating mode with the most significant 2 bits. Figure 5-12 on the next page shows the PCC format.

When bit 3 or 2 is set to "1", the standby mode is set. If the standby mode is released by the standby release signal, both bits are automatically cleared and the normal operating mode is set. (For details, refer to Chapter 7. "Standby Functions".)

The least significant 2 bits of the PCC are set by a 4-bit memory manipulation instruction (with the most significant 2 bits set to "0").

Bits 3 and 2 are set to "1" by the STOP and HALT instructions, respectively.

The STOP and HALT instructions can always by executed irrespective of the MBE contents.

6427525 0094983 200 **m** 5-28 The CPU clock can only be selected during operation with the main-system clock. When operating with the subsystem clock, the least significant 2 bits of the PCC are invalidated and  $f_{\rm XT}/4$  is fixed. The STOP instruction is also enabled only during operation with the main-system clock.

Example 1: Set the machine cycle to 0.95 us  $(f_X = 4.19 \text{ MHz}).$ 

SEL MB15 MOV A, #0011B MOV PCC,A

2: Set the machine cycle to 1.63 us  $(f_X = 4.91 \text{ MHz}).$ 

SEL MB15 MOV A, #0010B MOV PCC,A

3: Set the STOP mode (be sure to write NOP instruction after STOP and HALT instructions).

STOP NOP

When the  $\overrightarrow{\text{RESET}}$  signal is generated, the PCC is cleared to "0".

5-29 5-29 6427525 0094984 147 🎟

Figure 5-12 Processor Clock Control Register Format



NOTE: When using a value of  $f_X$  such that 4.19 MHz <  $f_X \leq 5$  MHz, if the maximum speed:  $\Phi = f_X/4$  (PCC1, PCC0 = 11) is set as the CPU clock frequency, 1 machine cycle becomes less than 0.95 us, with the result that the specified MIN value of 0.95 cannot be observed. Therefore, in this case PCC1, PCC0 = 11 cannot be set. Use PCC1, PCC0 = 10 or 01 or 00. As a result, the combination of  $f_X = 4.19$  MHz and PCC1, PCC0 = 11 is the selected maximum CPU clock speed (1 machine cycle = 0.95 us).

5-30 5-30 6427525 0094985 083 🎟

#### (2) System clock control register (SCC)

The SCC is a 4-bit registered used to select the CPU clock  $\Phi$  with the least significant bit and to control main system clock oscillation stop page with the most significant bit. Figure 5-13 shows the SCC format.

Although bits 3 and 0 of SCC are located at the same data memory address, both bits cannot be changed simultaneously. Thus, these two bits of SCC are set by a bit manipulation instruction. Bits 3 and 0 of SCC can always be bit-manipulated irrespective of the MBE contents.

Main-system clock oscillation can be stopped by setting SCC bit 3 only when in operation with the subsystem clock. Oscillation when in operation with the main-system clock is stopped by the STOP instruction.

When the  $\overline{\text{RESET}}$  signal is generated, the SCC is cleared to "0".



Figure 5-13 System Clock Control Register Format

БА 6427525 ОО94986 ТЪТ ■ 5-31

- NOTE 1: A maximum of  $1/f_{XT}$  is required to change the system clock. Thus, when stopping the main-system clock oscillation, set SCC bit 3 following the elapse of more than the number of machine cycles shown in Table 5-5 after the subsystem clock has been changed to the subsystem clock.
  - 2: If oscillation is stopped by setting SCC bit 3 while in operation with the main-system clock, the normal STOP mode is not set.
  - 3: When "1" is set in SCC bit 3, X1 input is internally short-circuited to V<sub>SS</sub> (GND potential) to prevent leakage from the crystal oscillator unit. Thus, when using an external clock for the main-system clock, do not set "1" in SCC bit 3.
  - 4: When PCC = 0001B (with  $\phi = f_X/16$  selected), do not set "1" in SCC bit 0 switching from the main system clock to subsystem clock should be performed after setting PCC to the other state (PCC  $\neq$  0001B). Do not perform setting of PCC = 0001B when operating with subsystem clock.
  - (3) System clock oscillator
    - (i) The main system clock oscillator oscillates with a crystal resonator or a ceramic resonator connected to the X1 and X2 pins (with a standard frequency of 4.194304 MHz).

External clocks can be input to this oscillator. In this case, apply the clock signal to the X1 pin and the inverted clock signal to the X2 pin.

■ 6427525 0094987 956 ■ 5-32 Figure 5-14 External Circuit of Main-System Clock Oscillator

(a) Crystal/ceramic oscillation





- NOTE: When an external clock is input, STOP mode cannot be set. This is because the X1 pin is short-circuited to  $V_{\rm SS}$  in the STOP Mode.
  - (ii) The subsystem clock oscillator oscillates with a crystal resonator (with a standard frequency of 32.768 kHz) connected to the XT1 and XT2 pins. External clock can be input to this oscillator. In this case, apply the clock signal to the XT1 pin and the inverted signal to the XT2 pin.

The XT1 pin status can be tested by bit 3 of the clock mode register (WM).



Figure 5-15 External Circuit of Subsystem Clock Oscillator







- NOTE 1: When main system clock and subsystem clock oscillator are used, the shaded area in Figures 5-14 and 5-15 should be wired in order to avoid effects of wiring capacitance etc., as shown below.
  - . Minimize the length of wiring.
  - . Do not cross other signal lines, or position wiring close to a variable high current.
  - . The grounding point of the oscillator capacitor should always be of the same potential as  $V_{\rm DD}$ . Do not connect it to the supply pattern where there is a high current.
  - . Do not pick up the signal form the oscillator.

The subsystem clock oscillator is designed to be a low amplification circuit which consumes only a low current and misoperation caused by noise may occur more often than with the main system clock oscillator.

Therefore, when using the subsystem clock, extreme care is required for the wiring procedure. Figure 5-16 shows bad examples of resonator connection circuits.

> ∎ 6427525 0094989 729 **■** 5-34

Figure 5-16 Bad Examples of Resonator Connection Circuit

- (a) Connection circuit is too long.
- μPD75336 V<sub>DD</sub> X1 X2 V<sub>DD</sub> X1 V<sub>DD</sub> X1 V<sub>DD</sub> X1 V<sub>DD</sub> X1 V<sub>DD</sub> X1
- (c) A line carrying varying large current is running near the connection circlet.

(b) Connection circuit crosses a signal line.



(d) Current is flowing in the grounding line of the oscillation circuit. (The electric potential at points A, B and C fluctuates.)





Remarks 1: When the subsystem clock is used, pins X1 and X2 in the figures above should be read as XT1 and XT2, respectively. Insert also a resistor serially on the XT2 side.

■ 6427525 0094990 440 **■** 5-35 Remarks 2: Pin arrangements in the figures above are for illustration purposes only and may differ from those for the uPD75336.

- Figure 5-16 Bad Examples of Resonator Connection Circuit (cont'd)
  - (e) Signal is being taken out of the connection circuit.
- (f) The main system clock signal line is placed adjacent to and parallel with the subsystem signal line.



- Remarks 1: When the subsystem clock is used, pins X1 and X2 in the figures above should be read as XT1 and XT2, respectively. Insert also a resistor serially on the XT2 side.
  - 2: Pin arrangements in the figures above are for illustration purposes only and may differ from those for the uPD75336.

■ 6427525 0094991 387 ■ 5-36

NOTE 2: In Figure 5-16 (f), XT2 is arranged in parallel with X1. This may lead to erroneous operation due to the X1 crosstalk noise multiplied by XT2 crosstalk noise.

To prevent erroneous operation, X1 and XT2 should not be arranged in parallel, and the NC pin located between the two should be connected to  $V_{DD}$ .



(4) Frequency divider

The frequency divider divides the main-system clock oscillator output  $(f_X)$  and generates various clocks.

(5) When subsystem clock is not used

When it is not necessary to use a subsystem clock because of low power consumption operation, clock operation, etc. handle the XT1 and XT2 pins as follows:

XT1: Connect to  $V_{SS}$  or  $V_{DD}$ XT2: Leave open

In this state, however, some leakage current may result via an internal feedback resistor of the subsystem clock oscillator. To minimize the leakage current, the internal feedback resistor can be removed by a mask option. In this case also, handle the XT1 and XT2 pins as described above (be sure to specify the mask option when ordering).

> ■ 6427525 0094992 213 ■ 5-37

# 5.2.3 SYSTEM CLOCK AND CPU CLOCK SETTINGS

(1) Time required for system clock and CPU clock switching

The system clock and the CPU clock can be mutually switched with the least significant 2 bits of the SCC and the least significant bit of the SCC. This switching is not executed just after register rewriting and operation continues with the previous clock during the specified number of machine cycles. Thus, to stop main system clock oscillation, it is necessary to execute a STOP instruction or to set SCC bit 3 to "1" after the specified switching time.



| Set Value<br>before<br>Switching |     |     | Set Value after Switching |                    |                      |            |                      |          |                     |              |                                                                             |              |             |          |          |          |          |
|----------------------------------|-----|-----|---------------------------|--------------------|----------------------|------------|----------------------|----------|---------------------|--------------|-----------------------------------------------------------------------------|--------------|-------------|----------|----------|----------|----------|
| scc<br>0                         | PCC | PCC | SCC<br>0                  | PCC<br>1           | PCC<br>0             | · SCC<br>0 | PCC<br>1             | PCC<br>0 | SCC<br>0            | PCC<br>1     | PCC<br>O                                                                    | SCC<br>0     | PCC<br>1    | PCC<br>0 | SCC<br>0 | PCC<br>1 | PCC<br>0 |
|                                  |     | U   | 0                         | 0                  | 0                    | 0          | 0                    | 1        | 0                   | 1            | 0                                                                           | 0            | 1           | 1        | 1        | x        | x        |
| 0                                | 0   | 0   |                           |                    | 1 machine<br>cycle   |            | 1 machine<br>cycle   |          | 1 machine<br>cycle  |              | $f_X/64f_{XT}$<br>machine<br>cycles<br>(2 machine<br>cycles)                |              |             |          |          |          |          |
|                                  | 0   | 1   | 4 machine<br>cycles       |                    |                      |            | 4 machine<br>cycles  |          | 4 machine<br>cycles |              | Setting<br>prohibited                                                       |              |             |          |          |          |          |
|                                  | 1   | 0   | 8 machine<br>cycles       |                    | 8 machine<br>cycles  |            |                      |          |                     | 8 ma<br>cycl | achin<br>Les                                                                | ne           | cyc.        | mach     | nine     |          |          |
|                                  | 1   | 1   | 16 machine<br>cycles      |                    | 16 machine<br>cycles |            | 16 machine<br>cycles |          |                     |              | <pre>f<sub>X</sub>/4f<sub>XT</sub> machine cycles (32 machine cycles)</pre> |              |             |          |          |          |          |
| 1                                | х   | x   |                           | 1 machine<br>cycle |                      | 1          | ting<br>hibi         |          | 1 ma<br>cyc         | achin<br>Le  | ne                                                                          | 1 ma<br>cycl | achii<br>Le | ne       |          |          |          |

# Table 5-5 Maximum Time Required for System Clock and CPU Clock Switching

Remarks 1 : Values with  $f_X = 4.19$  MHz and  $f_{XT} = 32.768$  kHz are indicated in parentheses.

- 2 : x : don't care
- 3 : CPU clock  $\phi$  is a clock to be supplied to the internal CPU. The reciprocal of this clock is the minimum instruction time (defined as 1 machine cycle in this manual).
  - 6427525 0094994 096 5-39

- NOTE 1: When PCC = 0001B (with  $\phi = f_{XT}/16$  selected) do not set "1" in SCC bit 0. Switching from the main system clock to subsystem clock should be performed after setting PCC to the other state (PCC  $\neq$  0001B). Do not perform setting of PCC = 0001B when operating with subsystem clock.
  - 2: The values of  $f_X$  and  $f_{XT}$  vary depending on conditions such as the dispersion of the resonator ambient temperature and load capacitance performance. When  $f_X$  is higher than the nominal value, and when  $f_{XT}$  is lower than the nominal value, in particular, the machine cycle figure obtained from the expressions  $f_X/64f_{XT}$ ,  $f_X/8f_{XT}$  and  $f_X/4f_{XT}$  in the table will be larger than that obtained with the nominal values of  $f_X$  and  $f_{XT}$ . Therefore, when setting the wait time required to switch between the system clock and CPU clock, it should be made longer than the number of machine cycles obtained with the nominal values of  $f_X$  and  $f_{XT}$ .
  - (2) System clock and CPU clock switching procedure

System clock and CPU clock switching is described with reference to Figure 5-17.

## ■ 6427525 0094995 T22 ■ 5-40

# Figure 5-17 System Clock and CPU Clock Switching



- When a RESET signal is generated, the CPU starts at the lowest speed (15.3 us/4.19 MHz) of the main system clock after the wait time (31.3 ms/ 4.19 MHz) for maintaining the oscillation stabilization time.
- (2) The CPU rewrites the PCC and operates at its maximum available speed after the elapse of sufficient time for the V<sub>DD</sub> pin voltage to increase to a voltage allowing the highest speed operation.
- ③ The CPU detects commercial power-off from the interrupt input\*, sets SCC bit 0 to "1" and operates with the subsystem clock. (Subsystem clock oscillation must have started.) After the elapse of the time required for the CPU clock to switch to the subsystem clock (32 machine cycles), the CPU sets SCC Bit 3 to "1" and stops main system clock oscillation.

■ 6427525 0094996 969 **■** 5-41

(4) After the CPU detects the commercial power reset from the interrupt, it clears SCC bit 3 to "0" and starts main system clock oscillation. Following the elapse of the time required for oscillation stabilization, the CPU clears SCC bit 0 to "0" and operates at its highest speed.

\*: Use of INT4 is effective.

#### 5.2.4 CLOCK OUTPUT CIRCUIT

(1) Clock output circuit configuration

The clock output circuit is configured as shown in Figure 5-18.

(2) Clock output circuit functions

The clock output circuit generates clock pulses from the P22/PCL pin. It is used to generate remote controlled outputs and supply the peripheral LSI with clock pulses.

Use the following procedure to generate clock pulses:

- (a) Select the clock output frequency with clock output disabled.
- (b) Write "0" in the P22 output latch.
- (C) Set the port 2 input/output mode to output.
- (d) Enable clock output.

■ 6427525 0094997 8T5 ■ 5-42

Figure 5-18 Clock Output Circuit Configuration



- Remarks: When the clock output enabled/disabled status is switched, pulses with short widths will not be output.
  - (3) Clock output mode register (CLOM)

The CLOM is a 4-bit register used to control clock output. It is set by a 4-bit memory manipulation instruction. Data cannot be read from the CLOM.

Example: Generate CPU clock  $\phi$  from PCL/P22 pin.

SEL MB15 ; Or CLR1 MBE MOV A, #1000B MOV CLOM, A

When the RESET signal is generated, the CLOM is cleared to "0" and clock output is disabled.

■ 6427525 0094998 731 ■ 5-43 Figure 5-19 Clock Output Mode Register Format



NOTE: Be sure to write "0" to bit 2 of CLOM.

(4) Example of application to remote controlled output

The uPD75336 clock output functions can be applied to remote controlled output. The remotely controlled output carrier frequency is selected by the clock frequency select bit of the clock output mode register. Pulse output is enabled/disabled by controlling the clock output enable/disable bit by software.

When switching the clock output enabled/disabled status, pulses with short widths will not be output.

5-44 ■ 6427525 0094999 678 ■



■ 6427525 0095000 T98 ■ 5-45

This Material Copyrighted By Its Respective Manufacturer

Figure 5-20 Example of Application to Remote Controlled Output

# 5.3 BASIC INTERVAL TIMER

The uPD75336 is equipped with an 8-bit basic interval timer which has the following functions:

- (a) Reference time generation (4 time intervals)
- (b) Watchdog timer application to detect inadvertent program loop
- (c) Wait time selection and count upon standby mode release
- (d) Count contents read
- 5.3.1 BASIC INTERVAL TIMER CONFIGURATION

The basic interval timer is configured as shown in Figure 5-21.



Figure 5-21 Basic Interval Timer Configuration

- \*: Instruction execution
  - 6427525 0095001 924 5-46

# 5.3.2 BASIC INTERVAL TIMER MODE REGISTER (BTM)

The BTM is a 4-bit register used to control basic interval timer operations.

The BTM is set by a 4-bit memory manipulation instruction.

Bit 3 can be set independently by a bit manipulation instruction.

Example 1: Set the interrupt generation interval to 1.95 ms (4.19 MHz).

SEL MB15 ; Or CLR1 MBE MOV A, #1111B MOV BTM, A ; BTM ~ 1111B

2: Clear BT and IRQBT (watchdog timer application).

SEL MB15 ; Or CLR1 MBE SET1 BTM. 3 ; BTM bit 3 is set to "1".

When bit 3 is set to "1", the basic interval timer contents and the basic interval timer interrupt request flag (IRQBT) are simultaneously cleared (basic interval timer start).

When the RESET signal is generated, the contents are cleared to "0" and the interrupt request signal generation interval time is set to its maximum value.

> ■ 6427525 0095002 860 ■ 5-47

# Figure 5-22 Basic Interval Timer Mode Register Format



# 5.3.3 BASIC INTERVAL TIMER OPERATION

The basic interval timer (BT) is incremented by clock pulses from the clock generator and sets the interrupt request flag (IRQBT) due to an overflow. BT count operation cannot be stopped.

Four interrupt generation intervals are available by setting the BTM (Figure 5-22).

The basic interval timer and the interrupt request flag can be cleared by setting bit 3 of the BTM to "1" (interval timer start instruction).

The count status can be read from the basic interval timer (BT) by an 8-bit manipulation instruction. Data cannot be written to the BT.

■ 6427525 0095003 7T7 ■ 5-48 NOTE: When reading the basic interval timer count contents, execute the read instruction twice and compare the two read contents so as not to read unstable data undergoing count updating. If the two values are both acceptable, use the second read value as the correct one. If they differ completely, execute reading again from the beginning.

| Example: | BT cou | nt cont | ents read |                      |
|----------|--------|---------|-----------|----------------------|
|          |        | SET1    | MBE       |                      |
|          |        | SEL     | MB15      |                      |
|          |        | MOV     | ML, #BT;  | BT address set to HL |
|          | LOOP:  | MOV     | XA, @HL;  | 1st read             |
|          |        | MOV     | BC, XA    |                      |
|          |        | MOV     | XA, @HL;  | 2nd read             |
|          |        | SKE     | XA, BC    | •                    |
|          |        | BR      | LOOP      |                      |

To obtain the oscillation stabilization time from STOP mode release to system clock oscillation stabilization, the wait function is available to stop CPU operation until the basic interval timer overflows.

The wait time after the RESET signal is generated is fixed. However, if the STOP mode has been released by interrupt generation, the wait time can be selected by BTM setting. In that case, the wait time is equal to the interval time shown in Figure 5-22. BTM setting must be done before STOP mode setting. (For details, refer to Chapter 7. "Standby Functions.)

> ■ 6427525 0095004 633 ■ 5-49

# 5.3.4 BASIC INTERVAL TIMER APPLICATION EXAMPLE

Example 1: Enable basic interval timer interruption and set the interrupt generation interval to 1.95 ms (at 4.19MHz).

> SEL MB15 MOV A, #1111B MOV BTM, A ; Set and start EI ; Interrupt enabled EI IEBT ; BT interrupt enabled

2: Watchdog timer application

Divide the program into several modules which terminate processing within the BT set period and clear BT and IRQBT at the end of each module. If an interrupt is generated, the program is judged to have an inadvertent loop.





Example 3: Set the wait time upon STOP mode release by interruption to 7.8 ms.

SEL MB15 MOV A, #1101B MOV BTM, A ; BTM ~ 1101B STOP ; STOP Mode set NOP

4: Set the high-level width of a pulse to be input to INT4 interrupt (both-edge detection). (The pulse width should not exceed the BT set value which should be 7.8 ms or more.)

| <int4< th=""><th>interr</th><th>upt routin</th><th>e</th><th>(MBE = 0)&gt;</th></int4<> | interr | upt routin | e | (MBE = 0)>             |
|-----------------------------------------------------------------------------------------|--------|------------|---|------------------------|
| LOOP:                                                                                   | MOV    | XA, BT     | ; | 1st read               |
|                                                                                         | MOV    | BC, XA     | ; | Data storage           |
|                                                                                         | MOV    | XA, BT     | ; | 2nd read               |
|                                                                                         | SKE    | A, C       |   |                        |
|                                                                                         | BR     | LOOP       |   |                        |
|                                                                                         | MOV    | A, X       |   |                        |
|                                                                                         | SKE    | А, В       |   |                        |
|                                                                                         | BE     | LOOP       |   |                        |
|                                                                                         | SKT    | PORT0.0    | ; | POO = 1?               |
|                                                                                         | BR     | AA         | ; | NO                     |
|                                                                                         | MOV    | XA, BC     | ; | Data storage into data |
|                                                                                         |        |            |   | memory                 |
|                                                                                         | MOV    | BUFF, XA   |   |                        |
|                                                                                         | CLR1   | FLAG       | ; | Data available. Flag   |
|                                                                                         |        |            |   | clear                  |
|                                                                                         |        |            |   |                        |

RETI

6427525 0095006 406 📼 5-51

| AA | : | MOV  | HL, #BUFF                   |
|----|---|------|-----------------------------|
|    |   | MOV  | A, C                        |
|    |   | SUBC | A, @HL                      |
|    |   | INCS | L .                         |
|    |   | MOV  | С, А                        |
|    |   | MOV  | А, В                        |
|    |   | SUBC | A, @HL                      |
|    |   | MOV  | B, A                        |
|    |   | MOV  | XA, BC                      |
|    |   | MOV  | BUFF, XA ; Data storage     |
|    |   | SET1 | FLAG ; Data available. Flag |
|    |   |      | set                         |

RETI

# ■ 6427525 0095007 342 ■ 5-52

#### 5.4 WATCH TIMER

The uPD75336 incorporates one watch timer channel which has the following functions.

- (a) Sets the test flag (IRQW) at 0.5 second intervals. The standby mode can be released by IRQW.
- (b) 0.5 second intervals can be set with the main system or subsystem clock.
- (c) The fast mode enables setting of a 128 times (3.91 ms) interval useful to program debugging and inspection.
- (d) The fixed frequencies (2.048 kHz, 4.096 kHz and 32.768 kHz) can be output to the P23/BUZ pin for use to generate buzzer sound or trim the system clock oscillator frequency.
- (e) Since the frequency divider can be cleared, the clock can be started from zero seconds.
- 5.4.1 WATCH TIMER CONFIGURATION

The watch timer is configured as shown in Figure 5-23.

# ■ 6427525 0095008 289 **■** 5-53

Figure 5-23 Watch Timer Block Diagram



Values at  $f_X = 4.194304$  MHz and  $f_{XT} = 32.768$  kHz are indicated in parentheses.



# 5.4.2 CLOCK MODE REGISTER

The clock mode register (WM) is an 8-bit register used to control the watch timer. Its format is shown in Figure 5-24.

The clock mode register is set by an 8-bit manipulation instruction, except for bit 3. Bit 3 is used to test the XT1 pin input level. A bit test enables the input level for the XT1 pin to be tested. Data cannot be written to this bit. When the RESET signal is generated, all bits except bit 3 are cleared to "0".

Example: Generate time with the main-system clock (4.19 MHz). Enable buzzer output.

CLR1 MBE MOV XA, #84H MOV WM, XA ; WM set

Figure 5-24 Clock Mode Register Format



■ 6427525 0095010 937 ■ 5-55

# Figure 5-24 Clock Mode Register Format (cont'd)

# Count Clock (f<sub>W</sub>) Select Bit

| WMO | 0 | System clock divided output:<br>f <sub>X</sub> /128 selected |
|-----|---|--------------------------------------------------------------|
|     | 1 | Subsystem clock: f <sub>XT</sub> selected                    |

## Operation Mode Select Bit

| 100 | 0 | Normal clock mode<br>(f <sub>W</sub> /2 <sup>1</sup> *: IRQW set at 0.5 sec) |
|-----|---|------------------------------------------------------------------------------|
| WM1 | 1 | Fast clock mode<br>(f <sub>W</sub> /2 <sup>7</sup> : IRQW set at 3.91 ms)    |

# Clock Operation Enable/Disable Bit

| WM2     | 0 | Clock operation stop<br>(frequency divider clear) |
|---------|---|---------------------------------------------------|
| VV IV12 | 1 | Clock operable                                    |

# XT1 Pin Input Level (Only Bit Test Enabled)

| WM3 | 0 | XT1 pin input at low level  |
|-----|---|-----------------------------|
| WM3 | 1 | XT1 pin input at high level |

# BUZ Output Frequency Select Bit

| WM5 | WM4 | BUZ output frequency             |
|-----|-----|----------------------------------|
| 0   | 0   | $\frac{f_W}{2^{14}}$ (2.048 kHz) |
| 0   | 1   | $\frac{f_W}{2^3}$ (4.096 kHz)    |
| 1   | 0   | Setting prohibited               |
| 1   | 1   | i <sub>w</sub> (32, 768 kHz)     |

#### BUZ Output Enable/Disable Bit

| WM7 | 0 | BUZ output disabled |
|-----|---|---------------------|
| WM1 | 1 | BUZ output enabled  |

Remarks: Values at  $f_W = 32.768$  kHz are indicated in parentheses.

# ■ 6427525 0095011 873 ■ 5-56

#### 5.5 TIMER/EVENT COUNTER

# 5.5.1 TIMER/EVENT COUNTER CONFIGURATION

The uPD75336 incorporates to timer/event counter channels. Its format is shown in Figure 5-25.

(1) Differences between timer/event counter channel 0 and channel 1.

The two channels have the following differences:

Table 5-6 Differences between Timer/Event Counter Channel 0 and Channel 1

| Differences                      | Channel O                               | Channel 1                                               |
|----------------------------------|-----------------------------------------|---------------------------------------------------------|
| Select count pulse               | $f_X/2^{10}, f_X/2^8, f_X/2^6, f_X/2^4$ | $f_{X}/2^{12}, f_{X}/2^{10}, f_{X}/2^{10}, f_{X}/2^{6}$ |
| Clock supply to serial interface | Possible                                | Not possible                                            |

#### (2) Timer/event counter functions

The timer/event counter has the following functions: (a) Programmable interval timer operation

- (b) Output of square waves with selected frequency to the PTOn pin
- (c) Event counter operation
- (d) Output of N-divided TIn pin input to the PTOn pin (frequency divider operation)
- (e) Serial shift clock supply to the serial interface circuit
- (f) Count state read function ■ 6427525 0095012 707 ■ 5-57





## 5.5.2 TIMER/EVENT COUNTER BASIC CONFIGURATION AND OPERATION

The timer/event counter can select several operating modes using the timer/event counter mode register (TMO/TM1). Its basic configuration and operations are as follows.

- Count pulse CP is selected by TMn setting and is input to the 8-bit count register (T0/T1).
- (2) Tn is a binary 8-bit up-counter which is incremented by one when CP is input. When the RESET signal is generated, TMn bit 3 is set (timer start) or a match signal is generated, Tn is cleared to "0". Data can be read from Tn by the 8-bit memory manipulation instruction. Data cannot be written to (T0/T1).
- (3) Modulo register (TMODO, TMOD1) is an 8-bit register used to determine the Tn count number. Values are set in TMODn by the 8-bit memory manipulation instruction but data cannot be read from TMODn. When the RESET signal is generated, TMODn is initialized to FFH.
- (4) The comparator compares Tn and TMODn contents. When they match each other, the comparator generates a match signal and sets the interrupt request flag (IRQTO/IRQT1).

Figure 5-26 shows count operation timings.

### ■ 6427525 0095014 582 ■ 5-59

Figure 5-26 Count Operation Timings



5.5.3 TIMER/EVENT COUNTER MODE REGISTERS (TMO, TM1)

The timer/event counter mode register (TMO, TM1) is an 8bit register used to control the timer/event counter. Its format is shown in Figure 5-27.

TMO and TM1 are set by the 8-bit memory manipulation instruction.

Bit 3 is a timer start bit and can be manipulated individually. When the timer starts operating, bit 3 is reset to "0".

When the  $\overline{\text{RESET}}$  signal is generated, all bits of the timer mode register are cleared to "0".

Example 1: Start the timer in the interval timer mode with CP = 4.09 kHz.

Example 2: Restart the timer according to timer mode register setting.

SEL MB15 ; Or CLR1 MBE SET1 TM0.3; TM0. bit 3 + 1

Figure 5-27 Timer/Event Counter Mode Register Format (Channels 0 and 1)



■ 6427525 0095016 355 **■** 5-61

# 5.5.4 TIMER/EVENT COUNTER OUTPUT ENABLE FLAGS (TOEO, TOE1)

The timer/event counter output enable flag (TOEO, TOE1) is a flag used to control the timer out F/F (TOUT F/F) status output enabling disabling for PTOO and PTO1 pins. The timer out F/F is an F/F which is inverted by a match signal from the comparator. When bit 3 of the timer mode register (TMO, TM1) is set to "1", the timer out F/F is reset to "0".

When the  $\overline{\text{RESET}}$  signal is generated, TOEO, TOE1 and the timer out F/F are cleared to "0".

Figure 5-28 Timer/Event Counter Output Enable Flag Format (Channels 0, 1)



#### 5.5.5 TIMER/EVENT COUNTER OPERATING MODES

The count operation stop mode and the count operating mode are available by the mode register setting for the timer/ event counter operation.

The following operations are enabled irrespective of the mode register setting:

- TIn pin signal input and test (P13 input of dualfunction pins is testable) \*1
- (2) Output of timer out F/F status to PTOn \*2

∎ 6427525 0095017 291 **■** 5-62

- (3) Modulo register (TMODn) setting
- (4) Count register (Tn) read
- (5) Interrupt request flag (IRQTn) set/clear/test
  - \*1: When using timer/event counter channel 1 (TI1), set the P80 dual-function pin to the input mode.
    - 2: When using the timer/event counter output pins (PTOO, PTO1), set the P2O and P21 dual-function pins as follows.
      - (1) Clear the P20 and P21 output latches.
      - 2) Set port 2 to the output mode.
      - 3 Disable on-chip pull-up resistor at port 2.
- (1) Count operation stop mode

When TMn bit 2 is "0", this mode is set. In this mode, the count operation is not carried out because count pulse (CP) supply to the count register is stopped.

(2) Count operating mode

When TMn bit 2 is "1", this mode is set. In this mode, the count pulses selected by bits 4 to 6 are supplied to the count register and the count operation is carried out as shown in Figure 5-29.

Timer operation can normally by started using the following procedure:

■ 6427525 0095018 128 ■ 5-63

- Set the count value in the modulo register (TMODn).
- ② Set the operating mode, count clock and start instruction in the mode register (TMn).

The modulo register is set by an 8-bit data transfer instruction.

NOTE: Set a value other than "0" in the modulo register.

Example: Set 3FH in the channel 0 modulo register.

SEL MB15 ; Or CLR1 MBE MOV XA. #3FH MOV TMODO, XA

Figure 5-29 Operation in Count Operating Mode



\*: A signal to the serial interface can be output to timer/event counter channel 0 only.

∎ 6427525 0095019 064 **■** 5-64

#### 5.5.6 TIMER/EVENT COUNTER TIME SETTING

[Timer setting time] (cycle) is obtained by dividing [modulo register contents + 1] by [count pulse frequency] selected by setting the timer mode register.

T (SEC) = 
$$\frac{N+1}{f_{CP}}$$
 = (N + 1) · (Resolution)

T (SEC) : Timer set time (sec)
f<sub>CP</sub> (Hz): Count pulse frequency (Hz)
N : Modulo register value (N \neq 0)

Once the timer is set, an interrupt request signal (IRQTn) is generated at the set interval.

Table 5-7 shows the resolution and maximum set time (when FFH is set in the modulo register) with each count pulse of the timer/event counter.

Example: Generate 30 ms time interval ( $f_X = 4.194304$  MHz).

In this case, use a mode with the maximum set time of 62.5 ms.

The time interval is given as

 $\frac{30 \text{ ms}}{244 \text{ us}}$  = 122.9 = 7AH

Set 79H in the modulo register.

SEL MB15 MOV XA, #79H MOV TMODO, XA

> ■ 6427525 0095020 886 ■ 5-65

| Mode Register |      |      | Timer Cha  | nnel O              | Timer Channel 1 |                     |  |
|---------------|------|------|------------|---------------------|-----------------|---------------------|--|
| TM'n6         | TMn5 | TMn4 | Resolution | Maximum<br>Set Time | Resolution      | Maximum<br>Set Time |  |
| 1             | 0    | 0    | 244 us     | 62.5 ms             | 980 us          | 250 ms              |  |
| 1             | 0    | 1    | 61.1 us    | 15.6 ms             | 244 us          | 62.5 ms             |  |
| 1             | 1    | 0    | 15.3 us    | 3.91 ms             | 61.1 us         | 15.6 ms             |  |
| 1             | 1    | 1    | 3.81 us    | 977 us              | 15.3 us         | 3.91 ms             |  |

# Table 5-7 Resolution and Maximum Set Time (with $f_x = 4.19$ MHz)

## 5.5.7 TIMER/EVENT COUNTER APPLICATION PRECAUTIONS

(1) Errors upon timer start

The time from timer start (TMn bit 3 set) to match signal generation may have a maximum difference of one clock count pulse (CP) from the value calculated in Section 5.5.6 "Timer/Event Counter Time Setting". This is because the count register is cleared asynchronously with regard to the CP as shown in Figure 5-30.

Figure 5-30 Count Register Clear Timing



#### (2) Precautions in timer start

Timer start (TMn bit 3 set) clears the count register Tn and the interrupt request flag IRQTn. If the timer is in the operating mode and IRQTn set and timer start occur simultaneously, IRQTn may not be cleared. This poses no problem when IRQTn is used as a vectored interrupt. In IRQTn test applications, however, a problem is that although the timer has started, IRQTn has been set. Thus, when starting the timer at a timing at which IRQTn may be set, stop the timer (by setting TMn bit 2 to "0") and then restart it, or execute timer start twice.

Example: Timer start at timing when IRQTO may be set

| SEL | MB15                 |
|-----|----------------------|
| MOV | XA, #0               |
| MOV | TMO, XA ; Timer stop |
| MOV | XA, #4CH             |
| MOV | TMO, XA ; Restart    |
|     |                      |

Or

SEL MB15 SET1 TM0.3 SET1 TM0.3 ; Restart



### (3) Errors in count register read

Count register contents can be read by an 8-bit data memory manipulation instruction. While this instruction is in operation, count pulse change is deferred so that the count register remains unchanged. Thus, when the count pulse signal source is set to TIn input, the count pulse is reduced by the instruction execution time (when the internal clock is used as a count pulse, this does not occur because the clock B in synchronization with the instruction).

Therefore, when applying TIn input as a count pulse and reading count register contents, the signal to be input must be one with a pulse width which will not cause incorrect counting if the count pulse is reduced. That is, the pulse to be input to TIn pin must have a width larger than one machine cycle in which the count is reserved by the read instruction.



(4) Count pulse changing precautions

If the count pulse has been changed by rewriting the timer mode register, the specification becomes valid just after instruction execution.

> ■ 6427525 0095023 595 ■ 5-68

Rewrite Rewrite Instruction Instruction Clock B Specification Clock A Specification Clock A Specification Clock A Clock B Count Pulse CP

A count pulse spike ((1) or (2)) may occur depending on combinations of clocks when the count pulse is changed. In this case, the counting may be incorrect or count register contents may be destroyed. To prevent this from occurring, when changing the count pulse, be sure to set bit 3 of the counter mode register to "1" and simultaneously restart the timer.



(5) Operation after modulo register change

The modulo register is changed when an 8-bit data memory manipulation instruction is executed.

## ■ 6427525 0095024 421 ■ 5-69



If the modulo register changed value is smaller than the count register value, the count register continues to count till it overflows. After it overflows, it recounts from 0. Thus, if the value (m) after the modulo register change is smaller than the value (n) before the change, it is necessary to restart the timer after the modulo register is changed.





#### 5.5.8 TIMER/EVENT COUNTER APPLICATIONS

- Use timer channel 0 as an interval timer which generates interrupts at 50 ms intervals.
  - . The most significant 4 bits of the mode register are set to 0100B and the maximum set time of 62.5 ms is selected.
  - . The least significant 4 bits of the mode register are set to 1100B.
  - . The modulo register is set as follows.

$$\frac{50 \text{ ms}}{244 \text{ us}} = 205 = \text{CDH}$$

<Program example>

| SEL | MB15           |                         |
|-----|----------------|-------------------------|
| MOV | XA, #OCDH      |                         |
| MOV | TMODO, XA ;    | Modulo set              |
| MOV | XA, #01001100B |                         |
| MOV | TMO, XA ;      | Mode set, timer start   |
| EI  | · ;            | Interrupt enabled       |
| EI  | IETO ;         | Timer interrupt enabled |

Remarks: In this application, the TIO pin can be used as an input pin.

(2) When 100 pulses are input from the TIO pin, an interrupt is generated (with pulse set to high active).

- . The most significant 4 bits of the mode register are set to 0000 and the rising edge is selected.
- . The least significant 4 bits of the mode register are set to 1100B.
- . The modulo register is set to 99 = 100 1.

■ 6427525 0095026 2T4 ■ 5-71

<Program example>

----

SEL MB15
MOV XA, #100 - 1
MOV TMODO, XA ; Modulo set
MOV XA, #00001100B
MOV TMO, XA ; Mode set
EI
EI
EI IETO ; INTTO enabled

# ■ 6427525 0095027 130 ■ 5-72

## 5.6 SERIAL INTERFACE

### 5.6.1 SERIAL INTERFACE FUNCTIONS

The uPD75336 incorporates a clocked 8-bit serial interface, with four modes available.

These modes are outlined below.

(1) Operation-halted mode

This mode is used when no serial transfer is to be performed, and allows power dissipation to be reduced.

(2) 3-wire serial I/O mode

In this mode, 8-bit data transfer is performed using three lines: The serial clock  $(\overline{SCK})$ , serial output (SO), and serial input (SI).

In the 3-wire serial I/O mode simultaneous transmission and reception is possible, increasing the data transfer processing speed.

Either the MSB or LSB can be specified as the start bit for an 8-bit data serial transfer, allowing connection to devices using either as the start bit.

The 3-wire serial I/O mode allows connection to 75X series and 78K series devices and various peripheral I/O devices.

■ 6427525 0095028 077 **■** 5-73 (3) 2-wire serial I/O mode

In this mode, 8-bit data transfer is performed using two lines: The serial clock ( $\overline{SCK}$ ) and the serial data bus (SBO or SB1). As the output level to the two lines can be manipulated by software, communication with multiple devices is possible.

Also, since software manipulation of the output level is possible for  $\overline{SCK}$  and SBO (or SB1), this mode is compatible with any communication format. It is therefore possible to eliminate the handshaking line previously required for connection to multiple devices, allowing efficient use of input/output ports.

(4) SBI mode (serial bus interface mode)

In the SBI mode, communication is performed with multiple devices by means of two lines: The serial clock  $(\overline{SCK})$  and the serial data bus (SBO or SB1).

This mode conforms to the NEC serial bus format.

In the SBI mode, the sender can output to the serial data bus an address to select the target device for serial communication, a command which gives a directive to the target device, and actual data. The receiver can determine by hardware whether the received data is an address, command or actual data.

This function allows input/output ports to be used efficiently, as with the 2-wire serial I/O mode, and also allows the serial interface control portion of the application program to be simplified.



# Figure 5-31 SBI System Configuration Example



# 5.6.2 SERIAL INTERFACE CONFIGURATION

The serial interface block diagram is shown in Figure 5-32.





Figure 5-32 Serial Interface Block Diagram

This Material Copyrighted By Its Respective Manufacturer

(1) Serial operating mode register (CSIM)

CSIM is an 8-bit register which specifies the serial interface operating mode, serial clock, wake-up function, etc. (See 5.6.3 (1) "Serial operating mode register" for details.)

(2) Serial bus interface control register (SBIC)

SBIC is an 8-bit register composed of bits which control the serial bus and flags which indicate various statuses of the input data from the serial bus, and is mainly used in the SBI mode. (See 5.6.3 (2) "Serial bus interface control register" for details.)

(3) Shift register (SIO)

The SIO register converts 8-bit serial data to parallel data and 8-bit parallel data to serial data. It performs transmission/reception operations (shift operations) in synchronization with the serial clock. A serial transfer is started by writing data to SIO. Actual transmission/reception operations are controlled by writes to the SIO. (See 5.6.3 (3) "Shift register" for details).

(4) SO latch

A latch which holds the SO/SBO and SI/SB1 pin levels. Can be directly controlled by software. Set at the end of the 8th SCK pulse in the SBI mode. (See 5.6.3 (2) "Serial bus interface control register" for details.)

(5) Serial clock selector

Selects the serial clock to be used. 5-77

## (6) Serial clock counter

Counts the serial clocks output and input in a transmission/reception operation, and checks that 8-bit data transmission/reception has been performed.

(7) Slave address register (SVA), address comparator

• In SBI mode

Used when the uPD75336 is used as a slave device. The slave sets its own specification number (slave address value) in the SVA register. The master outputs a slave address to select a specific slave.

The address comparator is used to compare the slave address received from the master with the SVA value, and if they match the relevant slave is determined to have been selected.

• In 2-wire serial I/O mode or SBI mode

When the uPD75336 transmits as the master or slave, the SVA register performs error detection. (See 5.6.3 (4) "Slave address register" for details.)

(8) INTCSI control circuit

Controls the generation of interrupt requests. Interrupt request (INTCSI) is generated in the following cases and interrupt request flag (IRQCSI) is set. (Refer to Figure 6-1 "Interrupt Control Circuit Block Diagram")

• In 3-wire and 2-wire serial I/O mode Interrupt request is generated on each count of 8 serial clock cycles.

> 6427525 0095033 434 5-78

• In SBI mode

When WUP\* = "0"... Interrupt request is generated on each count of 8 serial clock cycles.

When WUP = "1" ... When the SVA and SIO values match after address reception, interrupt request is generated.

\*: WUP ... Wake-up function specification bit (CSIM bit 5)

(9) Serial clock control circuit

Controls the supply of the serial clock to the shift register. Also controls the clock output to the  $\overline{\text{SCK}}$  pin when the internal system clock is used.

(10) Busy/acknowledge output circuit, bus release/command acknowledge detection circuit

Performs output and detection of various control signals in the SBI mode.

Does not operate in the 3-wire and 2-wire serial I/O mode.

(11) PO1 output latch

Latch used for serial clock generation by software after completion of 8 serial clock cycles.

Set to "1" by reset input.

When the internal system clock is selected as the serial clock, the PO1 output latch should be set to "1".

■ 6427525 0095034 370 ■ 5-79

## 5.6.3 REGISTER FUNCTIONS

(1) Serial operating mode register (CSIM)

The format of the serial operating mode register (CSIM) is shown in Figure 5-33.

CSIM is an 8-bit register which specifies the serial interface operating mode, serial clock, wake-up function, etc. CSIM is manipulated by 8-bit memory manipulation instructions.

The high-order 3 bits can be manipulated bit by bit using the individual bit names.

Read/write capability differs from bit to bit (see Figure 5-33). Bit 6 can be tested only, and data written to this bit is invalid.

Reset input clears this register to OOH.

Figure 5-33 Serial Operating Mode Register (CSIM) Format



# Figure 5-33 Serial Operating Mode Register (CSIM) Format (cont'd)

Serial clock selection bits (W)

|       |       | Sei                                                | SCK Pin  |                           |        |
|-------|-------|----------------------------------------------------|----------|---------------------------|--------|
| CSIM1 | CSIMO | 3-Wire Serial I/O<br>Mode                          | SBI Mode | 2-Wire Serial I/O<br>Mode | Mode   |
| 0     | 0     | Input clock to SCK pin from off chip               |          |                           | Input  |
| 0     | 1     | Timer/even counter output (TO)                     |          |                           | Output |
| 1     | 0     | $f_{X}/2^{4}$ (262 kHz)* $f_{X}/2^{6}$ (65.5 kHz)* |          |                           |        |
| 1     | 1     | $f_{\chi}/2^3$ (524 kHz)*                          |          |                           |        |

\*: ( ): When  $f_X = 4.19$  MHz

Serial interface operating mode selection bits (W)

| CSIM4 | CSIM3 | CSIM2 | Operating<br>Mode            | Shift Register<br>Bit Order                        | SO Pin<br>Function                           | SI Pin<br>Function                           |
|-------|-------|-------|------------------------------|----------------------------------------------------|----------------------------------------------|----------------------------------------------|
| x     | 0     | 0     | 3-wire<br>serial<br>I/O mode | SIO <sub>7 to 0</sub> ↔ XA<br>(MSB-first transfer) | SO/PO2<br>(CMOS output)                      | SI/PO3<br>(Input)                            |
|       |       | 1     | I/O mode                     | SIO <sub>O to 7</sub> ↔ XA<br>(LSB-first transfer) |                                              |                                              |
| 0     | 1     | 0     | SBI mode                     | SIO <sub>7 to 0</sub> ↔ XA<br>(MSB-first transfer) | SBO/PO2 (N-ch<br>open-drain<br>input/output) | PO3 input                                    |
| 1     |       |       |                              |                                                    | PO2 input                                    | SB1/P03 (N-ch<br>open-drain<br>input/output) |
| 0     | 1     | 1     | 2-wire<br>serial<br>I/O mode | SIO <sub>7 to 0</sub> ↔ XA<br>(MSB-first transfer) | SBO/PO2 (N-ch<br>open-drain<br>input/output) | P03 input                                    |
| 1     |       |       |                              |                                                    | PO2 input                                    | SB1/PO3 (N-ch<br>open-drain<br>input/output) |

Remarks: x: don't care

■ 6427525 0095036 143 ■ 5-81

# Figure 5-33 Serial Operating Mode Register (CSIM) Format (cont'd)

Wake-up function specification bit (W)

|     | 0 IRQCSI set at end of every serial transfer in each mode. |                                                                                                                                                                            |  |  |  |
|-----|------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| WUP | 1                                                          | Used only in SBI mode. IRQCSI is set only when the address received after bus release matches the slave address register data (wake-up status). SBO/SB1 is high impedance. |  |  |  |

NOTE: If WUP = 1 is set during  $\overline{\text{BUSY}}$  signal output,  $\overline{\text{BUSY}}$  is not released. With the SBI, the  $\overline{\text{BUSY}}$  signal is output after the  $\overline{\text{BUSY}}$  release directive until the next fall of the serial clock ( $\overline{\text{SCK}}$ ). When setting WUP = 1, it is necessary to confirm that the SBO (or SB1) pin has been driven high after  $\overline{\text{BUSY}}$  is released before setting WUP = 1.

Signal from address comparator (R)

|      | Clearing Condition (COI = 0)                                                  | Setting Condition (COI = 1)                                            |
|------|-------------------------------------------------------------------------------|------------------------------------------------------------------------|
| COI* | When slave address register (SVA)<br>and shift register data do not<br>match. | When slave address register<br>(SVA) and shift register data<br>match. |

\*: A COI read is valid only before the start of ate completion of a serial transfer. During a transfer an indeterminate value will be read. Also, COI data written by an 8-bit manipulation instruction is ignored.

> ■ 6427525 0095037 08T ■ 5-82

|      |   | Shift Register           | Serial Clock<br>Counter | IRQCSI Flag | SO/SBO & SIO/SB1 Pins                      |
|------|---|--------------------------|-------------------------|-------------|--------------------------------------------|
| GGTE | 0 | Shift operation disabled | Cleared                 | Retained    | Port O function only                       |
| CSIE | 1 | Shift operation enabled  | Count<br>operation      | Settable    | Function in each mode plus port 0 function |

Serial interface operation enable/disable specification bit (W)

Remarks 1: The operating mode can be selected according to the setting of CSIE, CSIM3, and CSIM2.

| CSIE | CSIM3 | CSIM2 | Operating Mode         |
|------|-------|-------|------------------------|
| 0    | x     | x     | Operation-halted mode  |
| 1    | 0     | x     | 3-wire serial I/O mode |
| 1    | 1     | 0     | SBI mode               |
| 1    | 1     | 1     | 2-wire serial I/O mode |

x : don't care

2: The PO1/SCK pin status depends on the setting of CSIE, CSIM1 and CSIM0 as shown below.

| CSIE                            | CSIM1 | CSIMO | PO1/SCK Pin Status                         |
|---------------------------------|-------|-------|--------------------------------------------|
| ö                               | 0     | 0     | Input port                                 |
| 0                               | 0     | 1     | High-level output                          |
| 0                               | 1     | 0     |                                            |
| 0                               | 1     | 1     |                                            |
| 1                               | 0     | 0     | High impedance                             |
| 1                               | 0     | 1     | Serial clock output<br>(high-level output) |
| 1                               | 1     | 0     | (                                          |
| 1                               | 1     | 1     |                                            |
| ■ 6427525 0095038 T16 ■<br>5-83 |       |       |                                            |

- 3: The following procedure should be used to clear CSIE during a serial transfer.
  - Clear the interrupt enable flag (IECSI) to set the interrupt disabled state.
  - 2 Clear CSIE.
  - ③ Clear the interrupt request flag (IRQCSI).
- Example 1: This example selects  $f_X/2^4$  as the serial clock, generates an IRQCSI serial interrupt at the end of each serial transfer, and selects the mode in which serial transfers are performed in the SBI mode with the SBO pin as the serial data bus.

SEL MB15 ; Or CLR1 MBE MOV XA, #10001010B MOV CSIM, XA ; CSIM + 10001010B

2: To enable serial transfers in accordance with the contents of CSIM.

SEL MB15 ; Or CLR1 MBE SET1 CSIE

(2) Serial bus interface control register (SBIC)

The format of the serial bus interface control register (SBIC) is shown in Figure 5-34.

SBIC is an 8-bit register composed of bits which control the serial bus and flags which indicate various statuses of the input data form the serial bus, and is mainly used in the SBI mode.

> ■ 6427525 0095039 952 ■ 5-84

SBIC is manipulated by bit-manipulation instructions; it cannot be manipulated by 4-bit or 8-bit memory manipulation instructions.

Read/write capability differs from bit to bit (see Figure 5-34).

Reset input clears this register to OOH.

- NOTE: In the 3-wire and 2-wire serial I/O modes, only the following bits can be used:
  - Bus release trigger bit (RELT) ... SO latch setting
  - command trigger bit (CMDT) ... SO latch clearing

Figure 5-34 Serial Bus Interface Control Register (SBIC) Format



| Remarks: | (R) :  | Read only          |
|----------|--------|--------------------|
|          | (W) :  | Write only         |
|          | (R/W): | Read/write enabled |

■ 6427525 0095040 674 **■** 5-85

Figure 5-34 Serial Bus Interface Control Register (SBIC) Format (cont'd)

Bus release trigger bit (W)

RELT The bus release signal (REL) trigger output control bit. The SO latch is set (1) by setting this bit (RELT = 1), after which the RELT bit is automatically cleared (0).

NOTE: SBO (or SB1) must not be cleared during a serial transfer: Ensure that it is cleared before a transfer is started or after it is completed.

Command trigger bit (W)

| CMDT | The command signal (CMD) trigger output control bit. The SO      |
|------|------------------------------------------------------------------|
|      | latch is cleared (0) by setting this bit (CMDT = 1), after which |
|      | the CMDT bit is automatically cleared (0).                       |

NOTE: SBO (or SB1) must not be cleared during a serial transfer: Ensure that it is cleared before a transfer is started or after it is completed.

Bus release detection flag (R)

| RELD | Clearing Conditions (RELD = 0)                                                                                                                                                                              | Setting Condition (RELD = 1)                  |
|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------|
|      | <ol> <li>When a transfer start<br/>instruction is executed</li> <li>When RESET is input</li> <li>When CSIE = 0 (see Figure 5-33)</li> <li>When SVA and SIO match when an<br/>address is received</li> </ol> | When the bus release signal (REL) is detected |

■ 6427525 0095041 500 ■ 5-86 Figure 5-34 Serial Bus Interface Control Register (SBIC) Format (cont'd)

Command detection flag (R)

| CMDD | Clearing Conditions (CMDD = 0)                                                                                                                                                                         | Setting Condition (CMDD = 1)                 |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------|
|      | <ol> <li>When a transfer start<br/>instruction is executed</li> <li>When the bus release signal<br/>(REL) is detected</li> <li>When RESET is input</li> <li>When CSIE = 0 (see figure 5-33)</li> </ol> | When the command signal (CMD)<br>is detected |

Acknowledge trigger bit (W)

| ACKT | When ACKT is set after the end of a transfer, ACK is output in                                                                                 |
|------|------------------------------------------------------------------------------------------------------------------------------------------------|
|      | synchronization with the next $\overline{\text{SCK}}$ . After the $\overline{\text{ACK}}$ signal is output, ACKT is automatically cleared (0). |
| 1    | AUNI IS automatically cleared (0).                                                                                                             |

- NOTE 1: ACKT must not be set (1) before completion of a serial transfer or during a transfer.
  - 2: ACKT cannot be cleared by software.
  - 3: When ACKT is set, ACKE should be reset to 0.

Acknowledge enable bit (R/W)

| ACKE | 0 | 0 Disables automatic output of the acknowledge signal (ACK)<br>(output by ACKT is possible). |                                                                                                                             |  |  |  |  |
|------|---|----------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
|      |   | When set before end of transfer                                                              | ACK is output in synchronization with the 9th SCK clock cycle.                                                              |  |  |  |  |
|      | 1 | When set after end of transfer                                                               | $\overline{ACK}$ is output in synchronization with $\overline{SCK}$ immediately after execution of the setting instruction. |  |  |  |  |

6427525 0095042 447 **5-87** 

# Figure 5-34 Serial Bus Interface Control Register (SBIC) Format (cont'd)

## Acknowledge detection flag (R)

| ACKD | Clearing Conditions (ACKD = 0)                                        | Setting Condition (ACKD = 1)                                                                                       |
|------|-----------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------|
|      | <ol> <li>When transfer starts</li> <li>When RESET is input</li> </ol> | When the acknowledge signal $(\overline{ACK})$<br>is detected (Synchronized with<br>the rise of $\overline{SCK}$ ) |

## Busy enable bit (R/W)

| BSYE | 0 | <ol> <li>Disabling of automatic busy signal output</li> <li>Busy signal output is stopped in synchronization with the<br/>fall of SCK immediately after execution of the clearing<br/>instruction.</li> </ol> |
|------|---|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | 1 | The busy signal is output in synchronization with the fall of $\overline{SCK}$ following the acknowledge signal.                                                                                              |

Example 1: To output the command signal.

SEL MB15 ; Or CLR1 MBE SET1 CMDT

2: To test RELD and CMDD, and perform different processing according to the type of receive data. This interrupt routine is only performed when WUP = 1 and there is an address match.

|       | SEL | MB15   |                   |
|-------|-----|--------|-------------------|
|       | SKF | RELD ; | RELD test         |
|       | BR  | ! ADRS |                   |
|       | SKT | CMDD ; | CMDD test         |
|       | BR  | !DATA  |                   |
| CMD : | •   | ;      | Command interpret |
| DATA: | •   | •••• ; | Data processing   |
| ADRS: | •   | ;      | Address decode    |

(3) Shift register (SIO)

The configuration around the shift register is shown in Figure 5-35. SIO is an 8bit register which carries out parallel-to-serial conversion and performs serial transmission/reception (shift operations) in synchronization with the serial clock.

A serial transfer is started by writing data to SIO.

In transmission, the data written to SIO is output to the serial output (SO) or the serial data bus (SBO/ SB1). In reception, data is read into SIO form the serial input (SI) or SBO/SB1.

SIO can be read or written to by an 8-bit manipulation instruction.

If RESET is input during its operation, the value of SIO is indeterminate. If RESET is input in the standby mode, the value of SIO is retained.

The shift operation stops after transmission/ reception of 8 bits.

> 5-89 ■ 6427525 0095044 2ЪТ ■



# Figure 5-35 Configuration around Shift Register

SIO reading and the start of a serial transfer (write) are possible at the following times:

- When the serial interface enable/disable bit (CSIE)
   = 1, except when CSIE is set to "1" after data has been written into the shift register.
- When the serial clock has been masked after an 8bit serial transfer.
- When SCK is high.

Ensure that  $\overline{\text{SCK}}$  is high when data is written to or read from the SIO register.

In the 2-wire serial I/O mode and SBI mode data bus configuration, input pins and output pins have dual functions. Output pins have an N-ch open-drain configuration. Therefore, in a device in which reception is to be performed henceforth FFH should be set in the SIO register.

> 5-90 6427525 0095045 156 🎟

(4) Slave address register (SVA)

SVA is an 8-bit register used by the slave to set the slave address value (its own specification number).

It is a write-only register which is manipulated by an 8-bit manipulation instruction.

After RESET signal input, the value of SVA is indeterminate. However, when RESET is input in the standby mode, the value of SVA is retained.

The two functions of the SVA register are described below.

(a) Slave address detection (SBI mode)

Used when the uPD75336 is connected to the serial bus as a slave device.

The master outputs to its connected slaves a slave address to select a specific slave. If these two data items (the slave address output from the master and the SVA value) are found to match when compared by the address comparator, the relevant slave is determined to have been selected.

At this time, bit 6 (COI) of the serial operating mode register (CSIM) is set to "1".

When an address is received the bus release detection flag (RELD) is cleared (0) if a match is not detected. IRQCSI is set only when a match is detected when WUP = 1. This interrupt request indicates that a communication request has been issued from the master to the uPD75336.

# 5-91 ••• 6427525 0095046 092 🚥

(b) Error detection (2-wire serial I/O mode or SBI mode)

The SVA performs error detection in the following cases:

- When the uPD75336 transmits addresses, commands or data as the master device.
- When the uPD75336 receives data as a slave device.

See 5.6.6 (6) or 5.6.7 (8) "Error detection" for details.

#### 5.6.4 OPERATION-HALTED MODE

The operation-halted mode is used when no serial transfer is performed, allowing power dissipation to be reduced.

In this mode, the shift register does not perform shift operations and can be used as an ordinary 8-bit register.

When the RESET signal is input the operation-halted mode is set. The PO2/SO/SBO and PO3/SI/SB1 pins are fixed as input ports. PO1/SCK can be used as an input port depending on the setting of the serial operating mode register.

[Register setting]

Operation-halted mode setting is performed by the serial operating mode register (CSIM) (see 5.6.3 (1) "Serial operating mode register" for the contents of CSIM).

CSIM is manipulated by 8-bit memory manipulation instructions, but bit manipulation of CSIE is also possible.

# 

|         | Reset input clears this CSIM register to OOH. |       |       |       |       |       |       |       |                                                                                                                                                                                                                                                 |
|---------|-----------------------------------------------|-------|-------|-------|-------|-------|-------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         |                                               | t III | Indio | cates | s bit | ts u  | sed   | in th | ne operation-halted mode.                                                                                                                                                                                                                       |
| Address | 7                                             | 6     | 5     | 4     | 3     | 2     | 1     | 0     | Symbol                                                                                                                                                                                                                                          |
| FEOH    | CSIE,                                         | COI   | WUP   | CSIM4 | CSIM3 | CSIM2 | CSIMI | CSIMO | CSIM                                                                                                                                                                                                                                            |
| -       |                                               |       |       |       |       |       | L     |       | Serial Clock Selection Bits (W)*<br>Serial Interface Operating Mode Selection<br>Bits (W)<br>Wake-Up Function Specification Bit (W)<br>Signal from Address Comparator (R)<br>Serial Interface Operation Enable/Disable<br>Specification Bit (W) |

\*: Allow selection of PO1/SCK pin status.

Remarks: (R): Read only (W): Write only

Serial interface operation enable/disable specification bit (W)

|      |                                    | Shift Register | Serial Clock | IRQCSI   | SO/SBO &                |  |
|------|------------------------------------|----------------|--------------|----------|-------------------------|--|
|      |                                    | Operation      | Counter      | Flag     | SI/SB1 Pins             |  |
| CSIE | CSIE 0 Shift operation<br>disabled |                | Cleared      | Retained | Port 0<br>function only |  |

Serial clock selection bits (W)

The  $PO1/\overline{SCK}$  pin status depends on the CSIMO and CSIM1 settings as shown below.

| CSIM1 | CSIMO | P01/SCK Pin Status |
|-------|-------|--------------------|
| 0     | 0     | High impedance     |
| 0     | 1     | High level         |
| 1     | 0     |                    |
| 1     | 1     |                    |
|       | •     |                    |

6427525 0095048 965 MB 5-93 The following procedure should be used to clear CSIE during a serial transfer.

- Clear the interrupt enable flag (IECSI) to set the interrupt disabled state.
- 2 Clear CSIE.

③ Clear the interrupt request flag (IRQCSI).

5.6.5 3-WIRE SERIAL I/O MODE OPERATION

The 3-wire serial I/O mode allows connection to the system used in the 75X series, uPD7500 series, 78K series, etc.

Communication is performed using three lines: The serial clock (SCK), serial output (SO), and serial input (SI).

Figure 5-36 Example of 3-Wire Serial I/O System Configuration

3-Wire Serial I/0 - 3-Wire Serial I/0

Remarks: A uPD75336 can also be used as the slave CPU.

■ 6427525 0095049 8T1 ■ 5-94

### (1) Register setting

When the device is used in the 3-wire serial I/O mode setting of the following two registers is used:

• Serial operating mode register (CSIM)

- Serial bus interface control register (SBIC)
- (a) Serial operating mode register (CSIM)

When the 3-wire serial I/O mode is used, CSIM is set as shown below (see 5.6.3 (1) "Serial operating mode register" for the contents of CSIM).

CSIM is manipulated by 8-bit memory manipulation instructions. Bit manipulation of bits 7, 6 and 5 is also possible.

Reset input clears the CSIM register to OOH.

Shaded area indicates bits used in the 3-wire serial I/O mode.



Remarks: (R): Read only (W): Write only



## Serial clock selection bits (W)

| CSIM1 | CSIMO | Serial Clock                              | SCK Pin Mode |
|-------|-------|-------------------------------------------|--------------|
| 0     | 0     | Input clock to SCK pin from off chip      | Input        |
| 0     | 1     | Timer/event counter output (TO)           | Output       |
| 1     | 0     | f <sub>X</sub> /2 <sup>4</sup> (262 kHz)* |              |
| 1     | 1     | $f_{X}/2^{3}$ (524 kHz)*                  |              |

\*: ( ): When  $f_X = 4.19$  MHz

Serial interface operating mode selection bits (W)

| CSIM4 | CSIM3 | CSIM2 | Shift Register Bit<br>Order                          | SO Pin<br>Function         | SI Pin<br>Function |
|-------|-------|-------|------------------------------------------------------|----------------------------|--------------------|
| x     | 0     | 0     | SIO 7 to 0 $\leftrightarrow$ XA (MSB-first transfer) | SO/PO2<br>(CMOS<br>output) | SI/PO3<br>(Input)  |
|       |       | 1     | SIO 0 to 7 $\leftrightarrow$ XA (LSB-first transfer) |                            |                    |

Remarks: x: don't care

Wake-up function specification bit (W)

0

IRQCSI set at end of every serial transfer.

Signal from address comparator (R)

| COI* | Clearing Condition (COI = 0)                                                  | Setting Condition (COI = 1)                                            |
|------|-------------------------------------------------------------------------------|------------------------------------------------------------------------|
|      | When salve address register<br>(SVA) and shift register<br>data do not match. | When slave address register<br>(SVA) and shift register<br>data match. |

■ 6427525 0095051 45T ■ 5-96

\*: A COI read is valid only before the start or after completion of a serial transfer. During a transfer an indeterminate value will be read. Also, COI data written by an 8-bit manipulation instruction is ignored.

Serial interface operation enable/disable specification bit (W)

|        |  | Shift Register             | Serial Clock       | IRQCSI   | SO/SBO &                                            |
|--------|--|----------------------------|--------------------|----------|-----------------------------------------------------|
|        |  | Operation                  | Counter            | Flag     | SI/SB1 Pins                                         |
| CSIE 1 |  | Shift operation<br>enabled | Count<br>operation | Settable | Function in<br>each mode<br>plus port 0<br>function |

(b) Serial bus interface control register (SBIC)

When the 3-wire serial I/O mode is used, SBIC is set as shown below (see 5.6.3 (2) "Serial bus interface control register" for the contents of SBIC).

SBIC is manipulated by bit manipulation instructions.

Reset input clears the SBIC register to OOH.

Shaded area indicates bit s used in the 3-wire serial I/O mode.



Remarks: (W): Write only

🔳 6427525 0095052 396 📖 5-97

Bus release trigger bit (W)

RELT The bus release signal (REL) trigger output control bit. The SO latch is set (1) by setting this bit (RELT = 1), after which the RELT bit is automatically cleared (0).

Command trigger bit

| CMDT | The command signal (CMD) trigger output control bit. The |
|------|----------------------------------------------------------|
|      | SO latch is cleared (0) by setting this bit (CMDT = 1),  |
|      | after which the CMDT bit is automatically cleared (0).   |

- NOTE: Bits other than RELT and CMDT should not be used in the 3-wire serial I/O mode.
  - (2) Communication operation

In the 3-wire serial I/O mode, data transmission/ reception is performed in 8-bit units. Data is transmitted/received bit by bit in synchronization with the serial clock.

Shift register shift operations are performed in synchronization with the fall of the serial clock  $(\overline{SCK})$ . Then send data is held in the SO latch and output for the SO pin. Also, receive data input to the SI pin is latched in the shift register on the rise of  $\overline{SCK}$ .

At the end of an 8-bit transfer the operation of the shift register stops automatically and the IRQCSI interrupt request flag is set.

■ 6427525 0095053 222 ■ 5-98



The SO pin becomes a CMOS output and outputs the SO latch status, and thus the SO pin output status can be manipulated in accordance with the setting of the RELT bit and CMDT bit.

However, manipulation should not be performed during a serial transfer.

The SCK pin output level is controlled by manipulating the PO1 output latch in the output mode (internal system clock mode) (see 5.6.8 "SCK PIN OUTPUT MANIPULATION").

# Figure 5-37 3-Wire Serial I/O Mode Timing



# (3) Serial clock selection

Serial clock selection is performed by setting bits 0 and 1 of the serial operating mode register (CSIM). Any of the following 4 clocks can be selected.

Table 5-8 Serial Clock Selection and Use (In 3-Wire Serial I/O Mode)

| ·             |           |                                |                                                                         |                                  |                                                                 |                                                                  |  |
|---------------|-----------|--------------------------------|-------------------------------------------------------------------------|----------------------------------|-----------------------------------------------------------------|------------------------------------------------------------------|--|
| Mode Register |           | Serial Clock                   |                                                                         | Possible Timing for              |                                                                 |                                                                  |  |
| CSIM<br>1     | CSIM<br>O | Source                         | Serial Clock<br>Mask                                                    | Shift Register R/W and<br>Serial |                                                                 | Use                                                              |  |
| 0             | 0         | Ex-<br>ternal<br>SCK           | Automatically<br>masked at end<br>of 8-bit data<br>transfer. (2)<br>(3) |                                  | In operation-<br>halted mode (CSIE<br>= 0)<br>When serial clock | Slave CPU                                                        |  |
| 0             | 1         | TOUT<br>F/F                    |                                                                         | _                                | is masked after<br>end of 8-bit<br>serial transfer              | Half-duplex<br>asynchronous<br>transfer<br>(software<br>control) |  |
| 1             | 0         | f <sub>X</sub> /2 <sup>+</sup> |                                                                         |                                  | Medium-speed<br>serial<br>transfer<br>(software<br>control)     |                                                                  |  |
| 1             | 1         | f <sub>X</sub> /2 <sup>3</sup> |                                                                         |                                  |                                                                 | High-speed<br>serial<br>transfer                                 |  |

# (4) Signals

RELT and CMDT operation is shown in Figure 5-38.

Figure 5-38 RELT & CMDT Operation



## (5) MSB/LSB-first switching

The 3-wire serial I/O mode includes a function for selecting MSB-first or LSB-first transfer.

Figure 5-39 shows the shift register (SIO) and internal bus configuration. As shown in Figure 5-39, reading/writing can be performed by inverting the MSB/LSB.

MSB/LSB-first switching can be specified by bit 2 of the serial operating mode register (CSIM).



Figure 5-39 Transfer Bit Switching Circuit

Start bit switchover is implemented by switching the order in which data bits are written to the shift register (SIO). The SIO shift order is always the same.

Therefore, MSB/LSB start bit switching must be performed before writing data to the shift register.

5-101 ■ 6427525 0095056 T31 ■

### (6) Start of transfer

When the following two conditions are met a serial transfer is started by setting transfer data in the shift register (SIO).

- The serial interface operation enable/disable bit (CSIE) = 1.
- After an 8-bit serial transfer, the internal serial clock is stopped or SCK is high.
  - NOTE: The transfer will not be started if CSIE is set to "1" after data is written into the shift register.

When an 8-bit transfer ends, the serial transfer stops automatically and the IRQCSI interrupt request flag is set.

Example: In the following example the data in the RAM specified by the HL register is transferred to SIO, and at the same time the SIO data is fetched into the accumulator and the serial transfer is started.

> MOV XA, @HL; Fetch send data from RAM SEL MB15 ; Or CLR1 MBE XCH XA, SIO; Exchange send data with receive data and start transfer

5-102 ■ 6427525 0095057 978 ■

- (7) 3-wire serial I/O mode applications
  - Example 1: To transfer data MSB-first (master operation) using a 262 kHz transfer clock (when operating at 4.19 MHz). <Sample program>

| CLR1 | MBE                           |
|------|-------------------------------|
| MOV  | XA, #10000010B                |
| MOV  | CSIM, XA ; Transfer mode      |
|      | setting                       |
| MOV  | XA, TDATA ; TDATA is transfer |
|      | data storage                  |
|      | address                       |
| MOV  | SIO, XA ; Transfer data       |
|      | setting & start of            |
|      | transfer                      |

NOTE: From the second time onward, the transfer can be started by setting data in SIO (MOV SIO, XA or XCH XA, SIO).



In this application the uPD75336 SI/SB1 pin can be for input.

# 6427525 0095058 804 MM 5-103

Example 2: To transmit/receive LSB-first data using an external clock (slave operation). (In this case the function for reversing the MSB and LSB in shift register read/write operation is used.)



<Sample program>

Main Routine

CLR1 MBE MOV XA, #84H MOV CSIM, XA ; Serial operation stopped, MSB/LSB inversion mode, external clock MOV XA, TDATA MOV SIO, XA ; Transfer data setting & start of transfer EI IECSI ΕI Interrupt Routine (MBE = 0) MOV XA, TDATA XCH XA, SIO ; Receive data setting & start of transfer MOV RDATA, XA; Receive data save RETI

∎ 6427525 0095059 740 🔳 5-104

Example 3: To transmit/receive data at high speed using a 524 kHz transfer clock (when operating at 4.19 MHz).



<Program example> ··· Master side

|       | CLR1   | MBE            |   |           |
|-------|--------|----------------|---|-----------|
|       | MOV    | XA, #10000011B |   |           |
|       | MOV    | CSIM, XA       | ; | Transfer  |
|       | ·      |                | • | mode      |
|       |        |                |   | setting   |
|       | MOV    | XA, TDATA      |   |           |
|       | MOV    | SIO, XA        | ; | Transfer  |
|       |        |                |   | data      |
|       |        |                |   | setting & |
|       | •      |                |   | start of  |
|       |        |                |   | transfer  |
|       | :      |                |   |           |
|       | :      |                |   |           |
|       | :      |                |   |           |
| LOOP: | SKTCLR | IRQCSI         | ; | IRQCSI    |
|       |        |                |   | test      |
|       | BR     | LOOP           |   |           |
|       | MOV    | XA, SIO        | ; | Receive   |
|       |        |                |   | data      |

5.6.6 2-WIRE SERIAL I/O MODE OPERATION

The 2-wire serial I/O mode allows adaptation by means of the program to any communication format.

 Communication is basically performed using two lines: The serial clock ( $\overline{SCK}$ ) and serial data input/output (SBO or SB1).

Figure 5-40 Example of 2-Wire Serial I/O System Configuration

2-Wire Serial I/C ++ 2-Wire Serial I/O



Remarks: A uPD75336 can also be used as the slave CPU.

(1) Register setting

When the device is used in the 2-wire serial I/O mode setting of the following two registers is used:

- Serial operating mode register (CSIM)
- Serial bus interface control register (SBIC)

(a) Serial operating mode register (CSIM)

When the 2-wire serial I/O mode is used, CSIM is set as shown below (see 5.6.3 (1) "Serial operating mode register" for the contents of CSIM).

■ 6427525 0095061 3T9 ■ 5-106 CSIM is manipulated by 8-bit memory manipulation instructions. Bit manipulation of bits 7, 6 and 5 is also possible.

Reset input clears the CSIM register to OOH.

Shaded area indicates bits used in the 2-wire serial I/O mode.



Remarks: (R): Read only (W): Write only

Serial clock selection bits (W)

| CSIM1 | CSIMO | Serial Clock                               | SCK Pin Mode |
|-------|-------|--------------------------------------------|--------------|
| 0     | 0     | Input clock to SCK pin from off chip       | Input        |
| 0     | 1     | Timer/event counter output (TO)            | Output       |
| 1     | 0     | f <sub>X</sub> /2 <sup>6</sup> (65.5 kHz)* |              |
| 1     | 1     |                                            |              |

\*: ( ): When  $f_X = 4.19$  MHz

# 6427525 0095062 235 **5-**107

| CSIM4 | СЗІМЗ | CSIM2 | Shift Register Bit<br>Order             | SO Pin<br>Function                                    | SI Pin<br>Function                                    |
|-------|-------|-------|-----------------------------------------|-------------------------------------------------------|-------------------------------------------------------|
| 0     | 1     | 1     | SIO 7 to 0 ↔ XA<br>(MSB-first transfer) | SBO/PO2<br>N-ch<br>open-<br>drain<br>input/<br>output | P03<br>input                                          |
| 1     |       |       |                                         | PO2<br>input                                          | SB1/P03<br>N-ch<br>open-<br>drain<br>input/<br>output |

Serial interface operating mode selection bits (W)

Wake-up function specification bit (W)

| WUP | 0 | IRQCSI | set | at | end | of | every | serial | transfer. |  |
|-----|---|--------|-----|----|-----|----|-------|--------|-----------|--|
|     |   |        |     |    |     |    |       |        |           |  |

Signal from address comparator (R)

| COI* | Clearing Condition (COI = 0)                                                  | Setting Condition (COI = 1)                                            |
|------|-------------------------------------------------------------------------------|------------------------------------------------------------------------|
|      | When salve address register<br>(SVA) and shift register<br>data do not match. | When slave address register<br>(SVA) and shift register<br>data match. |

\*: A COI read is valid only before the start or after completion of a serial transfer. During a transfer an indeterminate value will be read. Also, COI data written by an 8-bit manipulation instruction is ignored.

> ■ 6427525 0095063 171 ■ 5-108

Serial interface operation enable/disable specification bit (W)

|        | Shift Register             | Serial Clock       | IRQCSI   | SO/SBO &                                            |  |
|--------|----------------------------|--------------------|----------|-----------------------------------------------------|--|
|        | Operation                  | Counter            | Flag     | SI/SB1 Pins                                         |  |
| CSIE 1 | Shift operation<br>enabled | Count<br>operation | Settable | Function in<br>each mode<br>plus port 0<br>function |  |

(b) Serial bus interface control register (SBIC)

When the 2-wire serial I/O mode is used, SBIC is set as shown below (see 5.6.3 (2) "Serial bus interface control register" for the contents of SBIC).

SBIC is manipulated by bit manipulation instructions.

Reset input clears the SBIC register to OOH.

Shaded area indicates bit s used in the 2-wire serial I/O mode.

| Address | s 7  | 6              | 5    | 4    | З      | 2      | 1    | 0      | Symbol      |  |     |
|---------|------|----------------|------|------|--------|--------|------|--------|-------------|--|-----|
| FE2H    | BSYE | ACKD           | ACKE | ACKT | CMDI   | DRELD  | CMDT | 1.1764 | SBIC        |  |     |
|         |      | ould I<br>rial |      |      | l in : | 2-Wire |      |        | Bus Release |  | (W) |

Remarks: (W): Write only

Bus release trigger bit (W)

RELT The bus release signal (REL) trigger output control bit. The SO latch is set (1) by setting this bit (RELT = 1), after which the RELT bit is automatically cleared (0).

5-109 🛚 6427525 0095064 008 🖿

Command trigger bit

CMDT The command signal (CMD) trigger output control bit. The SO latch is cleared (0) by setting this bit (CMDT = 1), after which the CMDT bit is automatically cleared (0).

- NOTE: Bits other than RELT and CMDT should not be used in the 2-wire serial I/O mode.
  - (2) Communication operation

In the 2-wire serial I/O mode, data transmission/ reception is performed in 8-bit units. Data is transmitted/received bit by bit in synchronization with the serial clock.

Shift register shift operations are performed in synchronization with the fall of the serial clock  $(\overline{\text{SCK}})$ . Then send data is held in the SO latch and output MSB-first from the SB0/P02 (or SB1/P03) pin. Also, receive data input to the SB0 (or SB1) pin is latched in the shift register on the rise of  $\overline{\text{SCK}}$ .

At the end of an 8-bit transfer the operation of the shift register stops automatically and the IRQCSI interrupt request flag is set.



Since the pin specified as the SBO (or SB1) pin serial data bus is an N-ch open-drain input/output, it must be pulled high externally. Also, since the N-ch transistor must be turned off during data reception, FFH is written to SIO beforehand.

Since the SBO (or SB1) pin outputs the SO latch status, the SBO (or SB1) pin output status can be manipulated in accordance with the setting of the RELT bit and CMDT bit.

However, manipulation should not be performed during a serial transfer.

The SCK pin output level is controlled by manipulating the PO1 output latch in the output mode (internal system clock mode) (see 5.6.8 "SCK Pin Output Manipulation").

#### ■ 6427525 0095066 980 ■ 5-111

(3) Serial clock selection

Serial clock selection is performed by setting bits 0 and 1 of the serial operating mode register (CSIM). Any of the following 3 clocks can be selected.

Table 5-9 Serial Clock Selection and Use (In 2-Wire Serial I/O Mode)

| Mode I    | Register  | S                              | erial Clock                                                 | Possible Timing for                                                                                |                                        |  |  |
|-----------|-----------|--------------------------------|-------------------------------------------------------------|----------------------------------------------------------------------------------------------------|----------------------------------------|--|--|
| CSIM<br>1 | CSIM<br>O | Source                         | Serial Clock<br>Mask                                        | Shift Register R/W and<br>Serial                                                                   | Use                                    |  |  |
| 0         | 0         | Ex-<br>ternal<br>SCK           | Automatically<br>masked at end<br>of 8-bit data<br>transfer | <ol> <li>In operation-<br/>halted mode (CSIE<br/>= 0)</li> <li>When serial clock</li> </ol>        | Slave CPU                              |  |  |
| 0         | 1         | TOUT<br>F/F                    | transfer.                                                   | <ul> <li>is masked after<br/>end of 8-bit<br/>serial transfer</li> <li>When SCK is high</li> </ul> | Arbitrary-<br>speed serial<br>transfer |  |  |
| 1         | 0         | f <sub>X</sub> /2 <sup>6</sup> |                                                             | () when sok is high                                                                                | Low-speed<br>serial                    |  |  |
| 1         | 1         |                                |                                                             |                                                                                                    | transfer                               |  |  |

(4) Signals

RELT and CMDT operation is shown in Figure 5-42.

#### Figure 5-42 RELT & CMDT Operation



#### (5) Start of transfer

When the following two conditions are met a serial transfer is started by setting transfer data in the shift register (SIO).

- The serial interface operation enable/disable bit (CSIE) = 1.
- After an 8-bit serial transfer, the internal serial clock is stopped or SCK is high.
  - NOTE 1: The transfer will not be started if CSIE is set to "1" after data is written into the shift register.
    - 2: Since the N-ch transistor must be turned off during data reception, FFH should be written to SIO beforehand.

When an 8-bit transfer ends, the serial transfer stops automatically and the IRQCSI interrupt request flag is set.

#### (6) Error detection

In the 2-wire serial I/O mode, since the status of the serial bus SBO/SB1 pin during transmission is also written into the SIO shift register of the transmitting device, transmission errors can be detected in the following ways:

(a) Comparison of pre-transmission and posttransmission SIO data

In this case, a transmission error is judged to have been generated if the two data items are different.

■ 6427525 0095068 753 ■ 5-113 (b) Use of slave address register (SVA)

Transmission is performed after setting the send data in the SIO and SVA registers. After transmission the COI bit of the serial operating mode register (CSIM) (the match signal from the address comparator) is tested: "1" indicates normal transmission, and "0", a transmission error.

(7) 2-wire serial I/O mode applications

A serial bus is configured and multiple devices connected.

Example: Top configure a system with a uPD75336 as the master and a uPD75104, uPD75402A and uPD7225G connected as slaves.



The uPD75104 is connected via the SI pin and SO pin. When serial data is not being output the serial operating mode register is manipulated and the output buffer turned off to release the bus.

Since the uPD75402A SO pin cannot be placed in the high impedance state, it should be made an open collector output by connecting a transistor as shown in the figure. Then, when data is input the transistor is turned off by writing OOH to the shift register beforehand.

Which microcomputer outputs data when is determined in advance.

The serial clock is output by the uPD75336, which is the master microcomputer, and the other slave microcomputers all operate on an external clock.

#### 5.6.7 SBI MODE OPERATION

The SBI (serial bus interface) is a high-speed serial interface which conforms to NEC serial bus format.

The SBI is a single-master high-speed serial bus. Its format includes the addition of bus configuration functions to the clocked serial I/O system to enable communication to be performed with multiple devices using two signal lines. Consequently, when a serial bus is configured with multiple microcomputers and peripheral ICs, it is possible to reduce the number of ports used and the amount of wiring on the substrate.

> ■ 6427525 0095070 301 ■ 5-115

The master can output to a slave on the serial data bus an address to select the target device for serial communication, a command which gives a directive to the target device, and actual data. The slave can determine by hardware whether the received data is an address, command or actual data. This function allows the serial interface control portion of the application program to be simplified.

SBI functions are incorporated in number of devices including the 75% series, and 78% series 8/16-bit single-chip microcomputers.

An example of a serial bus configuration when CPUs and peripheral ICs with a serial interface conforming to the SBI are used is shown in Figure 5-43.

In the SBI the SBO (SB1) serial data bus pin is an opendrain output and thus the data bus line is in the wired-OR state. The serial data bus line requires a pull-up resistor.

## ■ 6427525 0095071 248 ■ 5-116

Figure 5-43 Example of SBI Serial Bus Configuration



NOTE: When master/slave exchange processing is performed, since serial clock line (SCK) input/output switching is performed asynchronously between master and slave, a pull-up resistor is also required for the serial clock line (SCK).

#### (1) SBI functions

Since conventional serial I/O methods have only data transfer functions, when a serial bus is configured with multiple devices connected a large number of ports and wires are required for Chip Select signal and command/data differentiation, busy status recognition, etc. If these controls re performed by software, the load incurred by software is very large.

> ■ 6427525 0095072 184 ■ 5-117

With the SBI, a serial bus can be configured using only two lines: The serial clock,  $\overline{SCK}$ , and the serial data bus, SBO (SB1). As a result, the number of microcomputer ports and the amount f substrate wiring can be significantly reduced.

SBI functions are described below.

(a) Address/Command/data differentiation function

Identifies serial data as an address, command or actual data.

(b) Chip selection by address

The master performs chip selection by address transmission.

(C) Wake-up function

A slave can identify address reception (chip selection) easily by means of the wake-up function (settable/releasable by software).

When the wake-up function is set, an interrupt (IRQCSI) is generated when a matching address is received.

As a result, non-selected CPUs can operate without regard to serial communications even when communication with multiple devices is performed.

(d) Acknowledge signal (ACK) control function

Controls the acknowledge signal used to confirm serial data reception.

■ 6427525 0095073 010 ■ 5-118 (e) Busy signal (BUSY) control function

Controls the busy signal used to give notification of a slave busy status.

(2) SBI definition

The SBI serial data format and the meaning of the signals used are explained in the following section.

Serial data transmitted via the SBI is classified into three types: Commands, addresses and data.

Address, command and data timing is shown in Figure 5-44.



Figure 5-44 SBI Transfer Timing

Address Transfer

The bus release signal and command signal are output by the master. The  $\overline{\text{BUSY}}$  signal is output by the slave.  $\overline{\text{ACK}}$  can be output by either the master or slave (normally output by the 8-bit data receiver).

The serial clock is output by the master continuously from the start of an 8-bit data transfer until  $\overline{\text{BUSY}}$  is released.

(a) Bus release signal (REL)

The bus release signal indicates that the SBO (SB1) line has changed from low to high when the  $\overline{\text{SCK}}$  line is high (when the serial clock is not being output). This signal is output by the master.

Figure 5-45 Bus Release Signal



The bus release signal indicates that the master is about to send an address to a slave. Slaves incorporate hardware to detect the bus release signal.

(b) Command signal (CMD)

The command signal indicates that the SBO (SB1) line has changed for high to low when the  $\overline{SCK}$  line is high (when the serial clock is not being output). This signal is output by the master.

■ 6427525 0095075 993 ■ 5-120

#### Figure 5-46 Command Signal



Slaves incorporate hardware to detect the bus release signal.

(c) Address

An address is 8-bit data output by the master to slaves connected to the bus line in order to select a particular slave.

Figure 5-47 Address



The 8-bit data following the bus release signal and command signal is defined as an address. In a slave this condition is detected by hardware and a check is performed by hardware to see if the 8-bit data matches the slave's own specification number (slave address). If the 8-bit data matches the slave address, that slave is determined to have been selected and communication is subsequently performed with the master until a disconnect directive is received from the master.

■ 6427525 0095076 82T ■ 5-121 Figure 5-48 Slave Selection by Address



(d) Command & data

The master sends a command or data to the slave selected by address transmission.

Figure 5-49 Command







The 8-bit data following the command signal is defined as a command. 8-bit with no command signal is defined as data. The way in which commands and data are used can be freely decided according to the communication specifications.

■ 6427525 0095077 766 ■ 5-122

#### (e) Acknowledge signal( $\overline{ACK}$ )

The acknowledge signal is used to confirm serial data reception between the sender and receiver.

Figure 5-51 Acknowledge Signal

[When output in synchronization with 11th SCK clock cycle]



[When output in synchronization with 9th SCK clock cycle]

SBO (SB1)

SCK

ACK

The acknowledge signal is a one-shot pulse synchronized with the fall of SCK after an 8bit data transfer. Its position is arbitrary and it can be synchronized with any SCK clock cycle.

After 8-bit data transmission the sender checks whether the receiver has sent back an acknowledge signal. If an acknowledge signal is not returned within a specific time after data transmission, reception can be judged not to have been performed correctly.

(f) Busy signal (BUSY), ready signal (READY)

The busy signal notifies the master that a slave is preparing for data transmission/ reception.

🖬 6427525 0095078 6T2 📰 5 - 123

The ready signal notifies the master that a slave is ready for data transmission/reception.

Figure 5-52 Busy Signal & Ready Signal



With the SBI a slave reports its busy status to the master by driving the SBO (SB1) line low.

The busy signal is output following the acknowledge signal output by the master or slave. Busy signal setting/release is performed in synchronization with the fall of SCK. When the busy signal is released the master automatically terminates output of the SCK serial clock.

When he busy signal is released and the ready signal state is entered the master can start the next transfer.

#### (3) Register setting

When the device is used in the SBI mode, setting of the following two registers is used:

- Serial operating mode register (CSIM)
- Serial bus interface control register (SBIC)
- (a) Serial operating mode register (CSIM)

When the SBI mode is used, CSIM is set as shown below (see 5.6.3 (1) "Serial operating mode register" for the contents of CSIM). ■ 6427525 0095079 539 ■ 5-124 CSIM is manipulated by 8-bit memory manipulation instructions. Bit manipulation of bits 7, 6 and 5 is also possible.

Reset input clears the CSIM register to OOH.

Shaded area indicates bits used in the SBI mode.



Remarks: (R): Read only (W): Write only

Serial clock selection bits (W)

| CSIM1 | CSIMO | Serial Clock                         | SCK Pin Mode |
|-------|-------|--------------------------------------|--------------|
| 0     | 0     | Input clock to SCK pin from off chip | Input        |
| 0     | 1     | Timer/event counter output (TO)      | Output       |
| 1     | 0     | $f_{X}^{/2^{+}}$ (262 kHz)*          |              |
| 1     | 1     | $f_{\rm X}^{2^3}$ (524 kHz)*         |              |

\*: (): When  $f_{\chi} = 4.19$  MHz

#### L 6427525 0095080 250 ■ 5-125

Serial interface operating mode selection bits (W)

| CSIM4 | СЗІМЗ | CSIM2 | Shift Register Bit<br>Order             | SO Pin<br>Function                                    | SI Pin<br>Function                                    |
|-------|-------|-------|-----------------------------------------|-------------------------------------------------------|-------------------------------------------------------|
| 0     | 1     | 0     | SIO 7 to 0 ↔ XA<br>(MSB-first transfer) | SB0/P02<br>N-ch<br>open-<br>drain<br>input/<br>output | PO3<br>input                                          |
| 1     |       |       | •                                       | P02<br>input                                          | SB1/P03<br>N-ch<br>open-<br>drain<br>input/<br>output |

Wake-up function specification bit (W)

| WUP | 0 | IRQCSI set at end of every serial transfer with mask state of SBI mode.                                                                                                                   |
|-----|---|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     | 1 | Used only slave in SBI mode. IRQCSI is set only when<br>the address received after bus release matches the<br>slave address register data (wake-up status). SBO/SB1<br>is high impedance. |

NOTE: If WUP = 1 is set during BUSY signal output, BUSY is not released. With the SBI, the BUSY signal is output after the BUSY release directive until the next fall of the serial clock (SCK). When setting WUP = 1, it is necessary to confirm that the SBO (or SB1) pin has been driven high after BUSY is released before setting WUP = 1.

> ■ 6427525 0095081 197 ■ 5-126

Signal from address comparator (R)

| COI* | Clearing Condition (COI = 0)                                                  | Setting Condition (COI = 1)                                            |
|------|-------------------------------------------------------------------------------|------------------------------------------------------------------------|
|      | When slave address register<br>(SVA) and shift register<br>data do not match. | When slave address register<br>(SVA) and shift register<br>data match. |

\*: A COI read is valid only before the start or after completion of a serial transfer. During a transfer an indeterminate value will be read. Also, COI data written by an 8-bit manipulation instruction is ignored.

Serial interface operation enable/disable specification bit (W)

|        | Shift Register             | Serial Clock       | IRQCSI   | SO/SBO &                                            |  |
|--------|----------------------------|--------------------|----------|-----------------------------------------------------|--|
|        | Operation                  | Counter            | Flag     | SI/SB1 Pins                                         |  |
| CSIE 1 | Shift operation<br>enabled | Count<br>operation | Settable | Function in<br>each mode<br>plus port 0<br>function |  |

(b) Serial bus interface control register (SBIC)

When the SBI mode is used, SBIC is set as shown below (see 5.6.3 (2) "Serial bus interface control register" for the contents of SBIC).

SBIC is manipulated by bit manipulation instructions.

Reset input clears the SBIC register to OOH.

Shaded area indicates bits used in the SBI mode.

6427525 0095082 023 5-127



Remarks: (R) : Read only
 (W) : Write only
 (R/W): Read/write enabled

Bus release trigger bit (W)

|  | The bus release signal (REL) trigger output control bit.<br>The SO latch is set (1) by setting this bit (RELT = 1),<br>after which the RELT bit is automatically closed (2). |
|--|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|  | after which the RELT bit is automatically cleared (0).                                                                                                                       |

NOTE: SBO (or SB1) must not be cleared during a serial transfer: Ensure that it is cleared before a transfer is started or after it is completed.

Command trigger bit (W)

CMDT The command signal (CMD) trigger output control bit. The SO latch is cleared (0) by setting this bit (CMDT = 1), after which the CMDT bit is automatically cleared (0).

NOTE: SB0 (or SB1) must not be cleared during a serial transfer: Ensure that it is cleared before a transfer is started or after it is completed.

■ 6427525 0095083 TLT ■ 5-128

#### Bus release detection flag (R)

| RELD | Clearing Conditions (RELD = 0)                                                                                                                                                                              | Setting Condition<br>(RELD = 1)                     |
|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------|
|      | <ol> <li>When a transfer start instruction<br/>is executed</li> <li>When RESET is input</li> <li>When CSIE = 0 (see Figure 5-33)</li> <li>When SVA and SIO match when an<br/>address is received</li> </ol> | When the bus<br>release signal<br>(REL) is detected |

Command detection flag (R)

| CMDD | Clearing Conditions (CMDD = $0$ )                                                                                                                                                                      | Setting Condition<br>(CMDD = 1) |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------|
|      | <ol> <li>When a transfer start instruction<br/>is executed</li> <li>When the bus release signal (REL)<br/>is detected</li> <li>When RESET is input</li> <li>When CSIE = 0 (see Figure 5-33)</li> </ol> | signal (CMD) is                 |

Acknowledge trigger bit (W)

| ACKT | When ACKT is set after the end of a transfer, ACK is     |
|------|----------------------------------------------------------|
|      | output in synchronization with the next SCK. After the   |
|      | ACK signal is output, ACKT is automatically cleared (0). |

NOTE 1: ACKT must not be set (1) before completion of a serial transfer or during a transfer.

- 2: ACKT cannot be cleared by software.
- 3: When ACKT is set, ACKE should be reset to 0.

■ 6427525 0095084 9T6 ■ 5-129

## Acknowledge enable bit (R/W)

| ACKE | 0 | Disables automat<br>(output by ACKT | ic output of the acknowledge signal is possible).                                                                                               |
|------|---|-------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
|      | 1 | When set before<br>end of transfer  | The $\overline{ACK}$ signal is output in synchronization with the 9th $\overline{SCK}$ clock cycle.                                             |
|      |   | When set after<br>end of transfer   | The $\overline{ACK}$ signal is output in<br>synchronization with $\overline{SCK}$ immediately<br>after execution of the setting<br>instruction. |

# Acknowledge detection flag (R)

| ACKD |    | Clearing Conditions<br>(ACKD = 0)           | Setting Condition<br>(ACKD = 1)                                                            |  |  |  |
|------|----|---------------------------------------------|--------------------------------------------------------------------------------------------|--|--|--|
|      | 00 | When transfer starts<br>When RESET is input | When the acknowledge signal<br>(ACK) is detected<br>(synchronized with the rise<br>of SCK) |  |  |  |

Busy enable bit (R/W)

| BSYE | 0 | <ul> <li>Disabling of automatic busy signal output</li> <li>Busy signal output is stopped in synchronization<br/>with the fall of SCK immediately after execution<br/>of the clearing instruction.</li> </ul> |
|------|---|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | 1 | The busy signal is output in synchronization with the fall of SCK following the acknowledge signal.                                                                                                           |

(4) Serial clock selection

Serial clock selection is performed by setting bits 0 and 1 of the serial operating mode register (CSIM). Any of the following 4 clocks can be selected.

#### ын 6427525 0095085 832 нн 5-130

| Table 5-10 | Serial | Clock | Selection | and | Use | (In | SBI | Mode) | ) |
|------------|--------|-------|-----------|-----|-----|-----|-----|-------|---|
|------------|--------|-------|-----------|-----|-----|-----|-----|-------|---|

| Mode 1    | Mode Register |                                | erial Clock                                                                 | Possible Timing for                                             |                                                    |                                        |  |
|-----------|---------------|--------------------------------|-----------------------------------------------------------------------------|-----------------------------------------------------------------|----------------------------------------------------|----------------------------------------|--|
| CSIM<br>1 | CSIM<br>O     | Source                         | Serial Clock<br>Mask                                                        |                                                                 | t Register R/W and<br>Serial                       | Use                                    |  |
| 0         | 0             | Ex-<br>ternal<br>SCK           | Automatically (1)<br>masked at end<br>of 8-bit data<br>transfer. (2)<br>(3) | In operation-<br>halted mode (CSIE<br>= 0)<br>When serial clock | Slave CPU                                          |                                        |  |
| 0         | 1             | TOUT<br>F/F                    |                                                                             |                                                                 | is masked after<br>end of 8-bit<br>serial transfer | Arbitrary-<br>speed serial<br>transfer |  |
| 1         | 0             | f <sub>X</sub> /2*             |                                                                             | 9                                                               | When SCK is high                                   | Medium-speed<br>serial<br>transfer     |  |
| 1         | 1             | f <sub>X</sub> /2 <sup>3</sup> |                                                                             |                                                                 |                                                    | High-speed<br>serial<br>transfer       |  |

When the internal system clock is selected  $\overline{SCK}$  stops at 8 pulses internally, bit externally the count continues until the slave is in the ready state.

(5) Signals

The operation of signals and flags in SBIC in the SBI mode are shown in Figures 5-53 to 5-58, and SBI signals are listed in Table 5-11.

🔲 6427525 0095086 779 🔜 5-131



Figure 5-53 RELT, CMDT, RELD & CMDD Operation (Master)

NOTE: ACKT must not be set before the end of a transfer.

#### Figure 5-56 ACKE Operation

a. When ACKE = 1 on completion of transfer



**5-13**3

#### Figure 5-57 ACKD Operation



a. When  $\overline{ACK}$  signal is output in 9th  $\overline{SCK}$  clock interval

b. When ACK signal is output after 9th SCK clock interval



c. Clearing timing when transfer start directive is given during BUSY state







Table 5-11 Various Signals in SBI Mode

| Meaning of<br>Signal | Outputs<br>next CMD<br>signal and<br>indicates<br>send data<br>is address. | <ul> <li>i)</li> <li>After REL</li> <li>signal</li> <li>output</li> <li>send data</li> <li>is address.</li> <li>i)</li> <li>Send data</li> <li>with no</li> <li>REL signal</li> <li>output is</li> <li>command.</li> </ul> | (to be continued) |
|----------------------|----------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|
| Effects on<br>Flags  | . RELD set<br>. CMDD clear                                                 | . CMDD set                                                                                                                                                                                                                 | (to be c          |
| Output<br>Conditions | . RELT set                                                                 | . CMDT set                                                                                                                                                                                                                 |                   |
| Timing Chart         | SB0/SB1                                                                    | SB0/SB1 H"                                                                                                                                                                                                                 |                   |
| Definition           | SBO/SB1 rising<br>edge when SCK =<br>1                                     | SBO/SB1 fa <u>lling</u><br>edge when SCK =<br>1                                                                                                                                                                            |                   |
| Output<br>Device     | Master                                                                     | Master                                                                                                                                                                                                                     |                   |
| Signal Name          | Bus release<br>signal<br>(REL)                                             | Command<br>signal<br>(CMD)                                                                                                                                                                                                 |                   |
|                      |                                                                            | ■ 6427525 0095090<br>5-13 <sup>5</sup>                                                                                                                                                                                     | ጔፐፐ               |

Table 5-11 Various Signals in SBI Mode (cont'd)

Meaning of processing completion reception Signal (to be continued) disabled Receive receive enabled Serial due to Serial . ACKD set Effects on Flags of instruc-Conditions T write data directive) (] ACKE = 1 ② ACKT set  $(1) \\ (2) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3) \\ (3)$ Execution (transfer Output N tion to BSYE to SIO start READY READY [Synchronous busy output] - BUSY Timing Chart BUSY -ACK ACK 6 SBO/SB1 DO SBO/SB1 DO SCK signal output to SBO/SB1 in 1 before start or serial transfer serial receive interval after signal output to SBO/SB1 completion of signal output Definition Synchronous busy signal] Acknowledge completion. High-level <u>SCK</u> clock to SBO/SB1 Low-level Low-level signal after after Master/ Output Device slave Slave Slave Busy signal (<u>BUSY</u>) Acknowledge Signal Name signal (READY) signal (ACK) Ready 6427525 0095091 036 🔳 5-136

Table 5-11 Various Signals in SBI Mode (cont'd)



<sup>5-137</sup> 

(to be continued)

Meaning of Signal cessed by value to slave or Numeric be prodevice master Effects on IRQCSI set Flags \* (rise of 9th <u>SCK</u> cycle) clock of instruc-Conditions directive) \*2 Execution Output write to transfer SIO when CSIE = 1tion to (serial start æ \_2<sup>™</sup>7 Timing Chart -SBO/SB1 Š synchronization transferred in signal or CMD with SCK with Definition no output of 8-bit data either REL signal Master/ Device Output slave Signal Name (D7 to D0) Data

Various Signals in SBI Mode (cont'd)

Table 5-11

When WUP = 0, IRQCSI is always set on the 9th rise of  $\overline{SCK}$ . \*1:

6427525 0095093 909 🖿

5-138

When WUP = 1, IRQCSI is set only when an address is received and that address matches the value of the slave address register (SVA). When in the  $\overline{\text{BUSY}}$  state, the transfer starts after transition to the READY state. 3:

#### (6) Pin configuration

The configuration of the serial clock pin  $(\overline{SCK})$  and the serial data bus pin (SBO or SB1) is as shown below.

- (a) SCK ..... Pin for input/output of serial clock
  - 1) Master ... CMOS, push-pull output
  - (2) Slave .... Schmitt input
- (b) SB0, SB1 ..... Serial data input/output dualfunction pin For both master and slave, output is N-ch open drain, input is Schmitt input.

Since the serial data bus line output is N-ch opendrain, an external pull-up resistor is necessary.

Figure 5-59 Pin Configuration Diagram



- NOTE: Since the N-ch transistor must be turned off during data reception, FFH should be written to SIO beforehand. It can always be turned off during transmission. However, when the wake-up function specification bit (WUP) is 1, the N-ch transistor is always off, and therefore FFH need not be written to SIO prior to reception.
  - (7) Address match detection method

In the SBI mode, master address communication is used to select a specific slave and start communication.

Address match detection is performed by hardware. A slave address register (SVA) is provided, and IRQCSI is set only when the address sent from the master and the value set in SVA match in the wake-up state (WUP = 1).

NOTE 1: Detection of the slave selected/ nonselected state is performed by detection of a match with a slave address received after bus release (when RELD = 1). An address match interrupt (IRQCSI) generated when WUP = 1 is normally used for this match detection. Therefore, detection of selection/nonselection by slave address should be performed with WUP =1.

■ 6427525 0095095 781 ■ 5-140 NOTE 2: For selection/nonselection detection without using an interrupt when WUP = 0, the address detection method is not used, but instead detection should be performed by transmission/reception of commands set beforehand by the program.

### (8) Error detection

In the SBI mode, since the status of the serial bus SBO/SB1 pin during transmission is also written into the SIO shift register of the transmitting device, transmission errors can be detected in the following ways:

 (a) Comparison of pre-transmission and posttransmission SIO data

In this case, a transmission error is judged to have been generated if the two data items are different.

(b) Use of slave address register (SVA)

Transmission is performed after setting the send data in the SIO and SVA registers. After transmission the COI bit of the serial operating mode register (CSIM) (the match signal from the address comparator) is tested: "1" indicates normal transmission, and "0", a transmission error.

■ 6427525 0095096 618 ■ 5-141

### (9) Communication operation

With the SBI, the master normally selects the slave device to be communicated with from among the multiple connected devices by outputting an address onto the serial bus.

After the target communication device has been determined, commands and data are exchanged between the master device and slave device, thus implementing serial communication.

Data communication timing charts are shown in Figures 5-60 through 5-63.

In the SBI mode, shift register shift operations are performed in synchronization with the fall of the serial clock ( $\overline{SCK}$ ), and send data is latched in the SO latch and is output MSB-first from the SBO/PO2 or SB1/PO3 pin. Receive data input to the SBO (or SB1) pin is latched in the shift register on the rise of  $\overline{SCK}$ .

# ■ 6427525 0095097 554 ■ 5-142



Figure 5-60 Address Transmission from Master Device to Slave Device (WUP = 1) Figure 5-61 Command Transmission from Master Device to Slave Device





Figure 5-62 Data Transmission from Master Device to Slave Device





### (10) Start of transfer

When the following two conditions are met a serial transfer is started by setting transfer data in the shift register (SIO).

- The serial interface operation enable/disable bit (CSIE) = 1.
- After an 8-bit serial transfer, the internal serial clock is stopped or SCK is high.
  - NOTE 1: The transfer will not be started if CSIE is set to "1" after data is written into the shift register.
    - 2: Since the N-ch transistor must be turned off during data reception, FFH should be written to SIO beforehand. However, when the wake-up function specification bit (WUP) is 1, the N-ch transistor is always off, and therefore FFH need not be written to SIO prior to reception.
    - 3: If data is written to SIO when the slave is in the busy state, that data is not lost. The transfer starts when the busy state is released and the SBO (or SB1) input becomes high (ready state).

When an 8-bit transfer ends, the serial transfer stops automatically and the IRQCSI interrupt request flag is set.

> ■ 6427525 0095102 741 ■ 5-147

Example: In the following example the data in the RAM specified by the HL register is transferred to SIO, and at the same time the SIO data is fetched into the accumulator and the serial transfer is started.

> MOV XA, @HL; Fetch send data from RAM SEL MB15 ; or CLR1 MBE XCH XA, SIO; Exchange send data with receive data and start transfer

(11) Points to note concerning SBI mode

 (a) Detection of the slave detected/nondetected state is performed by detection of a match with a slave address received after bus release (when RELD = 1).

An address match interrupt (IRQCSI) generated when WUP = 1 is normally used for this match detection. Therefore, detection of selection/ nonselection by slave address should be performed with WUP = 1.

(b) For selection/nonselection detection without using an interrupt when WUP = 0, the address detection method is not used, but instead detection should be performed by transmission/ reception of commands set beforehand by the program.

■ 6427525 0095103 688 ■ 5-148

(c) When WUP is set to 1 during BUSY signal output, BUSY is not released. With the SBI, the BUSY signal is output following a BUSY release directive until the next fall of the serial clock (SCK). When WUP is set to 1, a check must be performed to ensure that SBO (SB1) has been driven high after BUSY is released before setting WUP to 1.

### (12) SBI mode applications

This section introduces an example of applications in which serial data communication is performed in the SBI mode. In this application example the uPD75336 can operate as either the master CPU or a slave CPU on the serial bus.

Also, the master can be changed by a command.

(a) Serial bus configuration

In the serial bus configuration in the application example given here the uPD75336 is assumed to be connected to the bus line as one of the devices on the serial bus.

Two uPD75336 pins are used: The serial data bus SBO (PO2/SO) and the serial clock  $\overline{SCK}$  (PO1).

A serial bus configuration example is shown in Figure 5-64.

■ 6427525 0095104 514 ■ 5-149



(b) Description of commands

<Command Types>

In this application example the following commands are set.

 READ command : Performs data transfer from slave to master.
 WRITE command : Performs data transfer from master to slave.
 6427525 0095105 450 5-150

- ③ END command : Indicates WRITE command completion to slave.
- (4) STOP command : Indicates WRITE command suspension to slave.
- (5) STATUS command: Reads slave-side status.
- 6 RESET command : Sets currently selected slave to nonselected status.
- ⑦ CHGMST command: Transfers mastership to slave side.

<Communication Procedure>

The procedure for communication between master and slave is shown below.

 The master starts communication by sending the address of the slave it wishes to communicate with to select the slave (chip selection).

The slave which receives the address returns  $\overline{ACK}$  and performs communication with the master (changes from nonselected to selected status).

2 Communication is performed between the slave selected in (1) and the master by transferring commands and data.

Master and slave on a one-to-one basis, the other slaves must be in the nonselected status.

■ 6427525 0095106 397 ■ 5-151

- ③ Communication is terminated when the slave changes to the nonselected status. This happens in the following cases:
  - When a RESET command is sent from the master the selected slave changes to nonselected status.
  - When the master is changed by the CHGMST command, the device which changes from master to slave assumes the nonselected status.

<Command Format>

The transfer format of each command is shown below.

(1) READ command

This command performs a read from a slave. A variable number of data bytes between 1 and 256 can be read; the number of data bytes is specified as a parameter from the master. If 00H is specified as the number of data bytes, a 256-byte data transfer is regarded as having been specified.

Figure 5-65 READ Command Transfer Format



■ 6427525 0095107 223 ■ 5-152

After receiving the number of data bytes, if the transmissible data is not less than that number of data bytes the slave returns  $\overline{ACK}$ . If there is insufficient data,  $\overline{ACK}$  is not returned and an error is generated.

When the master receives data it sends ACK to the slave for each byte received.

(2) WRITE, END and STOP commands

These commands are used to write data to a slave. A variable number of data bytes between 1 and 256 can be written: The number of data bytes is specified as a parameter from the master. If 00H is specified as the number of data bytes, a 256-byte data transfer is specified.

Figure 5-66 WRITE & END Command Transfer Format



Remarks: M: Output by master

S: Output by slave

After receiving the number of data bytes, if the receive data storage area is not less than that number of data bytes the slave returns ACK. If the storage area is insufficient, ACK is not returned and an error is generated.

6427525 0095108 16T 🔳

When the master has sent all the data it sends an END command. The END command informs the slave that all the data has been transferred correctly.

The slave also receives an END command before all data has been received. In this case data received up to reception of the END command is valid.

In data transmission, the master compares the SIO contents before and after transmission to check whether the data has been correctly output to the bus. If the pre-transmission and post-transmission SIO contents are different, the master sends a STOP command to suspend the data transfer.

Figure 5-67 STOP Command Transfer Format



Remarks: M: Output by master S: Output by slave

> When the slave receives the STOP command, it invalidates the data byte received immediately prior to the command.

3 STATUS command

This command reads the currently selected slave status.

■ 6427525 0095109 OT6 ■ 5-154 Figure 5-68 STATUS Command Transfer Format



Remarks: M: Output by master S: Output by slave

The format of the status byte returned by the slave is shown below.

Figure 5-69 STATUS Command Status Format



When the master receives status data it returns  $\overline{ACK}$  to the slave.

(4) RESET command

This command changes the currently selected slave to the nonselected status. Transmission of the RESET command allows all slaves to be set to the nonselected status.

6427525 0095110 818 🔤 5-155 Figure 5-70 RESET Command Transfer Format



Remarks: M: Output by master S: Output by slave

5 CHGMST command

This command passes mastership to the currently selected slave.

Figure 5-71 CHGMST Command Transfer Format



Remarks: M: Output by master S: Output by slave

> When the slave receives the CHGMST command it determines whether it is able to accept mastership, and returns data to the master. This data is as follows:

• OFFH: Master change possible

• OOH : Master change not possible

When data is transferred the slave compares the pre-transfer and posttransfer contents of SIO: If they do not match it does not return ACK and an error is generated.

■ 6427525 0095111 754 ■ 5-156 When the master receives data it returns  $\overline{ACK}$  to the slave. If the receive data is FFH, it henceforth operates as a slave. After the slave sends OFFH data and  $\overline{ACK}$  is returned from the master, it operates as the master.

<Error Generation>

Operation in the event of a communication error is described below.

A slave notifies the master of error generation by not returning  $\overline{ACK}$ . Only when the slave is receiving, when an error is generated the error indication bit in the status byte is set and all executing command processing is canceled.

After transmission of one byte is completed the master checks for  $\overline{ACK}$  from the slave. If  $\overline{ACK}$  is not returned from the slave within a specific time after completion of transmission an error is judged to have been generated and the master output an  $\overline{ACK}$  signal (as a dummy).

Figure 5-72 Master & Slave Operation in Case of Error Generation



Errors are shown below.

- Errors generated on slave side
- 1 Error in command transfer format
- 2 Reception of undefined command
- ③ Insufficient data transferred in READ command
- Insufficient data storage area in WRITE command.

5 When data changes in READ, STATUS and CHGMST command data transmission.

When any of (1) through (5) occurs,  $\overline{ACK}$  is not returned.

• Errors generated on master side

When data changes during WRITE command data transmission, a STOP command is sent to the slave.

# 5.6.8 SCK PIN OUTPUT MANIPULATION

As an output latch is incorporated in the  $\overline{SCK}/P01$  pin, it can be used for static output by means of software in addition to its normal serial clock function.

In addition, PO1 output latch manipulation allows the SCK number to be set to any desired value by software (SO/SBO, SI/SB1 pin control is performed by the RELT and CMDT bits of SBIC).

The method of manipulating the SCK/PO1 pin is shown below. 6427525 0095113 527 5-158

- 1 The serial operation mode register (CSIM) is set ( $\overline{SCK}$  pin: Output mode). While serial transfer is suspended,  $\overline{SCK} = 1$ .
- 2 The PO1 output latch is manipulated by a bitmanipulation instruction.

Example: To output one SCK clock cycle by software.

SEL MB15 ; or CLR1 MBE MOV XA, #00000011B;  $\overline{SCK}$  ( $f_X/2^3$ ), output mode MOV CSIM, XA CLR1 OFFOH.1 ;  $\overline{SCK}/P01 \neq 0$ SET1 OFFOH.1 ;  $\overline{SCK}/P01 \neq 1$ 

Figure 5-73 SCK/P01 Pin Configuration



The PO1 output latch is mapped onto bit 1 of address FFOH.  $\overline{\text{RESET}}$  signal generation sets the PO1 output latch to "1".

NOTE 1: The PO1 output latch must be set to "1" during a normal serial transfer.



NOTE 2: The PO1 output latch address cannot be specified as "PORTO.1" as shown below. The address (FFOH.1) must be written directly as the operand. However, when the instruction is executed, "MBE = 0" or "MBE = 1 and MBS = 15" needs to be set beforehand.

CLR1 PORTO.1 Cannot be used SET1 PORTO.1

CLR1 OFFOH.1 Can be used SET1 OFFOH.1



### 5.7 LCD CONTROLLER/DRIVER

### 5.7.1 LCD CONTROLLER/DRIVER CONFIGURATION

The uPD75336 incorporates a display controller which generates a segment signal and a common signal in accordance with display data memory data, a segment driver and a common driver which can directly drive the LCD panel.

The LCD controller/driver configuration is shown in Figure 5-74.

# ■ 6427525 0095116 236 ■ 5-161





### 5.7.2 LCD CONTROLLER/DRIVER FUNCTIONS

The on-chip LCD controller/driver of the uPD75336 has the following functions.

- (a) Reads the display data memory automatically by DMA operation and generates segment and common signals.
- (b) Can select display mode from among the following five modes.
  - (1) Static
  - (2) 1/2 duty (2-time multiplexing), 1/2 bias
  - (3) 1/3 duty (3-time multiplexing), 1/2 bias
  - (4) 1/3 duty (3-time multiplexing), 1/3 bias
  - (5) 1/4 duty (4-time multiplexing), 1/3 bias
- (c) Can select frame frequency in each display mode from among four frame frequencies.
- (d) There are a maximum of 20 segment signal outputs (S12 to S31) and a maximum of 4 common outputs (COMO to COM3).
- (e) Segment signal outputs (S24 to S27, S28 to S31) can be switched as a group of 4 to the output ports (BP0 to BP3, BP4 to BP7).
- (f) A split resistor for LCD drive power supply can be incorporated (mask option).
  - . Can handle various bias methods and LCD drive voltages.
  - . Current flow to the split resistor is cut when display is OFF.
- (g) The display data memory not used for display can be used as normal data memory.
   6427525 0095118 009 5-163

(h) Can operate with a subsystem clock.

Table 5-12 shows the maximum number of pixels which can be displayed in each display mode.

Table 5-12 Maximum Number of Pixels Displayed

| Bias<br>Method | Time<br>Multi-<br>plexing | COM Signal<br>Used   | Maximum No. of Pixels           |
|----------------|---------------------------|----------------------|---------------------------------|
| -              | Static                    | COM0<br>(COM1, 2, 3) | 20 (20 segments x 1 common) *1  |
| 1/2            | 2                         | COM0, 1              | 40 (20 segments x 2 commons) *2 |
|                | 3                         | COM0, 1, 2           | 60 (20 segments x 3 commons) *3 |
| 1/3            | 3                         |                      |                                 |
|                | 4                         | СОМО, 1, 2, 3        | 80 (20 segments x 4 commons) *4 |

- \*1: 2 digits of 8 segment signals/digit on 8 -type LCD panel
  - 2: 5 digits of 4 segment signals/digit on 8 -type LCD panel
  - 3: 6 digits of 3 segment signals/digit on 8 -type LCD panel
- 4: 10 digits of 2 segment signals/digit on 8.-type LCD panel



### 5.7.3 DISPLAY MODE REGISTER

The display mode register (LCDM) is an 8-bit register used to specify the display mode, LCD clock, frame frequency, segment output/bit port output selection, and display output ON/OFF control.

The LCDM is set by an 8-bit memory manipulation instruction. Only bit 3 (LCDM3) can be set and cleared by a bit manipulation instruction.

When the  $\overline{\text{RESET}}$  signal is generated, all bits are cleared to "0".

The display mode register format is shown on the next page.



Figure 5-75 Display Mode Register Format

| Address | <b>5</b> 7 | 6     | 5     | 4     | 3     | 2     | 1     | 0     | Symbol |
|---------|------------|-------|-------|-------|-------|-------|-------|-------|--------|
| F8CH    | LCDM7      | LCDM6 | LCDM5 | LCDM4 | LCDM3 | LCDM2 | LCDM1 | LCDM0 | LCDM   |

Display Mode Selection

| LCDM3 | LCDM2 | LCDM1 | LCDMO | No. of Time<br>Multiplexing | Bias Method |  |  |
|-------|-------|-------|-------|-----------------------------|-------------|--|--|
| 0     | ×     | ×     | ×     | Display OFF*                |             |  |  |
| 1     | 0     | 0     | 0     | 4                           | 1/3         |  |  |
| 1     | 0     | 0     | 1     | 3                           | 1/3         |  |  |
| 1     | 0     | 1     | 0     | 2                           | 1/2         |  |  |
| 1     | 0     | 1     | 1     | 3                           | 1/2         |  |  |
| 1     | 1     | 0     | 0     |                             | Static      |  |  |
|       | Oth   | ers   |       | Setting prohibited          |             |  |  |

\*: All segment signals are at non-selection level.

LCD Clock Selection

| LCDM5 | LCDM4 | LCDCL              |
|-------|-------|--------------------|
| 0     | 0     | $f_w/2^9$ (64 Hz)  |
| 0     | 1     | $f_w/2^8$ (128 Hz) |
| 1     | 0     | $f_w/2^7$ (256 Hz) |
| 1     | 1     | $f_w/2^6$ (512 Hz) |

NOTE: LCDCL is only supplied when the clock timer is in operation. When using the LCD controller, set the clock mode register WM bit 2 to "1".

Segment Output/Bit Port Output Switching Specification

| LCDM7 | LCDM6 | S24-S27         | S28-S31         | No. of Segment<br>Outputs | No. of Bit<br>Port Outputs |
|-------|-------|-----------------|-----------------|---------------------------|----------------------------|
| 0     | 0     | Segment output  | Segment output  | 20                        | 0                          |
| 0     | 1     | Segment output  | Bit port output | 16                        | 4                          |
| 1     | 0     | Bit port output | Segment output  | 16                        | 4                          |
| 1     | 1     | Bit port output | Bit port output | 12                        | 8                          |

Frame Frequency (Hz)

| the second s |         | (256 Hz)                | (512 Hz)                                                                                       |                                                       |                                                                                                                   |
|----------------------------------------------------------------------------------------------------------------|---------|-------------------------|------------------------------------------------------------------------------------------------|-------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------|
| 34                                                                                                             | 128     | 256                     | 512                                                                                            |                                                       |                                                                                                                   |
| 32                                                                                                             | 64      | 128                     | 256                                                                                            |                                                       | 32.768 kHz                                                                                                        |
| 21                                                                                                             | 43      | 85                      | 171                                                                                            | At $f_W =$                                            | Clock Timer Input<br>Clock                                                                                        |
| .6                                                                                                             | 32      | 64                      | 128                                                                                            |                                                       | $(f_X/128 \text{ or } f_{XT})$                                                                                    |
|                                                                                                                | 12<br>1 | 1     43       6     32 | A2         64         128           A1         43         85           6         32         64 | $\begin{array}{c ccccccccccccccccccccccccccccccccccc$ | 100     100     011       122     64     128     256       11     43     85     171       6     32     64     128 |

### 5.7.4 DISPLAY CONTROL REGISTER

The display control register (LCDC) controls the following LCD drive operations.

- . Enabling/disabling common and segment output
- . Cutting the current flow to the LCD drive power supply split resistor
- . Enabling/disabling synchronous clock (LCDCL) and synchronous signal (SYNC) to the external segment signal expansion controller/driver

The LCDC is set by a 4-bit memory manipulation instruction.

When  $\overline{\text{RESET}}$  is generated, all bits of the display control register are cleared to "0".

0

Figure 5-76Display Control Register FormatAddress3210Symbol

LCDC2

F8EH

0

LCDC0 LCDC

Display and Output Status through LCDCO and LCDM3

| LCDCO                                                         | 0                                                                                                 |                                                                                                   | 1                                                                                                 |  |
|---------------------------------------------------------------|---------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------|--|
| LCDM3                                                         | × <sup>·</sup>                                                                                    | 0                                                                                                 | 1                                                                                                 |  |
| СОМ0-3                                                        | "L" output<br>(display OFF)                                                                       | Output of common<br>signal corresponding<br>to display mode                                       | Output of common<br>signal corresponding<br>to display mode                                       |  |
| S12-S23                                                       | "L" output                                                                                        | Output of segment<br>signal corresponding                                                         | Output of segment signal corresponding                                                            |  |
| S24 to S31 segment specification pins                         | (display OFF)                                                                                     | to display mode<br>(non-selection level<br>output, display OFF)                                   | to display mode                                                                                   |  |
| S24 to S31 bit port<br>specification pins                     | Output of bit 0<br>contents of the<br>corresponding<br>display data memory<br>(bit port function) | Output of bit 0<br>contents of the<br>corresponding<br>display data memory<br>(bit port function) | Output of bit.0<br>contents of the<br>corresponding<br>display data memory<br>(bit port function) |  |
| Power supply to the<br>dividing resistor<br>(BIAS pin output) | OFF<br>(high impedance) *1                                                                        | ON<br>(high level) *1                                                                             | ON<br>(high level) *1                                                                             |  |

# LCDCL and SYNC Signal \*2 Output Enable/Disable Specification Bits

| LCDC2 | 0 | LCDCL and SYNC signal output<br>disabled | t |
|-------|---|------------------------------------------|---|
| LCDC2 | 1 | LCDCL and SYNC signal output<br>enabled  | t |

5-167 ■ 6427525 0095122 53T ■

- \*1: Cases when LCD drive power supply split resistor is not incorporated are shown in parentheses.
  - 2: LCDCL and SYNC signal outputs are reserved for future system expansion. Disable these signals for output at present.
    - NOTE: Figure 5-76 shows the cases when LCD drive power ( $V_{LC0}$  to  $V_{LC2}$ ) is supplied by BIAS pin output. If the LCD drive power supply is not dependent on BIAS pin output, the display output and bit port output are not affected by the LCDCO bit and are determined by LCDM setting only.

### 5.7.5 DISPLAY DATA MEMORY

The display data memory is mapped onto 1ECH to 1FFH.

This memory is an area which the LCD controller/driver reads by a DMA operation irrespective of CPU operation. The LCD controller controls the segment signals in accordance with the display data memory data. When S24 to S31 are used as bit ports, the bit 0 contents of the data written at addresses 1F8H to 1FFH of the display data memory are output from each bit port output pin.

If the display data memory is not used as an LCD display memory or port, it can be used as normal data memory.

The display data memory is manipulated bit-wise or in 4-bit units. 8-bit manipulation is not possible for this memory.

Figure 5-78 shows the relationships between each display data memory bit and segment/bit port output.

🖿 6427525 ОО95123 476 🎞 5-168

Figure 5-77 Data Memory Map



# 6427525 0095124 302 **6** 5-169

Figure 5-78 Relations between Display Data Memory and Common and Segment Signals



NOTE: When the 8-bit manipulation instruction is executed for the display data memory area (1ECH to 1FFH), the uPD75336 and the emulation chip mounted in the in-circuit emulator for evaluation operate differently as follows.

| uPD75336                           | CPU Emulation<br>Chip (uPD75000A)    | Peripheral Hardware<br>Emulation Chip<br>(uPD75390) |
|------------------------------------|--------------------------------------|-----------------------------------------------------|
| 8-bit unit read/<br>write disabled | 8-bit unit normal read/write enabled | 8-bit unit read/write<br>disabled                   |

When a program for 8-bit manipulation for the display data memory is created, it is not executed by the uPD75336. Do not execute 8-bit manipulation for the display data memory.

> ■ 6427525 0095125 249 ■ 5-170

If read/write is executed on the in-circuit emulator by the 8-bit manipulation instruction for the display data memory, an access is made as follows.

- . In a write, data is written to both the uPD75000A and uPD75390.
- . In a read, data is read from the uPD75000A.

Thus, when 8-bit manipulation is executed on the in-circuit emulator for the display memory area, normal operation appears to be carried out because the uPD75000A is accessed. However, since LCD display is made for the data written to the uPD75390, data written in 8-bit units is not normally displayed.

5.7.6 COMMON SIGNAL AND SEGMENT SIGNAL

Each pixel on the LCD panel lights up when the potential difference between the corresponding common and segment signals reaches the specified voltage (LCD drive voltage  $V_{\rm LCD}$ ). If the potential difference is equal to or less than  $V_{\rm LCD}$  or becomes 0 V, the LCD panel pixel goes out.

Because the LCD panel deteriorates if a DC voltage is applied to the common and segment signals, it is driven by an AC voltage.

(1) Common signals

Common signals are selected in the order shown in Table 5-13 according to the set number of time multiplexing and operation is repeated with the set time multiplexing as one cycle. In the static mode COMO, COM1, COM2 and COM3 are the same signals. Open COM2 and COM3 pins for 2-time multiplexing and open COM3 pin for 3-time multiplexing.

> ■ 6427525 0095126 185 ■ 5-171

### Table 5-13 COM Signals

| COM Signal<br>No. of Time<br>Multiplexing | СОМО | COM1 | COM2          | СОМЗ          |
|-------------------------------------------|------|------|---------------|---------------|
| Static                                    |      |      |               |               |
| 2                                         |      |      | Leave<br>open | Leave<br>open |
| 3                                         |      |      |               | Leave<br>open |
| 4                                         |      |      |               |               |

### (2) Segment signals

There are 20 segment signals corresponding to 20 locations in the data memory display data area (1ECH to 1FFH). Bits 0 to 3 are automatically read in synchronization with the timings of COMO to COM3, respectively. When each bit content is 1 or 0, it is converted to a select voltage or a non-select voltage, respectively, and is output from the segment pin (S12 to S31).

Thus, check for combinations of LCD panel front electrodes (corresponding to the segment signals) and rear electrodes (corresponding to the common signals) in which a display pattern is formed in the display data area and write bit data corresponding to the pattern to be displayed in the ratio of 1:1.

- -

(3) Output waveforms of common and segment signals

Voltages at levels shown in Tables 5-14 to 5-16 are output to the common and segment signals. A  $+V_{LCD}/-V_{LCD}$  ON voltage is set only when both become select signals. In all other combinations, an OFF voltage results.

### Table 5-14 LCD Drive Voltage (Static)

| Segment Signal Sn                 | Select                            | Non-Select                        |
|-----------------------------------|-----------------------------------|-----------------------------------|
| Common Signal COMO                | V <sub>LC0</sub> /V <sub>SS</sub> | V <sub>SS</sub> /V <sub>LC0</sub> |
| V <sub>SS</sub> /V <sub>LCO</sub> | $+V_{LCD}/-V_{LCD}$               | 0 V/0 V                           |

# Table 5-15 LCD Drive Voltage (1/2 Bias Method)

|             | Segment Signal Sn                 | Select                                    | Non-Select                                |
|-------------|-----------------------------------|-------------------------------------------|-------------------------------------------|
| Common Sign | al COMm                           | V <sub>LC0</sub> /V <sub>SS</sub>         | V <sub>SS</sub> /V <sub>LCO</sub>         |
| Select      | V <sub>SS</sub> /V <sub>LCO</sub> | $+v_{LCD}/-v_{LCD}$                       | 0 V/0 V                                   |
| Non-select  | $V_{LC1} = V_{LC2}$               | $+\frac{1}{2}V_{LCD}/-\frac{1}{2}V_{LCD}$ | $-\frac{1}{2}V_{LCD}/+\frac{1}{2}V_{LCD}$ |

### Table 5-16 LCD Drive Voltage (1/3 Bias Method)

|                    | Segment Signal Sn                 | Select                                    | Non-Select                                        |
|--------------------|-----------------------------------|-------------------------------------------|---------------------------------------------------|
| Common Signal COMm |                                   | V <sub>LC0</sub> /V <sub>SS</sub>         | V <sub>LC2</sub> /V <sub>LC1</sub>                |
| Select             | V <sub>SS</sub> /V <sub>LCO</sub> | $+v_{LCD}/-v_{LCD}$                       | $+\frac{1}{3}V_{\rm LCD}/-\frac{1}{3}V_{\rm LCD}$ |
| Non-select         | $V_{LC1} = V_{LC2}$               | $+\frac{1}{3}V_{LCD}/-\frac{1}{3}V_{LCD}$ | $-\frac{1}{3}V_{\rm LCD}/+\frac{1}{3}V_{\rm LCD}$ |



Figures 5-79 to 5-81 show common signal waveforms and Figure 5-82 shows common and segment signal voltages and phases.

Figure 5-79 Common Signal Waveform (Static)











Figure 5-81 Common Signal Waveform (1/3 Bias Method)

T<sub>F</sub> : Frame Cycle

### ■ 6427525 0095130 606 ■■ 5-175



### (c) Static display mode





Figure 5-82 Common and Segment Signal Voltages and Phases

(b) 1/2 Bias method

(a)

1/3 Bias method

## 5.7.7 $V_{LCO}$ , $V_{LC1}$ AND $V_{LC2}$ POWER SUPPLIES FOR LCD DRIVE

The uPD75336 can incorporate split resistors in  $V_{\rm LCO}$  to  $V_{\rm LC2}$  pins for LCD drive power supply. It can supply LCD drive power based on each bias method without the use of external split resistors. The uPD75336 is also equipped with BIAS pins to cope with various LCD drive voltages. The BIAS pins are externally connected to  $V_{\rm LCO}$  pins.

The following values are supplied as appropriate LCD drive power based on the static, 1/2 and 1/3 bias methods.

| Bias Method<br>LCD Drive<br>Power Supply | Without Bias<br>(Static Mode) | 1/2                   | 1/3                 |
|------------------------------------------|-------------------------------|-----------------------|---------------------|
| V <sub>LC0</sub>                         | V <sub>LCD</sub>              | V <sub>LCD</sub>      | V <sub>LCD</sub>    |
| V <sub>LC1</sub>                         | 2/3V <sub>LCD</sub>           | 1/2V <sub>LCD</sub> * | 2/3V <sub>LCD</sub> |
| v <sub>LC2</sub>                         | 1/3V <sub>LCD</sub>           |                       | 1/3V <sub>LCD</sub> |
| v <sub>ss</sub>                          | 0 V                           | 0 V                   | 0 V                 |

Table 5-17 LCD Drive Power Supply Values

- \* : In the case of 1/2 bias,  $\rm V_{LC1}$  and  $\rm V_{LC2}$  pins must be connected externally.
- Remarks :  $V_{LCD} = 3/5V_{DD}$  when BIAS and  $V_{LCO}$  pins are open. (split resistors must be on chip by mask option.)

 $V_{LCD} = V_{DD}$  when BIAS and  $V_{LCO}$  pins are connected.

■ 6427525 0095132 489 ■ 5-177

LCD drive power supply examples in accordance with Table 5-17 are shown in Figure 5-83 (a), (b) and (c).

Current flow through the split resistors can be cut off by clearing bit 0 (LCDCO) or the display control register to "0".

LCD power ON/OFF control is also effective to prevent a DC voltage from being applied to the LCD because the STOP instruction stops the LCD clock (if a system clock has been selected) when the watch timer is in operation with the main-system clock.

In other words, potential differences can be prevented between the LCD electrodes if the LCD clock stops by clearing bit 0 (LCDCO) of the display control register to "0" just before STOP instruction execution, thus equalizing all LCD drive power supplies to the same  $V_{\rm SS}$  potential.

When the watch timer is in operation with the subsystem clock, LCD display can continue.

### ■ 6427525 0095133 315 ■ 5-178

Figure 5-83 LCD Drive Power Supply Connection Examples (with On-Chip Split Resistors)

(a) 1/3 bias method and static display mode (Example with V<sub>DD</sub> = 5 V, V<sub>LCD</sub> = 3 V )



(b) 1/2 bias method

(Example with  $V_{DD}$ = 5 V,  $V_{LCD}$  = 5 V )



(c) 1/3 bias method and static display mode (Example with  $V_{DD}$  = 5 V,  $V_{LCD}$  = 5 V )



Figure 5-84 LCD Drive Power Supply Connection Examples (with External Split Resistors)

- (a) Static display mode\*
   (Example with V<sub>DD</sub>
   = 5 V, V<sub>LCD</sub> = 5 V )
- (b) Static display mode (Example with V<sub>DD</sub> = 5 V, V<sub>LCD</sub> = 3 V )





\*: Set LCDCO always to "1" (including the standby mode).

## ■ 6427525 0095135 198 ■ 5-180

# Figure 5-84 LCD Drive Power Supply Connection Examples (with External Split Resistors) (cont'd)

(c) 1/2 bias method (Example with  $V_{DD}$ = 5 V,  $V_{LCD}$  = 2.5 V )



(d) 1/3 bias method (Example with  $V_{DD}$ = 5 V,  $V_{LCD}$  = 3 V )



## ■ 6427525 0095136 024 ■ 5-181

#### 5.7.8 DISPLAY MODES

(1) Static display example

Figure 5-86 shows connection of a 3-digit LCD panel based on the static method with a display pattern shown in Figure 5-85 to the uPD75336 segment signals (S12 to S31) and common signal (COMO). The display example is 123 and the display data memory contents (addresses 1ECH to 1FFH) corresponding to this display.

This section provides a description using the first digit 3 (3) as an example. It is necessary to generate select and non-select voltages shown in Table 5-18 to the S12 to S18 pins at the COMO common signal timing in accordance with the display pattern in Figure 5-85.

Table 5-18 Select and Non-Select Voltages (COMO)

| Segment<br>Common | S12    | \$13 <sup>.</sup> | S14    | S15            | S16    | S17            | S18    |
|-------------------|--------|-------------------|--------|----------------|--------|----------------|--------|
| СОМО              | Select | Select            | Select | Non-<br>select | Select | Non-<br>select | Select |

It is clear that 1110101 should be set at bit 0 of the display data memory (addresses 1ECH to 1F2H) corresponding to S12 to S18.

Figure 5-87 shows the S14, S15 and COMO LCD drive waveforms. When S14 becomes a select voltage at the COMO select timing,  $+V_{\rm LCD}/-V_{\rm LCD}$  AC rectangular waveform at LCD ON level is generated.

#### ■ 6427525 0095137 T60 ■ 5-182

Since the same waveform as that of COMO is generated at COM1, COM2 and COM3, the drive capability can be improved by connecting COMO, COM1, COM2 and COM3.

Figure 5-85 Static LCD Display Pattern and Electrode Wiring





## ■ 6427525 0095138 9T7 ■ 5-183

Figure 5-86 Static LCD Panel Wiring Example



# ⊾ 6427525 0095139 833 **■** 5-184

-



Figure 5-87 Static LCD Drive Waveform Example

# (2) 2-time multiplexing display example

Figure 5-89 shows connection of a 5-digit LCD panel based on the 2-time multiplexing method with a display pattern shown in Figure 5-88 to the uPD75336 segment signals (S12 to S31) and common signals (COMO, COM1). The display example is 123.45 and the display data memory contents (addresses 1ECH to 1FFH) corresponding to this display.

This section provides a description using the third digit 3. (3) as an example. It is necessary to generate select and non-select voltages shown in Table 5-19 to the S20 to S23 pins at the COMO and COM1 common signal timings in accordance with the display pattern in Figure 5-88.

| Table | 5-19 | Select | and | Non-Select | Voltages | (COMO, | COM1 ) | ) |
|-------|------|--------|-----|------------|----------|--------|--------|---|
|-------|------|--------|-----|------------|----------|--------|--------|---|

| Segment<br>Common | S20    | S21    | S22            | S23            |
|-------------------|--------|--------|----------------|----------------|
| СОМО              | Select | Select | Non-<br>select | Non-<br>select |
| COM1              | Select | Select | Select         | Select         |

It is clear, for example, that xx10 should be set in the display data memory (address 1F7H) corresponding to S23.

Figure 5-90 shows the S23 and common signal LCD drive waveforms. When S23 becomes a select voltage at the COM1 select timing, a  $+V_{LCD}/-V_{LCD}$  AC rectangular waveform at LCD ON level is generated.

### ■ 6427525 0095141 491 ■ 5-186

Figure 5-88 2-Time Multiplexing LCD Display Parameter and Electrode Wiring





# ■ 6427525 0095142 328 **■** 5-187

Figure 5-89 2-Time Multiplexing LCD Panel Wiring Example





■ 6427525 0095143 264 ■ 5-188

Figure 5-90 2-Time Multiplexing LCD Drive Waveform Example (1/2 Bias Method)





## (3) 3-time multiplexing display example

Figure 5-92 shows connection of a 6-digit LCD panel based on the 3-time multiplexing method with a display pattern shown in Figure 5-91 to the uPD75336 segment signals (S12 to S29) and common signals (COMO to COM2). The display example is 12345.6 and the display data memory contents (addresses 1ECH to 1FDH) corresponding to this display.

This section provides a description using the second digit 5. (5.) as an example. It is necessary to generate select and non-select voltages shown in Table 5-20 to the S15 to S17 pins at the COMO to COM2 common signal timings in accordance with the display pattern in Figure 5-91.

| Segment<br>Common | S15        | S16    | S17        |
|-------------------|------------|--------|------------|
| СОМО              | Non-select | Select | Select     |
| COM1              | Select     | Select | Non-select |
| COM2              | Select     | Select |            |

Table 5-20 Select and Non-Select Voltages (COMO, 1, 2)

It is clear that X110 should be set in the display data memory (address 1EFH) corresponding to S15.

Figure 5-93 (1/2 bias method) and Figure 5-94 (1/3 bias method) show the S15 and common signal LCD drive waveforms. When S15 becomes a select voltage at the COM1/COM2 select timing, a  $+V_{\rm LCD}/-V_{\rm LCD}$  AC rectangular waveform at LCD ON level is generated.

■ 6427525 0095145 037 ■ 5-190 Figure 5-91 3-Time Multiplexing LCD Display Pattern and Electrode Wiring





# ■ 6427525 0095146 T73 ■ 5-191



Figure 5-92 3-Time Multiplexing LCD Panel Wiring Example

Figure 5-93 3-Time Multiplexing LCD Drive Waveform Example (1/2 Bias Method)



6427525 0095148 846 페 5-193

Figure 5-94 3-Time Multiplexing LCD Drive Waveform Example (1/3 Bias Method)



This Material Copyrighted By Its Respective Manufacturer

\_\_\_\_ ·

#### (4) 4-time multiplexing display example

Figure 5-96 shows connection of a 10-digit LCD panel based on the 4-time multiplexing method with a display pattern shown in Figure 5-95 to the uPD75336 segment signals (S12 to S31) and common signals (COMO to COM3). The display example is 123456.7890 and the display data memory contents (addresses 1ECH to 1FFH) corresponding to this display.

This section provides a description using the fifth digit 6. ( $\delta$ ) as an example. It is necessary to generate select and non-select voltages shown in Table 5-21 to the S20 and S21 pins at the COMO to COM3 common signal timings in accordance with the display pattern in Figure 5-95.

| Table 5-21 | Select and | Non-Select | Voltages | (COMO | to | COM3 ) | ) |
|------------|------------|------------|----------|-------|----|--------|---|
|------------|------------|------------|----------|-------|----|--------|---|

| Segment<br>Common | S20        | S21    |
|-------------------|------------|--------|
| СОМО              | Select     | Select |
| COM1              | Non-select | Select |
| COM2              | Select     | Select |
| СОМЗ              | Select     | Select |

It is clear that 1101 should be set in the display data memory (address 1F4H) corresponding to S20.

Figure 5-97 shows the S20 and COMO and COM1 LCD drive waveforms (COM2 and COM3 waveforms are omitted for the sake of drawings). When S20 becomes a select voltage at the COMO select timing, a  $+V_{\rm LCD}/-V_{\rm LCD}$  AC rectangular waveform at LCD ON level is generated.

■ 6427525 0095150 4T4 ■ 5-195

Figure 5-95 4-Time Multiplexing LCD Display Parameter and Electrode Wiring





■ 6427525 0095151 330 ■ 5-196



# ■ 6427525 0095152 277 ■ 5-197

Figure 5-97 4-Time Multiplexing LCD Panel Waveform Example (1/3 Bias Method)



## 5.8 A/D CONVERTER

The uPD75336 incorporates an 8-bit precision analog/ digital (A/D) converter having 8-channel analog inputs (ANO to AN7).

The A/D converter employs the successive approximation method.

### 5.8.1 A/D CONVERTER CONFIGURATION

The A/D converter has the configuration shown in Figure 5-98.

## ын 6427525 0095154 О4Т ни 5−199

Figure 5-98 A/D Converter Block Diagram





#### (1) A/D converter pins

(a) ANO to AN7

8-channel analog signal input pins for the A/D converter. Analog signals to be converted from analog to digital are input to these pins.

AN6 and P82, and AN7 and P83 serve as dualfunction pins in pairs.\*

The A/D converter incorporates a sample & hold circuit and an analog input voltage is internally held during A/D conversion.

- \*: When AN6 and AN7 are used, the following settings are necessary before A/D conversion.
  - (1) Set port 8 to the input mode.
  - ② Disable the on-chip pull-up resistor at port 8.

(For details, refer to Section 5.1 "DIGITAL INPUT/OUTPUT PORTS".)

NOTE: Use ANO to AN7 input voltages within the specified range. If a voltage equal to or greater than  $V_{DD}$  or equal to or less than  $V_{SS}$  (even in the absolute maximum rating range) is input, the converted value of that channel becomes indeterminate and may cause effects on the converted value of another channel.

■ 6427525 0095156 912 ■ 5-201 (b) AV<sub>REF</sub>

Pin to which A/D converter reference voltage is input.

Signals input to ANO to AN7 are converted to digital signals on the basis of voltages applied across  $AV_{REF}$  and  $AV_{SS}$ .

(c) AV<sub>SS</sub>

A/D converter GND pin. It always should be set the same voltage as  $\ensuremath{V_{\rm SS}}$  .

(2) A/D conversion mode register (ADM)

The ADM is an 8-bit register used to select the analog input channel, specify conversion start and detect the termination of conversion.

The ADM is set by an 8-bit manipulation instruction.

Bit 2 (EOC) and bit 3 (SOC) can be manipulated bitwise.

When the  $\overrightarrow{\text{RESET}}$  signal is generated, the ADM is initialized to 04H (only EOC is set to "1" and all other bits are cleared to "0").



#### Figure 5-99 A/D Conversion Mode Register Format



NOTE: A/D conversion starts with a maximum delay of 2  $/f_X$ sec (3.81 us at  $f_X$  = 4.19 MHz) after SOC setting (refer to 5.8.2 "A/D Converter Operations").

> ■ 6427525 0095158 795 ■ 5-203

#### (3) SA register(SA)

The SA (successive approximation) is an 8-bit register used to store A/D conversion results.

The SA is read by an 8-bit manipulation instruction. It is a read-only register and write operations and bit manipulation cannot be carried out.

When the  $\overline{\text{RESET}}$  signal is generated, the SA is set to 7FH.

NOTE: When A/D conversion is started with the ADM register bit 3 (SOC) set to "1", the conversion results in the SA are destroyed and the SA remains indeterminate until new conversion results are stored.

## 5.8.2 A/D CONVERTER OPERATIONS

The analog input signal to be converted to a digital signal is specified by setting bits 6, 5 and 4 (ADM6, 5, 4) of the A/D conversion mode register.

A/D conversion is started by setting ADM bit 3 (SOC) to "1". After setting, the SOC is automatically cleared to "0". A/D conversion is performed by hardware using the successive approximation method and the 8-bit conversion result data is stored in the SA register. Upon termination of conversion, ADM bit 2 (EOC) is set to "1".

Figure 5-100 shows an A/D conversion timing chart.

### ₩ 6427525 0095159 621 ₩ 5-204

#### Operate the A/D converter using the following procedure.



NOTE: It takes the EOC a maximum of 2<sup>4</sup>/fx (3.81 us at fx = 4.19 Mhz) to be cleared after A/D conversion start following SOC setting. Thus, execute the EOC test after the lapse of time specified in Table 5-22 following SOC setting. The A/D conversion time is also shown in Table 5-22.
■ 6427525 0095160 343 ■ 5-205

| SCC a | nd PCC | Set N | /alues | A/D<br>Conversion                    | Wait Time till                | Wait Time till                                        |                   |
|-------|--------|-------|--------|--------------------------------------|-------------------------------|-------------------------------------------------------|-------------------|
| SCC3  | SCCO   | PCC1  | PCC0   | Time                                 | EOC Test after<br>SOC Setting | Termination of A/D<br>Conversion after<br>SOC Setting |                   |
| 0     | 0      | 0     | 0      | 168/f <sub>x</sub>                   | Wait not required             | 3 machine cycles                                      |                   |
|       |        | 0     | 1      | (40.1  us)<br>$f_{X} =$<br>4.19  MHz | (40.1 <sup>"</sup> us/        | 1 machine cycle                                       | 11 machine cycle  |
|       |        | 1     | 0      |                                      |                               | 2 machine cycles                                      | 21 machine cycles |
|       |        | 1     | 1      |                                      | 4 machine cycles              | 42 machine cycles                                     |                   |
| 0     | 1      | x     | x      |                                      | Wait not required             | Wait not required                                     |                   |
| 1     | x      | x     | x      | Conversion<br>operation<br>stop      |                               |                                                       |                   |

Table 5-22 SCC and PCC Settings

x: don't care





Figure 5-101 shows the relations between analog input voltages and A/D converted 8-bit digital data.

■ 6427525 0095161 28T ■ 5-206

Figure 5-101 Relations between Analog Input Voltages and A/D Conversion Results (Ideal Case)



#### 5.8.3 STANDBY MODE PRECAUTIONS

The A/D converter operates with the main-system clock. Thus, it stops operating in the STOP mode or the HALT mode with the subsystem clock. Because current flows to the AV<sub>REF</sub> pin in this case also, it is necessary to cut this current to minimize the power consumption of the whole Since the P83 and P33 pins have higher drive system. capability than any other port, a voltage can be supplied directly to the  $AV_{REF}$  pin (see Figure 5-102). In this case, however, because the actual  $AV_{REF}$  voltage is not accurate, the converted value itself has no accuracy and can only be used for relative comparison. In the standby mode, power consumption can be minimized by generating a low level to P83 and P33.

> 6427525 0095162 116 🔳 5-207

The drive capability of the P83 and P33 pins of the uPD75390 peripheral hardware emulator used for emulation with EVAKIT is the same as that of any other port. Thus, when an example in Figure 5-102 is used,  $AV_{REF}$  for emulation becomes lower than  $AV_{REF}$  generated when uPD75336 is actually used, and the A/D conversion value does not become the same.

Figure 5-102 Example of How to Decrease Power Consumption in Standby Mode



\*: The P83 and P33 pins have higher drive capability than any other port.

## ■ 6427525 0095163 052 ■ 5-208

#### 5.8.4 OPERATING PRECAUTIONS AND OTHERS

(a) ANO to AN7 input ranges

Use ANO to AN7 input voltages within the specified range. If a voltage equal to or greater than  $V_{\rm DD}$  or equal to or less than  $V_{\rm SS}$  (even in the absolute maximum range) is input, the converted value of that channel becomes indeterminate and may cause effects on the converted value of another channel.

(b) Countermeasure against noise

To maintain 8-bit precision, extra precaution must be taken against noise in the  $AV_{REF}$  and ANO to AN7 pins. The higher the analog input source output impedance, the greater the effects. It is recommended to externally connect the C (see Figure 5-103), so as to reduce noise.

Figure 5-103 Analog Input Pin Treatment



6427525 0095164 T99 🔳 5-209

## (c) AN6/P82 and AN7/P83 pins

Analog input (AN6, AN7) pins serve as dual-function pins with input ports (P82, P83).

When performing A/D conversion with AN6 or AN7 selected, preset port 8 to the input mode and do not execute an input instruction during conversion, otherwise conversion accuracy may deteriorate.

If a digital pulse is applied to pins next to the pin undergoing A/D conversion, the expected A/D conversion value may not be obtained because of coupling noise. Thus, do not apply pulses to the pins adjacent to the pin undergoing A/D conversion.

## 6427525 0095165 925 5-210

#### 5.9 BIT SEQUENTIAL BUFFER: 16 BITS

The bit sequential buffers 0 to 3(BSB0 to BSB3) are special data memory for bit manipulation. Because bit manipulation can be performed easily by sequentially changing address and bit specification, this data memory is useful for bit-wise when processing of data with long bit lengths.

This data memory has a 16-bit configuration. It can perform pmem.@L addressing for a bit manipulation instruction and specify particular bits indirectly using the L register. In this case, processing can be carried out by sequentially shifting the specified bit simply by incrementing or decrementing the L register in the program loop.

Figure 5-104 Bit Sequential Buffer Format



Remarks 1: In pmem.@L addressing, the specified bit shifts in accordance with the L register.

2: In pmem.@L addressing, the BSB may operate independently of the MBE MBS specification.

Data can be operated in direct addressing as well. 1-bit data continuous input/output can be executed by combining 1-bit, 4-bit and 8-bit direct addressing and pmem.@L addressing. In the case of 8-bit manipulation, the most/ least significant 8 bits are manipulated by specifying BSBO and BSB2.

5-211 6427525 0095166 861 E

Example: Output 16-bit data of BUFF1 and BUFF2 serially from bit 0 of port 3.

|        | CLR1 | MBE                               |
|--------|------|-----------------------------------|
|        | MOV  | XA, BUFF1                         |
|        | MOV  | BSBO, XA ; BSBO and BSB1 set      |
|        | MOV  | XA, BUFF2                         |
|        | MOV  | BSB2, XA ; BSB2 and BSB3 set      |
|        | MOV  | L, #O                             |
| LOOP0: | SKT  | BSB0, @L ; BSB specified bit test |
|        | BR   | LOOP1                             |
|        | NOP  | ; Dummy (timing                   |
|        |      | adjustment)                       |
|        | SET1 | PORT3.0 ; Port 3 bit 0 set        |
|        | BR   | LOOP2                             |
| LOOP1: | CLR1 | PORT3.0 ; Port 3 bit 0 clear      |
|        | NOP  | ; Dummy (timing                   |
|        |      | adjustment)                       |
|        | NOP  |                                   |
| LOOP2: | INCS | L ; L + L + 1                     |
|        | BR   | LOOPO                             |
|        |      | RET                               |

## ■ 6427525 0095167 7T8 ■ 5-212

#### CHAPTER 6. INTERRUPT FUNCTIONS

On the uPD75336 there are 7 vectored interrupt sources and two testable inputs, enabling a wide variety of applications to be handled.

Moreover, the uPD75336's interrupt control circuit has the following special features, making possible extremely fast interrupt servicing.

- (a) Acknowledgment enabling/disabling can be controlled by means of the interrupt master enable flag (IME) and the interrupt enable flags (IExxx).
- (b) The interrupt service start address and MBE/RBE during interrupt servicing can be set arbitrarily using the vector table (for rapid starting of the actual interrupt service program).
- (c) It is possible to raise the priority of any single interrupt source and enable multiple interrupts from that source.
- (d) Interrupt request flags (IRQxxx) can be tested and cleared (allowing checking of interrupt generation by software).
- (e) Standby mode (STOP/HALT) can be released by an interrupt request (release source is selectable by means of an interrupt enable flag).
- 6.1 INTERRUPT CONTROL CIRCUIT CONFIGURATION

The interrupt control circuit is configured as shown in Figure 6-1, with each hardware item mapped onto data memory space.

### ■ 6427525 0095168 634 ■ 6-1



# 6.2 INTERRUPT SOURCE TYPES AND VECTOR TABLE

The uPD75336's interrupt source types and interrupt vector table are shown in Table 6-1 and Figure 6-2.

| Interru         | pt Source                                                                                                     | Internal/<br>External | Interrupt<br>Priority<br>*1 | Vectored Interrupt<br>Request Signal<br>(Vector Table<br>Address) |
|-----------------|---------------------------------------------------------------------------------------------------------------|-----------------------|-----------------------------|-------------------------------------------------------------------|
| INTBT           | (Basic time interval)<br>signal from basic<br>interval timer                                                  | Internal              | 1                           | VRQ1 (0002H)                                                      |
| INT4            | (Both rising edge and falling edge detection) valid                                                           | External              |                             |                                                                   |
| INTO            | (Rising/falling edge<br>detection selection)                                                                  | External              | 2                           | VRQ2 (0004H)                                                      |
| INT1<br>(0006H) | detection selection)                                                                                          | External              | 3                           | VRQ3                                                              |
| INTCSI          | (Serial data transfer<br>termination signal)                                                                  | Internal              | 4                           | VRQ4 (0008H)                                                      |
| INTTO           | Match signal for<br>programmable timer/<br>counter 0 count register<br>and modulo register                    | Internal              | 5                           | VRQ5 (000AH)                                                      |
| INTT1           | Match signal for<br>programmable timer/<br>counter 1 count register<br>and modulo register                    | Internal              | 6                           | VRQ6 (000CH)                                                      |
| INT2 *3         | (INT2 pin input rising<br>edge detection or rising<br>edge detection on any<br>input to KRO through KR7<br>*2 | External              |                             | le input signal<br>IRQ2 & IRQW)                                   |
| INTW *3         | (Signal from clock timer)                                                                                     | Internal              |                             |                                                                   |

# Table 6-1 Interrupt Source Types

- \*1: The interrupt priority is the order of precedence when multiple interrupt requests occur simultaneously.
  - 2: For details of INT2, see 6.3 (4) "INT2 and key interrupt 0 to 7(KR0 to KR7) hardware". ■ 6427525 0095170 292 ■ 6-3

3: Test source. This is affected by the interrupt enable flag as well as the interrupt source, however, the vectored interrupt is not generated.

| 0002H | MBE | RBE | INTBT/INT4 Start Address<br>(High-Order 6 Bits) |
|-------|-----|-----|-------------------------------------------------|
|       |     |     | INTBT/INT4 Start Address<br>(Low-Order 8 Bits)  |
| 0004H | MBE | RBE | INTO Start Address<br>(High-Order 6 Bits)       |
|       |     |     | INTO Start Address<br>(Low-Order 8 Bits)        |
| 0006H | MBE | RBE | INT1 Start Address<br>(High-Order 6 Bits)       |
|       |     |     | INT1 Start Address<br>(Low-Order 8 Bits)        |
| 0008H | MBE | RBE | INTCSI Start Address<br>(High-Order 6 Bits)     |
|       |     |     | INTCSI Start Address<br>(Low-Order 8 Bits)      |
| 000AH | MBE | RBE | INTTO Start Address<br>(High-Order 6 Bits)      |
|       |     |     | INTTO Start Address<br>(Low-Order 8 Bits)       |
| 000СН | MBE | RBE | INTT1 Start Address<br>(High-Order 6 Bits)      |
|       |     |     | INTT1 Start Address<br>(Low-Order 8 Bits)       |
|       |     |     |                                                 |

Figure 6-2 Interrupt Vector Table

Address

The interrupt priority shown in the table shows the order in which interrupts are executed when multiple interrupt requests are generated simultaneously or when multiple interrupt requests are pending.

The vector table contains the interrupt service routine start addresses and the set value of the MBE, RBE with interrupt servicing in progress. Vector table setting is performed by the VENTn assembler pseudo-instruction.

#### ■ 6427525 0095171 129 ■ 6-4

Example: INTBT/INT4 vector table setting.



NOTE: The vector table address specified by VENTn (n = 1 to 6) is address 2n.

Example: INTBT/INT4 and INTTO vector table setting.

VENT1 MBE = 0, RBE = 0, GOTOBTVENT5 MBE = 0, RBE = 1, GOTOTO



#### 6.3 INTERRUPT CONTROL CIRCUIT HARDWARE

(1) Interrupt request flags & interrupt enable flags

Nine types of interrupt request flags (IRQxxx) as shown below are provided corresponding to interrupt sources (interrupts: 7, test: 2).

INTO Interrupt Request Flag (IRQ0)
INT1 Interrupt Request Flag (IRQ1)
INT2 Interrupt Request Flag (IRQ2)
INT4 Interrupt Request Flag (IRQ4)
BT Interrupt Request Flag (IRQBT)
Serial Interface Interrupt Request Flag (IRQCSI)
Timer/Event Counter 0 Interrupt Request Flag (IRQT0)
Timer/Event Counter 1 Interrupt Request Flag (IRQT1)
Watch Timer Interrupt Request Flag (IRQW)

An interrupt request flag is set "1" by the generation of an interrupt request and cleared "0" automatically when the interrupt service routine is executed. However, since IRQBT and IRQ4 share a vector address, the clear operation is different (see 6.6 "Vector Address Sharing Interrupt Servicing").

Nine types of interrupt enable flags (IExxx) as shown below are provided corresponding to interrupt sources.

INTO Interrupt Enable Flag (IEO)
INT1 Interrupt Enable Flag (IE1)
INT2 Interrupt Enable Flag (IE2)
INT4 Interrupt Enable Flag (IE4)
BT Interrupt Enable Flag (IEBT)
Serial Interface Interrupt Enable Flag (IECSI)
Timer/Event Counter 0 Interrupt Enable Flag (IET0)
Timer/Event Counter 1 Interrupt Enable Flag (IET1)
Watch Timer Interrupt Enable Flag (IEW)

#### 6-6 ■ 6427525 0095173 TT1 ■

When the interrupt enable flag contents are "1", interrupts are enabled, when "0", interrupts are disabled.

When an interrupt request flag is set and the interrupt enable flag permits an interrupt, a vectored interrupt request (VRQn) is generated. This signal is also used to release standby mode.

The interrupt request flags and interrupt enable flags are manipulated by bit manipulation instructions and 4-bit memory manipulation instructions. In the case of bit manipulation instructions, direct manipulation is always possible irrespective of the MBE setting. In addition, the interrupt enable flags are manipulated by the EI IExxx instruction and the DI IExxx instruction. The SKTCLR is normally used for interrupt request flag testing.

Example: EI IEO ; INTO enabled DI IE1 ; INT1 disabled SKTCLR IRQCSI; skip and clear if IRQCSI is 1

When the interrupt request flag is set by an instruction, although no interrupt is generated, a vectored interrupt is executed in the same way as when an interrupt is generated.

The IRQO, IRQBT, IRQCSI, IRQTO, IRQT1 and IRQW interrupt request flags are cleared (0) by generation of a RESET signal. IRQ1, IRQ2 and IRQ4 are undefined after RESET signal input, and should therefore be cleared (0) by software. The interrupt enable flags are cleared (0) by generation of a  $\overrightarrow{\text{RESET}}$  signal. All interrupts are then disabled.

Table 6-2 Interrupt Request Flag Setting Signals

| Interrupt<br>Request<br>Flag | Interrupt Request Flag Setting Signal                                                                                      | Interrupt<br>Enable<br>Flag |
|------------------------------|----------------------------------------------------------------------------------------------------------------------------|-----------------------------|
| IRQBT                        | Set by basic time interval signal from basic interval timer.                                                               | IEBT                        |
| IRQ4                         | Set by INT4/POO pin input signal rising or falling edge detection.                                                         | IE4                         |
| IRQO                         | Set by INTO/P10 pin input signal edge<br>detection. Detected edge is selected by<br>INTO mode register (IMO).              | IEO                         |
| IRQ1                         | Set by INT1/P11 pin input signal edge<br>detection. Detected edge is selected by<br>INT1 mode register (IM1).              | IE1                         |
| IRQCSI                       | Set by serial interface serial data transfer operation termination signal.                                                 | IECSI                       |
| IRQT0                        | Set by match signal from timer/event counter #0.                                                                           | IETO                        |
| IRQT1                        | Set by match signal from timer/event counter #1.                                                                           | IET1                        |
| IRQW                         | Set by signal from clock timer.                                                                                            | IEW                         |
| IRQ2                         | Set by INT2/P12 pin input rising edge detection or detection of falling edge of any input to pins KR0/P60 through KR7/P73. | IE2                         |

#### ■ 6427525 0095175 874 ■ 6-8

#### (2) Interrupt priority selection register (IPS)

The interrupt priority selection register is used to select the "high-ranking interrupt" with multiple interrupt capability, this being specified by the low-order 3 bits.

Bit 3 is the interrupt master enable flag (IME) which specifies whether or not all interrupts are disabled.

IPS is set by a 4-bit memory manipulating instruction, but bit 3 is set/reset by an EI/DI instruction.

When the low-order 3 bits of IPS are modified, this should always be performed when interrupts are disabled (IME = 0).

| Example: | DI   |          | ; | Disab | le  | ir  | nterrupts    |   |
|----------|------|----------|---|-------|-----|-----|--------------|---|
|          | CLR1 | MBE      |   |       |     |     |              |   |
|          | MOV  | A, #1011 |   |       |     |     |              |   |
|          | MOV  | IPS, A   | ; | Make  | INT | 11  | high-ranking | J |
| ·        |      |          |   | inter | rur | pt, | and enable   |   |
|          |      |          |   | inter | rur | ots | 5            |   |

RESET signal generation clears all bits to "0".

The format of the interrupt priority selection register is shown in Figure 6-3.

#### ■ 6427525 0095176 700 ■ 6-9

# Figure 6-3 Interrupt Priority Selection Register



# ■ 6427525 0095177 647 ■ 6-10

#### (3) INTO, INT1 and INT4 hardware

 (a) The configuration of INTO is shown in Figure 6-4
 (a). It is an external interrupt input for which rising edge or falling edge detection can be selected.

The INTO pin also has a function for noise elimination by means of a sampling clock (refer to Figure 6-5 "Noise Elimination Circuit Input/ Output Timing"). In the noise elimination circuit, pulses narrower than 2 cycles\* of the sampling clock are eliminated as noise. However, pulses greater than 1 cycle of the sampling clock may be acknowledged depending on sampling timing (refer to Figure 6-5 (2) (a)). Pulses exceeding twice the width of the sampling clock can be surely acknowledged as interrupt signals.

In INTO, either  $\phi$  or  $f_X/64$  sampling clock can be selected. The selection is performed by the edge detection mode register bit 3 (IMO3) (refer to Figure 6-6 (a)).

Detected edge selection is performed by means of the edge detection mode register bit 0 (IMOO) and bit 1 (IMO1).

The format of IMO is shown in Figure 6-6 (a). IMO is set by a 4-bit manipulation instruction. Upon reset signal generation, all bits are cleared to "O" and rising edge detection is specified.

> \*: When sampling clock is  $\phi$  :  $2t_{CY}$ When sampling clock is  $f_x/64$ :  $128/f_y$

■ 6427525 0095178 583 ■ 6-11

- NOTE 1: Since INTO sampling is performed by means of a clock, it does not operate in standby mode.
  - 2: When INTO/P10 pin is input, it is input via noise elimination circuit. Therefore, pulses exceeding twice the width of the sampling clock also should be input.
- (b) The configuration of INT1 is shown in Figure 6-4(b). It is an external interrupt input for which rising edge or falling edge detection can be selected.

Detected edge selection is performed by means of the edge detection mode register (IM1).

The format of IM1 is shown in Figure 6-6 (b). IM1 is set by 4-bit manipulation instruction. Upon reset signal generation, all bits are cleared to "0" and rising edge detection is specified.

 (c) The configuration of INT4 is shown in Figure 6-4
 (c). It is an external interrupt input with both rising edge and falling edge detection capability.

#### ∎ 6427525 0095179 41T **■** 6-12

Figure 6-4 Configuration of INTO, INT1 and INT4

#### (a) INTO hardware



#### (b) INT1 hardware



#### (c) INT4 hardware



#### ■ 6427525 0095180 131 ■ 6-13

Figure 6-5 Noise Elimination Circuit Input/Output Timing



Remarks : t<sub>SMP</sub> = t<sub>CY</sub> or 64/f<sub>X</sub>

#### ■ 6427525 0095181 078 ■ 6-14

Figure 6-6 Edge Detection Mode Register Format

(a) INTO Edge Detection Mode Register (IMO)



(b) INT1 Edge Detection Mode Register (IM1)



NOTE: As the interrupt request flag may be set when the edge detection mode register is modified, the following procedure should be used: Disable interrupts and modify the mode register in advance, clear the interrupt request flag with the CLR1 instruction, and then enable interrupts again. Also, when  $f_x/64$  is selected as the sampling clock by modifying IMO, the interrupt request flag must be cleared after the elapse of 16 machine cycles following the mode register modification.

(4) INT2 and key interrupt 0 to 7 (KR0 to KR7) hardware

The configuration of INT2 and KRO to KR7 is shown in Figure 6-7. There are two types for IRQ2 setting, as follows. Either (a) or (b) can be selected by the edge detection mode resister (IM2).

(a) INT2 pin input rising edge detection

IRQ2 is set upon detection of an INT2 pin input rising edge.

(b) Falling edge detection on any of pins KR0 to KR7 (key interrupt)

IRQ2 is set upon detection of a falling edge in the input of any of pins KRO through KR7 selected by the edge detection mode register (IM2).

#### ■ 6427525 0095183 940 ■ 6-16

NOTE: If there is low-level input on even one of the pins selected for falling edge detection, IRQ2 is not set even if a falling edge is input on the other pins.

The format of IM2 is shown in Figure 6-6 (c). IM2 is set by a 4-bit manipulating instruction. Upon reset signal generation, all bits are cleared to "0" and rising edge detection is specified.

# 6-17



Figure 6-7 Configuration of INT2 and KRO to KR7

This Material Copyrighted By Its Respective Manufacturer

#### (5) Interrupt status flags

The interrupt status flags (ISTO, IST1) are flags in the PSW which indicate the status of the processing currently being executed by the CPU.

The interrupt priority control circuit controls multiple interrupts according to the contents of these flags as shown in Table 6-3.

Since ISTO and IST1 can be modified by bit manipulation instructions or 4-bit manipulation instructions, it is possible to perform multiple interrupts by changing the status during execution. ISTO and IST1 can be manipulated bit-wise at any time irrespective of the MBE setting.

When ISTO and IST1 are manipulated, it is always necessary to disable interrupts by executing a DI instruction prior to the manipulation, then to enable interrupts by execution of an EI instruction after the manipulation.

After IST1 and IST0 are saved to stack memory together with the rest of the PSW when an interrupt is acknowledged, their status is automatically changed to the next higher level. When an RETI instruction is executed, the original ISTO/IST1 values are restored.

RESET signal generation clears the flag contents to "0".

■ 6427525 0095186 65T ■ 6-19

# Table 6-3 IST1/IST0 Interrupt Servicing Status

| IST1 | ISTO | Executing<br>Processing<br>Status | CPU Processing                                                                       | Interrupt Requests for<br>which Interrupt<br>Acknowledgment is<br>Possible | After<br>Interrupt<br>Acknowl-<br>edgement |      |  |
|------|------|-----------------------------------|--------------------------------------------------------------------------------------|----------------------------------------------------------------------------|--------------------------------------------|------|--|
|      |      |                                   |                                                                                      |                                                                            | IST1                                       | IST0 |  |
| 0    | 0    | Status O                          | Normal program<br>processing in<br>progress                                          | Acknowledgment of all interrupts possible                                  | 0                                          | 1    |  |
| 0    | 1    | Status 1                          | Low-ranking<br>interrupt or<br>high-ranking<br>interrupt<br>servicing in<br>progress | Only high-ranking<br>interrupts can be<br>acknowledged                     | 1                                          | 0    |  |
| 1    | 0    | Status 2                          | High-ranking<br>interrupt<br>servicing in<br>progress                                | Acknowledgment of all<br>interrupts disabled                               | -                                          | -    |  |
| 1    | 1    | Setting prohibited                |                                                                                      |                                                                            |                                            |      |  |



#### 6.4 INTERRUPT SEQUENCE

When an interrupt is generated, it is serviced by the following procedure.



Figure 6-8 Interrupt Service Sequence

- \*1: ISTO, IST1: Interrupt status flags (PSW bits 3 & 2: See Table 6-3.)
  - 2: Each vector table contains the start address of the interrupt service program and MBE & RBE set values when the interrupt starts.

■ 6427525 0095188 422 ■■ 6-21

### 6.5 MULTIPLE INTERRUPT SERVICE CONTROL

On the uPD75336, multiple interrupts can be performed in two ways, as shown below.

(1) Multiple interrupts with high-ranking interrupt specified

This is the basic multiple interrupt method on the uPD75336; one of the interrupt sources is selected and multiple interrupts (dual interrupts) are enabled for that interrupt source.

In other words, the high-ranking interrupts specified by the interrupt priority selection register (IPS) are enabled when the status of the processing being executed is 0 or 1, and other interrupts (low-ranking interrupts) are enabled only when the status is 0 (Refer to Figure 6-9).

Therefore, if it is wished to set multiple interrupt capability for only one of the interrupts used, using this method makes it possible to accomplish dual interrupts without performing operations such as enabling/disabling during the interrupt servicing, and to hold down the number of nesting levels to two.

# 6-22

Figure 6-9 Multiple Interrupts by High-Rank Specification



(2) Multiple interrupts through modification of interrupt status flag

If the interrupt status flag is modified by the program, multiple interrupts are enabled. That is, multiple interrupts are enabled by changing IST1 & ISTO to 0 & 0 and setting status 0 in the interrupt service program.

This method is used when it is wished to enable multiple interrupts involving two or more interrupts, or to perform triple-or-above multiple interruption.

IST1/ISTO modification is performed with interrupts disabled beforehand by means of the DI instruction.

### ■ 6427525 0095190 080 ■ 6-23







# 6.6 VECTOR ADDRESS SHARING INTERRUPT SERVICING

Since INTBT and INT4 interrupt sources share a vector table, interrupt source selection is performed as shown below.

(1) When only one interrupt is used

The interrupt enable flag is set "1" for the necessary interrupt source of the two interrupt sources sharing the vector table, and the interrupt enable flag for the other source is cleared "0". In this case, when an interrupt request is generated by the enabled (IExxx = 1) interrupt source and acknowledged the corresponding interrupt request flag is reset (same operation as for interrupts not sharing a vector address).

(2) When both interrupts are used

The interrupt enable flags corresponding to the two interrupt sources are both set "1". In this case, the OR of the 2 interrupt source interrupt request flags constitutes the interrupt request.

In this case, even though an interrupt request is acknowledged by the setting of one or both of the interrupt request flags, neither interrupt request flag is reset.

In this case, therefore, it is necessary to determine within the interrupt service routine from which interrupt source the interrupt originated. This is done by checking the interrupt request flags with an SKTCLR instruction.

> ■ 6427525 0095192 953 ■ 6-25

If both request flags are set when this interrupt request flag test-and-clear operation is performed, the interrupt request remains even if one of the request flags is cleared. When this interrupt is selected as a "high-ranking interrupt", dual interrupt servicing is entered by means of the remaining interrupt request.

In other words, the interrupt request for which testing is not performed is serviced first. Meanwhile, in the case of a "low-ranking interrupt", the remaining interrupt is held pending, and thus the interrupt request for which testing was performed is serviced first. Therefore, the method of shared interrupt discrimination differs according to whether or to "high-ranking interrupts" are involved.

Table 6-4 Shared Interrupt Discrimination

| In case of "high-ranking<br>interrupt" | Interrupts are disabled and interrupt<br>request flag of interrupt to be given<br>priority is tested. |
|----------------------------------------|-------------------------------------------------------------------------------------------------------|
| In case of "low-ranking<br>interrupt"  | Interrupt request flag of interrupt source to be given priority is tested.                            |

# ■ 6427525 0095193 89T ■ 6-26

Example 1: When INTET and INT4 are both used as "high-ranking interrupts", and INT4 is given priority.

|         | DI     |        |               |
|---------|--------|--------|---------------|
|         | SKTCLR | IRQ4 ; | IRQ4 = 1?     |
|         | BR     | VSUBBT |               |
|         | :      |        |               |
|         | :      |        | INT4 service  |
|         | EI     |        | routine       |
|         | RETI   | ,      |               |
|         | :      |        |               |
|         |        |        |               |
| VSUBBT: | CLR1   | IRQBT  |               |
|         | :      |        |               |
|         | :      |        | INTBT service |
|         | EI     |        | routine       |
|         | RETI   |        |               |

2: When INTBT and INT4 are both used as "low-ranking interrupts", and INT4 is given priority.



■ 6427525 0095194 726 ■ 6-27

# 6.7 MACHINE CYCLES UNTIL INTERRUPT SERVICING

On the 75X, the machine cycles expended from setting of the interrupt request flag (IRQn) until the interrupt routine program is executed are as follows.

(1) When IRQn is set during interrupt control instruction execution

When IRQn is set during execution of an interrupt control instruction, the interrupt routine program is executed after 3 machine cycles of interrupt servicing have been performed following execution of the next instruction.



- A: Setting of IRQn
- B: Execution of next instruction (between 1 and 3 machine cycles depending on instruction)
- C: Interrupt servicing (3 machine cycles)

D: Execution of interrupt routine

Remarks 1: An interrupt control instruction is an instruction which manipulates interrupt-related hardware (data memory FBx address). These instructions comprise the DI and EI instructions.

6-2 8

- Remarks 2: The 3 machine cycles of interrupt servicing include the time for manipulation of the stack on acknowledgment of an interrupt, etc.
- NOTE 1: If there are a number of consecutive interrupt control instructions, the interrupt routine program is executed after 3 machine cycles of interrupt servicing have been performed following execution of the instruction which follows the last interrupt control instruction executed.
  - 2: If the DI instruction is executed using the IRQn setup timing (A in the above figure) or subsequent timing, the IRQn interrupt request is retained until the next EI instruction execution.
- (2) When IRQn is set during execution of an instruction other than an interrupt control instruction
  - (a) When IRQn is set in the last machine cycle of the instruction being executed

In this case, the interrupt routine program is executed after 3 machine cycles of interrupt servicing have been performed following execution of the instruction which follows the instruction being executed.

■ 6427525 0095196 5T9 ■ 6-29

Instruction Other than Interrupt Control Instruction



- A: Setting of IRQn
- B: Execution of next instruction (between 1 and 3 machine cycles depending on instruction)

C: Interrupt servicing (3 machine cycles)

- D: Execution of interrupt routine
  - NOTE: If the next instruction is an interrupt control instruction, the interrupt routine program is executed after 3 machine cycles of interrupt servicing have been performed following execution of the instruction which follows the last interrupt control instruction executed. Also, if the interrupt control instruction executed after IRQn is set is a DI instruction, the interrupt request by which IRQn was set is held pending.
- (b) When IRQn is set before the last machine cycle of the instruction being executed

In this case, the interrupt routine program is executed after 3 machine cycles of interrupt servicing have been performed following the instruction being executed.

6-30

Instruction Other than Interrupt Control Instruction



- A: Setting of IRQn
- C: Interrupt servicing (3 machine cycles)
- D: Execution of interrupt routine



# 6.8 EFFECTIVE USE OF INTERRUPTS

The following uses of the interrupt functions are effective.

(1) Setting MBE = 0 in the interrupt service routine

If the data memory to be used in the interrupt service routine is allocated in prioritized fashion to addresses 00H through 7FH and MBE = 0 is specified in the interrupt vector table, programming with memory bank transparency is possible.

If it is imperative to use memory bank 1 due to program considerations, memory bank 1 is selected by saving the memory bank selection register by means of a PUSH BS instruction.

(2) Split use of register banks in ordinary routines and interrupt routines

In ordinary routines, register banks 2 and 3 are used by setting RBE = 1 and RBS = 2. With a single interrupt service routine, using register bank 0 by setting RBE = 0 eliminates the need for register saving/restoration. With dual interrupt servicing, RBE = 1 is set, the register bank is saved by the PUSH BS instruction, and register bank 1 is used by setting RBS = 1.

6-32 🖬 6427525 0095199 208 페

#### (3) Use of software interrupts in debugging

Setting an interrupt request flag by means of an instruction results in the same operation as when an interrupt is generated. Irregular interrupt debugging or debugging when interrupts are generated simultaneously can be performed efficiently by setting the interrupt request flag by means of an instruction.

# 6-33

### 6.9 USE OF INTERRUPTS

When the interrupt function is used, the following settings are first carried out in the main program.

- (a) The interrupt enable flag to be used is set (EI IExxx instruction).
- (b) If INTO and INT1 are used, the active edge is selected (IMO/IM1 setting).
- (c) When dual interruption is used (by means of highranking interrupts), IPS is set (IME can also be set at the same time).
- (d) The interrupt master enable flag is set (EI instruction).

MBE and RBE are set by means of the vector table in the interrupt service program. However, register bank saving and setting is required for interrupts specified as "highranking interrupts".

Return from the interrupt service program is by means of an RETI instruction.

# 6-34

#### (1) Interrupt enabling/disabling



(1) All interrupts disabled by RESET signal.

- Interrupt enable flag set by EI IExxx instruction.
   At this stage, all interrupts are still disabled.
- ③ Interrupt master enable flag set by EI instruction.
   At this stage, INTO & INTT1 are enabled.
- (4) Interrupt enable flag cleared by DI IExxx instruction; INTO disabled.
- 5 All interrupts disabled by DI instruction.

на 6427525 0095202 622 на 6-35

(2) Example using INTET, INTO (falling edge active), and INTTO, with no multiple interrupts (all low-ranking interrupts)



 All interrupts disabled and status 0 set by RESET signal.
 RBE = 1 specified by reset vector table, register banks 2 & 3 used by means of SEL RB2 instruction.

- 2 INTO set to falling edge active.
- ③ Interrupts enabled by EI and EI IExxx instructions.
- ④ On fall of INTO, INTO interrupt service program is started. Status is changed to 1, and all interrupts are disabled. RBE becomes 0, and register banks 0 & 1 are used.

6-36 ■ 6427525 0095203 569 ■

- (5) Return from interrupt by means of RETI instruction. Status is restored to 0 and interrupts are enabled.
  - Remarks: When all interrupts are used as "lowranking interrupts" as in this example, register saving/restoration is completely unnecessary if register banks 2 and 3 are used by setting RBE = 1 and RBS = 2 in the main program, and register banks 0 and 1 are used by setting RBE = 0 in the interrupt service program.
- (3) Multiple interrupt by means of "high-ranking interrupts" (INTBT high-ranking interrupts, INTTO & INTCSI low-ranking interrupts)



- INTBT set to "high-ranking interrupt" by IPS setting and interrupts enabled simultaneously.
- ② Generation of low-ranking interrupt INTTO starts INTTO service program, sets status 1 and disables low-ranking interrupts. Register bank 0 is used by setting RBE = 0.
- ③ Generation of high-ranking interrupt INTBT results in dual interrupt servicing. Status 2 is set and all interrupts are disabled.
- (4) Register bank 1 is used by setting RBE = 1 and RBS = 1 (only the registers used need to be saved by PUSH instruction).
- (5) RBS is restored to 2 and return is performed. Status is restored to 1.



(4) Pending interrupt execution - interrupt input in interrupt disabled state -



- Although INTO is set in the interrupt disabled state, the request flag is held pending.
- 2 The INTO service program is started at the point at which interrupts are enabled by the EI instruction.
- 3 Same as 1
- ④ The INTCSI service program is started at the point at which the pending INTCSI is enabled.
   6427525 0095206 278 ■
   6-39

(5) Pending interrupt execution - simultaneous generation of two low-ranking interrupts -



- (1) If "low-ranking interrupt" INTO and INTTO are generated simultaneously (during execution of the same instruction), INTO, which has the higher interrupt priority, is executed first (INTTO is held pending).
- When the INTO service program is ended by the RETI instruction, the pending INTTO service program is started.

■ 6427525 0095207 104 ■ 6-40

(6) Pending interrupt execution - interrupt generation during interrupt servicing. (INTBT high-ranking interrupt, INTTO & INTCSI low-ranking interrupts)



 If high-ranking interrupt INTBT and low-ranking interrupt INTTO are generated simultaneously, the high-ranking interrupt servicing is started. (If it is certain that no high-ranking interrupt will be generated during the high-ranking interrupt servicing, DI IExx is not necessary.)

6-41

- (2) If a low-ranking interrupt is generated during execution of high-ranking interrupt, the interrupt is held pending.
- ③ When the high-ranking interrupt ends, servicing of INTCSI which has the highest ranking among the pending low-ranking interrupts is executed.
- When INTCSI servicing ends, the pending INTTO is serviced.
- (7) Two dual interrupts enabled. Dual interrupt enabled for INTTO and INTO. INTCSI and INT4: Single interruption -

<Main Program>



- Generation of an INTCSI interrupt for which dual interrupts are not enabled starts the INTCSI service program. Status is set to 1.
- ② Clearing ISTO sets the status to 0. INTCSI and INT4 for which dual interrupts are not enabled are disabled.
- ③ Generation of an INTTO interrupt for which dual interrupts are enabled results in dual interrupt execution, setting of status to 1, and disabling of all interrupts.
- (4) At the end of INTTO servicing, status is restored to 0.
- (5) The disabled INTCSI and INT4 are enabled and return is performed.

### ■ 6427525 0095210 7T9 ■ 6-43

#### CHAPTER 7. STANDBY FUNCTIONS

The uPD75336 is provided with standby functions for reducing the system power consumption. The standby functions comprise the following two modes.

- . STOP mode
- . HALT mode

The functions of STOP mode and HALT mode are described below respectively.

(1) STOP mode

In this mode the main system clock oscillation circuit is stopped and the entire system stops. The CPU current consumption is considerably reduced. In addition low-voltage ( $V_{DD}$  = up to 2 V) data memory retention is possible. This mode is thus effective for retaining the data memory contents at an extremely low current consumption.

As the uPD75336 STOP mode can be released by an interrupt request, intermittent operation is also possible. However, since a wait time is required for oscillation stabilization when the STOP mode is released, the HALT mode should be selected when processing must be started immediately by an interrupt request.

#### (2) HALT mode

In this mode the CPU operating clock is stopped, but oscillation by the system clock oscillation circuit continues. This mode does not allow current consumption to be reduced to the degree it is in the STOP mode, but it is effective when wishing to restart processing immediately by means of an interrupt request, or to perform intermittent operation such as clock operation.

> ■ 6427525 0095211 635 ■ 7-1

In both modes, the contents of all registers, flags, and data memory directly prior to the setting of standby mode are retained. In addition, the status of input/output port output latches and output buffers is retained, and thus the input/output port statuses are processed beforehand so that the overall system current consumption is minimized.

Notes on use are given below.

- NOTE 1: STOP mode can only be used when the system is operating on the main system clock (it is not possible to stop the oscillation of the subsystem clock). HALT mode can be used when operating on either the main system clock or the subsystem clock.
  - 2: When the LCD controller/driver and clock timer operating clock is the main system clock  $f_x$ , setting STOP mode will stop their operation. Therefore, to continue their operation, it is necessary to switch the operating clock to the subsystem clock  $f_{XT}$  before setting STOP mode.
  - 3: Standby mode and CPU clock/system clock switching allows efficient low current consumption and lowvoltage operation, but the time specified in 5.2.3 "System Clock and CPU Clock Settings" is required in each case from selection of the new clock by control register manipulation until operation under the post-switchover clock begins. For this reason, when the standby mode is used in conjunction with the clock switchover function standby mode should be set after the time required for switchover has elapsed.
  - 4: When the standby mode is used, the I/O port should be handled so that the current consumption is a minimum. In particular, the input port should not be left open. A low or high level must be input.

### 7-2 ■ 6427525 0095212 571 ■

### 7.1 STANDBY MODE SETTING AND OPERATING STATUS

|                          |                            | STOP Mode                                                                                                                          | HALT Mode                                                                                                                          |  |
|--------------------------|----------------------------|------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------|--|
| Setting instruction      |                            | STOP instruction                                                                                                                   | HALT instruction                                                                                                                   |  |
| System c<br>setting      |                            | Main system clock                                                                                                                  | Main system clock<br>Subsystem clock                                                                                               |  |
| Operat-<br>ing<br>status | Clock<br>generator         | Main system clock<br>oscillation only stopped                                                                                      | CPU clock $\Phi$ only stopped (oscillation continues)                                                                              |  |
| Status                   | Basic<br>interval<br>timer | Operation stopped                                                                                                                  | Operation enabled only<br>when main system clock<br>oscillates.<br>(IRQBT is set at basic<br>time interval.)                       |  |
| Serial<br>interface      |                            | Operation enabl <u>ed</u> when<br>external input SCK is<br>selected as serial clock                                                | Operation enabled only<br>when external SCK input is<br>selected as serial clock<br>or only when main system<br>clock oscillates.  |  |
| Timer/event<br>counter   |                            | Operation enabled only<br>when TIO pin input is<br>specified as count clock                                                        | Operation enabled when TIn<br>pin input is specified as<br>count clock or only when<br>main system clock<br>oscillates.            |  |
| Watch timer              |                            | Operation enabled when $f_{\rm XT}$ is selected as count clock                                                                     | Operation enabled                                                                                                                  |  |
|                          | LCD<br>controller          | Operation enabled when f <sub>XT</sub> is selected as LCDCL                                                                        | Operation enabled                                                                                                                  |  |
| A/D<br>converter         |                            | Operation stopped                                                                                                                  | Operation enabled*                                                                                                                 |  |
| External<br>interrupts   |                            | Operation enabled<br>Operation disable                                                                                             | l for INT1, 2 and 4<br>ed for INTO only                                                                                            |  |
| CPU                      |                            | Operatio                                                                                                                           | on stopped                                                                                                                         |  |
| Release signal           |                            | Interrupt request signal<br>from hardware for which<br>operation is enabled by<br><u>interrupt enable flag</u> , or<br>RESET input | Interrupt request signal<br>from hardware for which<br>operation is enabled by<br><u>inter</u> rupt enable flag, or<br>RESET input |  |

# Table 7-1 Operating Status in Standby Mode

■ 6427525 0095213 408 **■** 7-3 \*: Only in case of main system clock oscillation

The STOP and HALT modes are set by the STOP and HALT instructions respectively. (The STOP and HALT instructions set PCC bit 3 and bit 2 respectively).

Ensure that an NOP instruction is always written directly after a STOP instruction or HALT instruction.

When the CPU operating clock is changed by means of the low-order 2 bits of the PCC, after the PCC has been overwritten as shown in Table 4-1 there may be a time lag before the CPU clock is changed. Therefore when changing the pre-standby-mode CPU clock and the post-standby-moderelease CPU clock, standby mode is set when the number of machine cycles required for the CPU clock change have elapsed after the PCC is rewritten.

In standby mode, all the data in registers and data memory (general registers, flags, mode registers, output latches, etc.) for which operation is stopped while in that mode is saved.

Notes are given below.

NOTE 1: When STOP mode is set, the X1 input is internally shorted to  $V_{SS}$  (GND potential) to suppress leakage of the crystal oscillator section. Therefore, use of STOP mode is not possible on systems which employ an external clock.

### ■ 6427525 0095214 344 ■ 7-4

# NOTE 2: Before setting the STANDBY mode, set the interrupt request flag in advance. If there is an interrupt source for which both the interrupt request flag and interrupt enable flag are set, the STANDBY mode, even if entered, is immediately released (see Figure 6-1 "Interrupt Control Circuit Block Diagram"). However, in case of the STOP mode, the HALT mode is entered immediately after execution of the STOP instruction, a wait follows for the duration of time set by the BTM register, and then the operating mode is restored.



### 7.2 STANDBY MODE RELEASE

STOP mode and HALT mode are both released by generation of an interrupt request signal\* enabled by an interrupt enable flag, and by  $\overline{\text{RESET}}$  input. The release operation in each mode is shown in Figure 7-1.

\*: Except INTO

Figure 7-1 Standby Mode Release Operations

(a) STOP mode release by RESET input



(b) STOP mode release by interrupt generation



Remarks: The dotted line shows the case where the interrupt request which released standby mode is acknowledged (IME = 1).

■ 6427525 0095216 117 ■ 7-6



#### (c) HALT mode release by RESET input

(d) HALT mode release by interrupt generation



Remarks: The dotted line shows the case where the interrupt request which released standby mode is acknowledged (IME = 1).

When STOP mode is released by program of an interrupt, the wait time is determined by the setting of BTM (see Table 7-2).

The time until oscillation stabilizes varies according to the type of resonator used and the power supply voltage when STOP mode is released. Therefore, the wait time is selected according to the conditions of use and BTM is set before setting STOP mode.

> ■ 6427525 0095217 053 ■ 7-7

| втмз             | BTM2 | BTM1 | BTMO | Wait Time*<br>Figure in ( ) is for $f_X = 4.19$ MHz       |
|------------------|------|------|------|-----------------------------------------------------------|
| -                | 0    | 0    | 0    | Approx. 2 <sup>20</sup> /f <sub>X</sub> (Approx. 250 ms)  |
| -                | 0    | 1    | 1    | Approx. $2^{17}/f_{X}$ (Approx. 31.3 ms)                  |
| -                | 1    | 0    | 1    | Approx. $2^{15}/f_X$ (Approx. 7.82 ms)                    |
| -                | 1    | 1    | 1    | Approx. 2 <sup>13</sup> /f <sub>X</sub> (Approx. 1.95 ms) |
| Other than above |      |      | ve   | Setting prohibited                                        |

Table 7-2 Wait Time Selection by BTM

- \*: This time does not include the time until the start of oscillation after STOP mode release.
  - NOTE: In both the RESET input and the interrupt generation case, the wait time when STOP mode is released does not include the time until clock oscillation begins after STOP mode release ("a" in the diagram below).

STOP Mode Release Xl Pin Voltage Waveform

### на 6427525 0095218 Т9Т на 7-8

#### 7.3 OPERATION AFTER STANDBY MODE RELEASE

- When standby mode is released by RESET input, a normal reset operation is executed.
- (2) When standby mode is released by generation of an interrupt request, whether or not a vectored interrupt is performed when the CPU restarts instruction execution is determined by the contents of the interrupt master enable flag (IME).
  - (a) When IME = 0

After standby mode is released, execution is restarted from the instruction (NOP instruction) following that in which standby mode was set.

The interrupt request flag value is retained.

(b) When IME = 1

After standby mode is released, a vectored interrupt is executed after the execution of the two instructions following that in which standby mode was set. However, a vectored interrupt is not generated when standby mode is released by means of INTW or INT2 (testable inputs), and in this case the same processing is performed as in (a) above.

■ 6427525 0095219 926 ■ 7-9

### 7.4 USE OF STANDBY MODE

The procedure shown below is followed when using standby mode.

- Detection of the standby mode setting source, such as power cutoff by an interrupt input or port input. (Use of INT4 for power cutoff detection is effective.)
- ② Input/output port processing (processing to minimize current consumption). In particular, the input port should not be left open. A low or high level should be input.
- ③ Setting of interrupt to release standby mode. (Use of INT4 is effective; non-releasing interrupt enable flags are cleared.)
- ④ Post-release operation setting (IME manipulation according to whether or not interrupt servicing is performed).
- (5) Post-release CPU clock setting. (When switching, the necessary number of machine cycles are allowed to elapse before standby mode is set.)
- 6 Selection of wait time used when release is performed.
- (7) Standby mode setting (STOP/HALT mode).

When used in conjunction with system clock switching, standby mode allows low-power-consumption and low-voltage operation.

> ■ 6427525 0095220 648 ■ 7-10

(1) Example of use of STOP mode ( $f_x = 4.19$  MHz operation)

<When STOP mode is used under the following conditions>

- . STOP mode is set by an INT4 falling edge input and released by a rising edge input (INTBT is not used).
- . All input ports are high impedance. (when a pin is processed externally to reduce current consumption at high impedance)
- . Interrupts used in the program are INTO and INTTO; however, these are not used for releasing STOP mode.
- . Interrupts are also enabled after release.
- . After release, operation starts under the slowest CPU clock.
- . The wait time used when releasing is set to 31.3 ms.
- . After release, a further 31.3 ms wait is performed to allow the power supply to stabilize. The POO/INT4 pin is checked twice to eliminate chattering.



<Timing chart>

#### <Sample program>

(INT4 service program, MBE = 0) VSUB4: SKT PORTO.0 ; POO = 1? BR PDOWN ; power-down SET1 BTM.3 ; power-on WAIT : SKT IRQBT ; 31.3 ms wait BR WAIT SKT PORT0.0 ; check chattering BR PDOWN MOV A, #0011B PCC, A ; set high-speed mode MOV XA, #xxH]; set port mode register MOV PMGm, XA MOV EI IEO EI IETO RETI PDOWN: MOV A, #0 ; low-speed mode PCC, A MOV MOV XA, #00H MOV LCDM, XA ; LCD display off MOV LCDC, A PMGA, XA ; input/output ports high MOV impedance MOV PMGB, XA DI IEO ; INTO/INTTO disabled · DI IETO MOV A, #1011B MOV BTM, A ; wait time = 31.3 ms NOP STOP ; set STOP mode NOP RETI

> ■ 6427525 0095222 410 ■ 7-12

(2) Use of HALT mode ( $f_X = 4.19$  MHz,  $f_{XT} = 32.768$  kHz operation)

<In case of intermittent operation under the following conditions>

- . Subsystem clock is switched to on fall of INT4.
- . Main system clock oscillation is stopped and HALT mode is set.
- . Intermittent operation performed in standby mode at 0.5 sec. intervals.
- . System switches back to main system clock on rise of INT4.
- . INTBT is not used.

<Timing chart>





# <Sample program>

### (Initialization)

| MOV | A, #0011B                |
|-----|--------------------------|
| MOV | PCC, A ; high-speed mode |
| MOV | XA, #05                  |
| MOV | WM, XA ; subsystem clock |
| EI  | IE4                      |
| EI  | IEW                      |
| EI  | ; interrupts enabled     |

(Main routine)

|        | SKT    | PORT0.0 | ; | power supply OK? |
|--------|--------|---------|---|------------------|
|        | HALT   |         | ; | power-down mode  |
|        | NOP    |         | ; | power supply OK? |
|        | SKTCLR | IRQW    | ; | 0.5 flag set?    |
|        | BR     | MAIN    | ; | NO               |
|        | CALL   | WATCH   | ; | clock subroutine |
| MAIN : | :      |         |   |                  |
|        | :      |         |   |                  |
|        | :      |         |   |                  |

(INT4 service routine)

| VINT4: | SKT<br>BR | PORT0.0 ; power supply OK?, MBE = 0<br>PDOWN |   |
|--------|-----------|----------------------------------------------|---|
|        | CLR1      | SCC.3 ; start main system clock              |   |
|        |           | oscillation                                  |   |
|        | MOV       | A, #1000B                                    |   |
|        | MOV       | BTM, A                                       |   |
| WAIT1: | SKT       | IRQBT ; 250 ms wait                          |   |
|        | BR        | WAIT1                                        |   |
|        | SKT       | PORT0.0 ; check chattering                   |   |
|        | BR        | PDOWN                                        |   |
|        | CLR1      | SCC.0 ; switch to main system clock          | k |
|        | RETI      | •                                            |   |
|        | 642       | 7525 0095224 293 💻<br>7-14                   |   |

| PDOWN: | MOV  | XA, #00H |   |                           |
|--------|------|----------|---|---------------------------|
|        | MOV  | LCDM, XA | ; | LCD display off           |
|        | MOV  | LCDC, A  |   |                           |
|        | SET1 | SCC.0    | ; | switch to subsystem clock |
|        | MOV  | A, #5    |   |                           |
| WAIT2: | INCS | A        | ; | wait of 32 machine cycles |
|        |      |          |   | or more (35 machine       |
|        |      |          |   | cycles)*                  |
|        | BR   | WAIT2    |   |                           |
|        | SET1 | SCC.3    | ; | stop main system clock    |
|        |      |          |   | oscillation               |
|        | RETI |          |   |                           |

- \*: See 5.2.3 "System Clock and CPU Clock Settings" for details of switching between the system clock and CPU clock.
- NOTE: When switching from the main system clock to the subsystem clock, it is necessary to wait for the subsystem clock oscillation to stabilize before making the switchover.

🖬 6427525 0095225 12T 📟 7-15

### CHAPTER 8. RESET FUNCTION

The uPD75336 is reset by  $\overline{\text{RESET}}$  input and the various hardware units are initialized as shown in Table 8-1 to 8-3. Reset operation timing is shown in Figure 8-1.



Figure 8-1 RESET Input Reset Operation

Table 8-1 Hardware Status after Reset

|                      | Hardware                        | RESET Input inRESET Input durStandby ModeOperation                                                                         |                 |  |
|----------------------|---------------------------------|----------------------------------------------------------------------------------------------------------------------------|-----------------|--|
| Program counter (PC) |                                 | Program memory<br>address 0000H low-<br>order 6 bits set in<br>PC13 to PC8,<br>address 0001H<br>contents in PC7 to<br>PC0. | Same as at left |  |
| PSW                  | Carry flag (CY)                 | Retained                                                                                                                   | Undefined       |  |
|                      | Skip flags (SKO to<br>SK2)      | 0                                                                                                                          | 0               |  |
|                      | Interrupt status flag<br>(ISTO) | 0                                                                                                                          | 0               |  |
|                      | Bank enable flags<br>(MBE, RBE) | Program memory<br>address 0000H bit 6<br>set in RBE, bit 7<br>in MBE.                                                      | Same as at left |  |
| Stack point          | er (SP)                         | Undefined                                                                                                                  | Undefined       |  |

(to be continued)

■ 6427525 0095226 066 ■ 8-1

### Table 8-1 Hardware Status after Reset (cont'd)

|                                 | Hardware                                  | RESET Input in<br>Standby Mode | RESET Input during<br>Operation |
|---------------------------------|-------------------------------------------|--------------------------------|---------------------------------|
| Data memory                     | (RAM)                                     | Retained *1                    | Undefined                       |
| General reg<br>(X,A, H, L,      | cisters<br>D, E, B, C)                    | Retained                       | Undefined                       |
| Bank select<br>RBS)             | ion registers (MBS,                       | 0,0                            | 0.0                             |
| Basic<br>interval               | Counter (BT)                              | Undefined                      | Undefined                       |
| timer                           | Mode register (BTM)                       | 0                              | 0                               |
| Timer/<br>event                 | Counter (Tn)                              | 0                              | 0                               |
| counter $(n = 0, 1)$            | Modulo register<br>(TMODn)                | FFH                            | FFH                             |
|                                 | Mode register (TMn)                       | 0                              | 0                               |
|                                 | TOEn, TOUT F/F                            | 0, 0                           | 0, 0                            |
| Clock<br>timer                  | Mode register (WM)                        | 0                              | 0                               |
| Serial<br>interface             | Shift register (SIO)                      | Retained                       | Undefined                       |
| Interrace                       | Operating modé<br>register (CSIM)         | 0                              | 0                               |
| SBI control register<br>(SBIC)  |                                           | 0.                             | 0                               |
| Slave address register<br>(SVA) |                                           | Retained                       | Undefined                       |
| Clock<br>generation<br>circuit, | Processor clock<br>control register (PCC) | 0                              | 0                               |
| clock<br>output<br>circuit      | System clock control register (SCC)       | 0                              | 0                               |
| CIICUIU                         | Clock output mode<br>register (CLOM)      | 0                              | 0                               |

(to be continued)

■ 6427525 0095227 TT2 ■ 8-2

# Table 8-1 Hardware Status after Reset (cont'd)

|                                                             | Hardware                                          |                   | RESET Input in<br>Standby Mode | RESET Input during<br>Operation |
|-------------------------------------------------------------|---------------------------------------------------|-------------------|--------------------------------|---------------------------------|
| LCD<br>controller                                           | Display mo<br>(LCDM)                              | de register       | 0                              | 0                               |
|                                                             | Display co<br>register (                          |                   | 0                              | 0                               |
| A/D<br>converter                                            | Mode regis                                        | ter (ADM)         | O4H (EOC = 1)                  | 04H (EOC = 1)                   |
| Converter                                                   | SA registe                                        | r                 | 7FH                            | 7FH                             |
| Interrupt<br>functions                                      | Interrupt<br>request                              | IRQ1,IRQ2<br>IRQ4 | Undefined                      | Undefined                       |
| flags<br>(IRQxxx)                                           |                                                   | Other than above  | 0                              | 0                               |
|                                                             | Interrupt<br>(IExxx)                              | enable flags      | 0                              | 0                               |
|                                                             | Interrupt priority<br>selection register<br>(IPS) |                   | 0                              | 0                               |
| INTO, INT1 and INT2<br>mode registers (IMO,<br>IM1 and IM2) |                                                   | 0,0,0             | 0, 0, 0                        |                                 |
| Digital<br>ports                                            | Output buf                                        | fer               | Off                            | Off                             |
| ports                                                       | Output lat                                        | ch .              | Cleared (0)                    | Cleared (0)                     |
| Input/output mode<br>registers (PMGA, PMGB,<br>PMGC)        |                                                   | 0                 | 0                              |                                 |
| Pull-up resistor<br>specification<br>registers (POGA, POGB) |                                                   |                   | 0                              | 0                               |
| Bit sequent<br>BSB3)                                        | ial buffers                                       | (BSBO to          | Retained                       | Undefined                       |

(to be continued)

6427525 0095228 939 **6** 8-3

|            | Hardware                                                                                    | RESET Input in<br>Standby Mode                                                                                                               | RESET Input during<br>Operation |
|------------|---------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------|
| Pin status | P00 to P03, P10 to<br>P13, P20 to P23, P30<br>to P33, P60 to P63,<br>P70 to P73, P80 to P83 | Input                                                                                                                                        | Same as at left                 |
|            | P40 to P43, P50 to P53                                                                      | <ul> <li>When using<br/>internal pull-up<br/>resistor</li> <li> High level</li> <li>When open-drain</li> <li> High-<br/>impedance</li> </ul> | Same as at left                 |
|            | S12 to S32, COMO to COM3                                                                    | *2                                                                                                                                           | Same as at left                 |
|            | BIAS                                                                                        | . With internal<br>split resistor<br>Low level<br>. With no internal<br>split resistor<br>High-<br>impedance                                 | Same as at left                 |

### Table 8-1 Hardware Status after Reset (cont'd)

- \*1: Data in data memory addresses OF8H to OFDH is undefined after RESET input.
  - 2: Display outputs are selected using the  $\rm V_{LCX}$  shown below as the input source.

S12 to S31 :  $V_{LC1}$ COMO to COM2:  $V_{LC2}$ COM3 :  $V_{LC0}$ 

The display output level varies depending on the display output and  $V_{\rm LCX}$  external circuit.

■ 6427525 0095229 875 ■ 8-4 CHAPTER 9. PROM (PROGRAM MEMORY) WRITE AND VERIFY OPERATIONS

The program memory incorporated in the uPD75P336 is one-time PROM. The memory capacity is as follows:

uPD75P336: 16256 words x 8 bits

Write/verify operations on this one-time PROM are executed using the pins shown in the table below. Address updating is performed by means of clock input from the X1 pin, and not by address input.

# Table 9-1 Pin for Using Program Memory Write/Verify Operating Modes

| Pin Name                                                               | Function                                                                                                                  |
|------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------|
| X1, X2                                                                 | Input of address update clock for program memory write/verify. Inverse of X1 pin signal is input to X2 pin.               |
| MDO to MD3<br>(P30 to P33)                                             | Operating mode selection pins for program memory write/verify.                                                            |
| P40 to P43<br>(low-order 4 bits),<br>P50 to P53<br>(high-order 4 bits) | 8-bit data input/output pins for program memory write/verify.                                                             |
| V <sub>DD</sub>                                                        | Supply voltage application pin.<br>Applies 2.7 to 6.0 V in normal operation,<br>and +6 V for program memory write/verify. |
| V <sub>PP</sub>                                                        | Voltage application pin for program memory write/verify (normally V <sub>DD</sub> potential).                             |

NOTE 1: Since the uPD75P336 is not provided with an erase window, program memory contents cannot be erased.

■ 6427525 0095230 597 ■ 9-1 NOTE 2: Pins not used in a program memory write/verify operation are handled as follows:

All pins except XT2 ... Connect to V<sub>SS</sub> with a pull-down resistor.
 XT2 ..... Leave open.

9.1 PROGRAM MEMORY WRITE/VERIFY OPERATING MODES

When +6 V is applied to the  $V_{\rm DD}$  pin and +12.5 V to the  $V_{\rm PP}$  pin, the uPD75P336 is placed in the program memory write/ verify mode. This mode comprises one of the operating modes shown below according to the input signal to pins MD0 to MD3.

|                 | Operating       | Mode | Operating Mode |     |            |                                      |  |
|-----------------|-----------------|------|----------------|-----|------------|--------------------------------------|--|
| v <sub>DD</sub> | V <sub>PP</sub> | MDO  | MD1            | MD2 | MD3        | Operating Mode                       |  |
| +6 V            | +12.5 V         | н    | L              | Н   | L          | Program memory address<br>zero-clear |  |
|                 |                 | L    | н              | н   | . <b>H</b> | Write mode                           |  |
|                 |                 | L    | L              | H   | н          | Verify mode                          |  |
|                 |                 | н    | x              | Н   | н          | Program inhibit mode                 |  |

|  | Table | 9-2 | Operating | Modes |
|--|-------|-----|-----------|-------|
|--|-------|-----|-----------|-------|

Remarks: x: L or H



#### 9.2 PROGRAM MEMORY WRITE PROCEDURE

The procedure for writing to program memory is as shown below, allowing high-speed writing.

- (1) Unused pins are connected to  $V_{SS}$  with a pull-down resistor. The X1 pin is driven low.
- (2) 5 V is supplied to the  $V_{DD}$  and  $V_{PP}$  pins.
- (3) 10 us wait.
- (4) Program memory address zero-clear mode.
- (5) +6 V is supplied to  $V_{DD}$ , +12.5 V to  $V_{PP}$ .
- (6) Program inhibit mode.
- (7) Data is written in 1 ms write mode.
- (8) Program inhibit mode.
- (9) Verify mode. If write is successful go to (10), otherwise repeat (7) through (9).
- (10) (Number of times written in (7) through (9): X) x 1
  ms additional writes.
- (11) Program inhibit mode
- (12) Program memory address is updated (+1) by inputting
  4 pulses to the X1 pin.
- (13) Steps (7) through (12) are repeated until the last address.
- (14) Program memory address zero-clear mode.

■ 6427525 0095232 36T 💻 9-3 (15)  $V_{DD}/V_{PP}$  pin voltage is changed to 5 V.

(16) Power-off.

Steps (2) to (12) of this procedure are shown in the following figure.





### 9.3 PROGRAM MEMORY READ PROCEDURE

uPD75P336 program memory contents can be read using the following procedure. Reading is performed in verify mode.

- (1) Unused pins are connected to  $V_{SS}$  with a pull-down resistor. The X1 pin is driven low.
- (2) 5 V is supplied to the  $V_{DD}$  and  $V_{PP}$  pins.
- (3) 10 us wait.
- (4) Program memory address zero-clear mode.
- (5) +6 V supplied to  $V_{DD}$ , +12.5 V to  $V_{PP}$ .
- (6) Program inhibit mode.
- (7) Verify mode. When clock pulses are input to the X1 pin, data is output sequentially, one address per 4pulse-input cycle.
- (8) Program inhibit mode.
- (9) Program memory address zero-clear mode.
- (10)  $V_{DD}/V_{PP}$  pin voltage is changed to 5 V.

(11) Power-off.

Steps (2) to (9) of this procedure are shown in the following figure.

### ■ 6427525 0095234 132 ■ 9-5





#### CHAPTER 10. INSTRUCTION SET

The uPD75336 instruction set is an improved and extended version of that of the uPD7500 series, the predecessor of the 75X series. Thus, while inheriting the features of the uPD7500 series it constitutes a new epoch-making instruction set, with the following special characteristics.

- (1) Bit-manipulating instructions with a wide range of uses
- (2) Efficient 4-bit manipulating instructions
- (3) 8-bit data transfer instructions
- (4) GETI instruction for reduced program size
- (5) Stacked instructions and radix adjustment instructions for improved program efficiency
- (6) Table referencing instructions suitable for consecutive references
- (7) One-byte relative branch instructions
- (8) Easy-to-understand rearranged standard NEC mnemonics

In addition, see Chapter 3 "Data Memory Operation and Memory Map" for the addressing modes which can be used in data memory operations.



### 10.1 SPECIAL INSTRUCTIONS

An outline is given here of the special instructions in the uPD75336's instruction set.

10.1.1 GETI INSTRUCTION

The GETI instruction is used to convert the following instructions to 1-byte instructions.

(a) Total-space subroutine call instructions

- (b) Branch instructions to the total space
- (C) Any 2-byte 2-machine-cycle instruction (excluding BRCB and CALLF instructions)
- (d) A combination of two 1-byte instructions

The GETI instruction references a table in program memory addresses 0020H to 007FH, and executes the referenced 2byte data as one of the instructions in (a) through (d) above. Therefore the 48 instructions in (a) through (d) can be converted to 1-byte instructions.

Using the GETI instruction to convert frequently used instructions (a) through (d) to 1-byte instructions allows the number of program bytes to be considerably reduced.



#### 10.1.2 BIT MANIPULATION INSTRUCTIONS

uPD75336 bit manipulations can be performed by the following wide variety of instructions.

| (a) | Bit setting              | : | SET1   | mem. bit      |
|-----|--------------------------|---|--------|---------------|
|     |                          |   | SET1   | mem. bit*     |
| (b) | Bit clearing             | : | CLR1   | mem. bit      |
|     |                          |   | CLR1   | mem. bit*     |
| (c) | Bit testing              | : | SKT    | mem. bit      |
|     |                          |   | SKT    | mem. bit*     |
| (đ) | Bit testing              | : | SKF    | mem. bit      |
|     |                          |   | SKF    | mem. bit*     |
| (e) | Bit testing and clearing | : | SKTCLR | mem. bit*     |
| (f) | Boolean operations       | : | AND1   | CY, mem. bit* |
|     |                          |   | OR1    | CY, mem. bit* |
|     |                          |   | XOR1   | CY, mem. bit* |
| (g) | Bit transfer             | : | MOV1   | CY, mem. bit* |
|     |                          |   | MOV1   | mem. bit*, CY |

mem. bit\* is the bit address indicated by bit
manipulation addressing (fmem. bit, pmem. @L, @H + mem.
bit).

In particular, since all the above bit manipulation instructions can always be used on input/output ports, input/output operations can be performed extremely efficiently.

10.1.3 STACKED INSTRUCTIONS

The uPD75336 is provided with the following two kinds of stacked instruction.

(a) MOV A, #n4 or MOV XA, #n8
(b) MOV HL, #n8

"Stacked" means that these two kinds of instruction are located in consecutive addresses. L427525 0095238 888 10-3

Example: A0 : MOV A, #0 A1 : MOV A, #1 XA7: MOV XA, #07

If stacked instructions are arranged in sequence as in this example, if the first address to be executed is AO, the following two instructions are replaced by a NOP instruction before being executed; if the first address to be executed is A1, then the following instruction only is replaced by NOP. In other words, only the first instruction executed is effective and the following instructions are all processed as NOP instructions.

Use of these stacked instructions allows the setting of constants in an accumulator (A register or XA register pair) and setting of constants in the data pointer (HL register pair) to be performed efficiently.

# 10.1.4 RADIX ADJUSTMENT INSTRUCTIONS

Depending on the application, the result of a 4-bit data addition or subtraction (performed in binary) must be converted to decimal or subjected to radix-6 adjustment, as with a time.

For this purpose the uPD75336 instruction set includes radix adjustment instructions for adjusting the result of a 4-bit data addition or subtraction to a number of any desired radix.

(a) Radix adjustment in addition

If the radix for adjustment is m, the following combination adds memory (HL) to the accumulator and performs m-ary adjustment of the result.

■ 6427525 0095239 714 ■ 10-4

ADDS A, #16 - mADDC A, @HL; A, CY  $\leftarrow$  A + (HL) + CY ADDS A, #m

Overflow is left in the carry flag.

If a carry is generated as the result of executing the ADDC A, @HL instruction, the following ADDS A, #n4 instruction is skipped. If no carry is generated the ADDS A, #n4 instruction is executed, but the instruction skipping function at this time is disabled, and the next instruction is not skipped even if a carry is generated as a result of the addition. Therefore, a program can be written after the ADDS A, #n4 instruction.

Example: Decimal addition of accumulator and memory.

ADDS A, #6 ADDC A, @HL; A, CY + A + (HL) + CY ADDS A, #10 :

(b) Radix adjustment in subtraction

If the radix for adjustment is m, the following combination subtracts memory (HL) from the accumulator and performs m-ary adjustment of the result.

SUBC A, @HL ADDS A, #m

Underflow is left in the carry flag.

■ 6427525 0095240 436 ■ 10-5 If no borrow is generated as the result of executing the SUBC A, @HL instruction, the following ADDS A, #n4 instruction is skipped. If a borrow is generated the ADDS A, #n4 instruction is executed, but the instruction skipping function at this time is disabled, the next instruction is not skipped even if a carry is generated as a result of the addition. Therefore, a program can be written after the ADDS A, #n4 instruction.

# 10.1.5 SKIP INSTRUCTIONS AND MACHINE CYCLES REQUIRED FOR SKIPPING

With the uPD75336 instruction set, a program is configured using conditional judgments by means of skipping.

"Skipping" is a function whereby if the skip condition is fulfilled when a skip instruction (instruction with a skip condition) is executed, the following instruction is jumped over (skipped) and the instruction after the skipped instruction is executed.

If a skip is generated, the number of machine cycles required for skipping is as shown below.

- (a) When the instruction (the instruction to be skipped) following the skip instruction is a 3-byte instruction (either the BR !addr instruction or the CALL !addr instruction) : 2 machine cycles
- (b) With instructions other than those in (a): 1 machine cycle

■ 6427525 0095241 372 ■ 10-6

## 10.2 INSTRUCTION SET AND OPERATIONS

(1) Operand notation and description method

Operands are described in the operand field of an instruction in accordance with the description method for the operand notation for that instruction (see the "RA75X Assembler Package User's Manual Language Volume (EEU-730)" for details). When there are several elements in the description method field, one is selected. Capital letters and symbols "+" and "-" are keywords and are written as they are.

With immediate data, the relevant number or label is written.

The symbols given in the various register and flag format diagrams in Chapter 3 to 6 can be written as labels instead of mem, fmem, pmem, bit, and so forth (but note that there are restrictions on labels that can be used for fmem and pmem).

| Notation | Description Method                 |  |  |  |  |  |  |  |  |  |
|----------|------------------------------------|--|--|--|--|--|--|--|--|--|
| reg      | X, A, B, C, D, E, H, L             |  |  |  |  |  |  |  |  |  |
| regl     | X, B, C, D, E, H, L                |  |  |  |  |  |  |  |  |  |
| rp       | XA, BC, DE, HL                     |  |  |  |  |  |  |  |  |  |
| rp1      | BC, DE, HL                         |  |  |  |  |  |  |  |  |  |
| rp2      | BC, DE                             |  |  |  |  |  |  |  |  |  |
| rp'      | XA, BC, DE, HL, XA', BC', DE', HL' |  |  |  |  |  |  |  |  |  |
| rp'1     | BC, DE, HL, XA', BC', DE', HL'     |  |  |  |  |  |  |  |  |  |
| rpa      | HL, HL+, HL-, DE, DL               |  |  |  |  |  |  |  |  |  |
| rpal     | DE, DL                             |  |  |  |  |  |  |  |  |  |
| n4       | 4-bit immediate data or label      |  |  |  |  |  |  |  |  |  |
| n8       | 8-bit immediate data or label      |  |  |  |  |  |  |  |  |  |
| mem      | 8-bit immediate data* or label     |  |  |  |  |  |  |  |  |  |
| bit      | 2-bit immediate data or label      |  |  |  |  |  |  |  |  |  |

(to be continued)

■ 6427525 0095242 209 ■ 10-7

(cont'd)

| Notation                     | Description Method                                                                                                |  |  |  |  |  |  |  |  |  |  |
|------------------------------|-------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|
| fmem. bit                    | IST1, ISTO, MBE, RBE, IExxx, IRQxxx, PORTn.m<br>(n = 0 to 8, m = 0 to 3)                                          |  |  |  |  |  |  |  |  |  |  |
| pmem                         | PORTn (n = 0, 4)                                                                                                  |  |  |  |  |  |  |  |  |  |  |
| addr                         | 0000H to 3F7FH immediate data or label                                                                            |  |  |  |  |  |  |  |  |  |  |
| caddr<br>faddr<br>taddr      | 12-bit immediate data or label<br>11-bit immediate data or label<br>20H to 7FH immediate data (bit0 = 0) or label |  |  |  |  |  |  |  |  |  |  |
| PORTn<br>IExxx<br>RBn<br>MBn | PORTO to PORT8<br>IEBT, IECSI, IETO, IET1, IEO to IE2, IE4, IEW<br>RBO to RB3<br>MBO, MB1, MB2, MB15              |  |  |  |  |  |  |  |  |  |  |

\*: For 8-bit data processing, only an even address can be specified.

(2) Legend for operation descriptions

| A          | : | A register; 4-bit accumulator         |
|------------|---|---------------------------------------|
| в          | : | B register; 4-bit accumulator         |
| С          | : | C register; 4-bit accumulator         |
| D          | : | D register; 4-bit accumulator         |
| Е          | : | E register; 4-bit accumulator         |
| н          | : | H register; 4-bit accumulator         |
| L          | : | L register; 4-bit accumulator         |
| . <b>X</b> | : | X register; 4-bit accumulator         |
| XA         | : | Register pair (XA); 8-bit accumulator |
| BC         | : | Register pair (BC)                    |
| DE         | : | Register pair (DE)                    |
| HL         | : | Register pair (HL)                    |
| XA'        | : | Extended register pair (XA')          |
| BC'        | : | Extended register pair (BC')          |
| DE '       | : | Extended register pair (DE')          |
| HL'        | : | Extended register pair (HL')          |
| PC         | : | Program counter                       |
| SP         | : | Stack pointer                         |
|            |   | 6427525 0095243 145 🖿<br>10-8         |
|            |   |                                       |

| CY    | :         | Carry flag; bit accumulator           |
|-------|-----------|---------------------------------------|
| PSW   | :         | Program status word                   |
| MBE   | :         | Memory bank enable flag               |
| RBE   | :         | Register bank enable flag             |
| PORTr | <b>1:</b> | Port n $(n = 0 \text{ to } 8)$        |
| IME   | :         | Interrupt master enable flag          |
| IPS   | :         | Interrupt priority selection register |
| IExxx | <b>K:</b> | Interrupt enable flag                 |
| RBS   | :         | Register bank selection register      |
| MBS   | :         | Memory bank selection register        |
| BS    | :         | Bank selection register               |
| PCC   | :         | Processor clock control register      |
| •     | :         | Address, bit delimiter                |
| (xx)  | :         | Contents addressed by xx              |
| ххH   | :         | Hexadecimal data                      |

# (3) Explanation of symbols in addressing area field

| <u> </u>   | MB=MBE · MBS                              |            |             |  |  |
|------------|-------------------------------------------|------------|-------------|--|--|
| *1         | MB=0, 1, 2, 15                            |            |             |  |  |
| * 2        | MB= 0                                     |            |             |  |  |
|            | MBE = 0 : MB = 0 (000H-07FH)              | Data       | Data Memory |  |  |
|            | MB = 15 (F80H-FFFH)                       | Addr       | ressing     |  |  |
| *3         | MBE=1 : MB=MBS                            |            |             |  |  |
|            | MB=0, 1, 2, 15                            |            |             |  |  |
| * 4        | MB=15. fmem=FBOH-FBFH, FFOH-FFFH          |            |             |  |  |
| * 5        | MB=15. pmem=FC0H-FFFH                     |            |             |  |  |
| * 6        | addr = 0000H - 3F7FH                      |            |             |  |  |
| *7         | addr= (CurrentPC) - 15~(CurrentPC) - 1    |            | -           |  |  |
| <b>*</b> 1 | = $(CurrentPC) + 2 \sim (CurrentPC) + 16$ | Pro        | gram Memory |  |  |
| *8         | caddr=n000H-nFFFH                         | Addressing |             |  |  |
| * 0        | $n = PC_{13}, PC_{12} = 0 - 3$            |            |             |  |  |
| * 9        | faddr = 0000H - 07FFH                     |            |             |  |  |
| * 10       | taddr = 0020H - 007FH                     |            |             |  |  |

■ 6427525 0095244 081 ■ 10-9

Remarks 1: MB indicates the accessible memory bank. 2: With \*2 MB = 0 regardless of MBE/MBS. 3: With \*4 & \*5 MB = 15 regardless of MBE/MBS. 4: \*6 to \*10 indicate the respective addressable areas.

(4) Explanation of machine cycle field

S indicates the number of machine cycles required for the skip operation by an instruction with a skip function. The value of S varies as follows:

- . When no skip is performed ..... S = 0
- . When the instruction to be skipped is a 1-
- byte or 2-byte instruction ..... S = 1
- . When the instruction to be skipped is a 3byte instruction\* ..... S = 2
  - - \*: BR !addr, CALL !addr instruction

NOTE: The GETI instruction is skipped in 1 machine cycle.

One machine cycle is equal to one cycle of the CPU clock ; any of four times can be selected by setting the PCC register (see 5.2.2 (1) "Processor clock control register").

# ■ 6427525 0095245 ТЪ8 ■ 10-10

| NOTE 1   | Mnemonic | Operands         | No. of<br>Bytes | Machine<br>Cycles | Operation                                             | Address-<br>ing Area | Skip<br>Condition |
|----------|----------|------------------|-----------------|-------------------|-------------------------------------------------------|----------------------|-------------------|
|          |          | A. ≓n4           | 1               | 1                 | A←n4                                                  |                      | Stack A           |
|          |          | regl. #n4        | 2               | 2                 | regl⊷n4                                               |                      |                   |
|          |          | XA, #n8          | 2               | 2                 | XA←n8                                                 |                      | Stack A           |
|          |          | HL. ≢n8          | 2               | 2.                | HL⊷n8                                                 |                      | Stack B           |
|          |          | rp2, <b>#n</b> 8 | 2               | 2                 | rp2←n8                                                |                      |                   |
|          |          | A. @HL           | 1               | 1                 | A← (HL)                                               | *1                   |                   |
|          |          | A.@HL+           | 1               | 2+S               | $A \leftarrow (HL), \text{ then } L \leftarrow L + 1$ | *1                   | L=0               |
|          |          | A.@HL-           | 1               | 2+S               | $A \leftarrow (HL)$ , then $L \leftarrow L - 1$       | *1                   | L=FH              |
|          |          | A. @rpal         | 1               | 1                 | A← (rpal)                                             | *2                   |                   |
|          |          | XA, @HL          | 2               | 2                 | XA← (HL)                                              | *1                   |                   |
|          | MOV      | @hl. A           | 1               | 1                 | (HL) ←A                                               | *1                   |                   |
|          |          | @hl, XA          | 2               | 2                 | (HL) ←XA                                              | *1                   |                   |
|          |          | Ā. mem           | 2               | 2                 | A← (mem)                                              | *3                   |                   |
|          |          | XA, mem          | 2               | 2                 | XA← (mem)                                             | *3                   |                   |
| er       |          | mem. A           | 2               | 2                 | (mem) ←A                                              | *3                   |                   |
| Transfer |          | mem, XA          | 2               | 2                 | (mem) ←XA                                             | *3                   |                   |
| Τr       |          | A. reg           | 2               | 2                 | A←reg                                                 |                      |                   |
|          |          | XA, rpʻ          | 2               | 2                 | XA←rp'                                                | <u></u>              |                   |
|          |          | regl, A          | 2               | 2                 | regl←A                                                |                      |                   |
|          |          | rp'1, XA         | 2               | 2                 | rp'l←XA                                               |                      |                   |
|          |          | A, @HL           | 1               | 1                 | A- (HL)                                               | *1                   |                   |
|          |          | a, @hl+          | 1               | 2+S               | $A \rightarrow (HL)$ , then $L \leftarrow L+1$        | *1                   | L=0 .             |
|          |          | a, @hl-          | 1               | 2+S               | A- (HL), then $L \leftarrow L = 1$                    | *1                   | L=FH              |
|          |          | A, @rpal         | 1               | 1                 | A- (rpal)                                             | *2                   |                   |
|          | ХСН      | XA, @HL          | 2               | 2                 | XA~ (HL)                                              | *1                   |                   |
|          |          | A. mem           | 2               | 2                 | A↔ (mem)                                              | *3                   |                   |
|          |          | XA. mem          | 2               | 2                 | XA~ (mem)                                             | *3                   |                   |
|          |          | A. regl          | 1               | 1                 | A-regl                                                |                      |                   |
|          |          | XA. 17           | 2               | 2                 | ХА⊶гр′                                                |                      |                   |
| E 2      | MOVT     | XA. @PCDE        | 1               | 3                 | $XA \leftarrow (PC_{13-8} + DE)_{ROM}$                |                      |                   |
| NOTE     | TATOA I  | XA. @PCXA        | 1               | 3                 | $XA \leftarrow (PC_{13-8} + XA)_{ROM}$                |                      |                   |

NOTE 1: Instruction Group

2: Table reference

■ 6427525 0095246 954 ■ 10-11

| NOTE      | Mnemoni | c Operands      | No. of<br>Bytes | Machine<br>Cycles | Operation                                             | Address-<br>ing Area | Skip<br>Condition |
|-----------|---------|-----------------|-----------------|-------------------|-------------------------------------------------------|----------------------|-------------------|
|           |         | CY, fmem. bit   | 2               | 2                 | CY←(fmem.bit)                                         | *4                   |                   |
| fer       |         | CY, pmem. @L    | 2               | 2                 | $CY \leftarrow (pmem_{7-2} + L_{3-2}, bit (L_{1-0}))$ | *5                   |                   |
| transfer  | MOVI    | CY, @H+mem. bit | 2               | 2                 | CY←(H+mem <sub>3-0</sub> bit)                         | *1                   |                   |
|           |         | fmem, bit, CY   | 2               | 2                 | (fmem.bit) ←CY                                        | *4                   |                   |
| Bit       |         | pmem. @L, CY    | 2               | 2                 | $(pmem_{7-2}+L_{3-2}, bit(L_{1-0})) \leftarrow CY$    | *5                   |                   |
|           |         | @H+mem.bit,CY   | 2               | 2                 | (H+mem <sub>3-0</sub> . bit) ←CY                      | *1                   |                   |
|           |         | A, #n4          | 1               | 1+S               | Ā←Ā+n4                                                |                      | Carry             |
|           |         | XA, #n8         | 2               | 2+S               | XA←XA+n8                                              |                      | "                 |
|           | ADDS    | A, @HL          | 1               | 1+S               | A←A+(HL)                                              | *1                   | 11                |
|           |         | XA, rpʻ         | 2               | 2+S               | XA←XA+rp′                                             |                      | "                 |
|           |         | rp'1, XA        | 2               | 2+S               | rp'l←rp'l+XA                                          |                      | "                 |
|           |         | A, @HL          | 1               | 1                 | $A, CY \leftarrow A + (HL) + CY$                      | *1                   |                   |
|           | ADDC    | XA, rp'         | 2               | 2                 | XA. CY-XA+rp'+CY                                      |                      |                   |
|           |         | rp'l, XA        | 2               | 2                 | rp'l,CY←rp'l+XA+CY                                    |                      |                   |
|           |         | A, @HL          | 1.              | 1+S               | A←A−(HL)                                              | *1                   | borrow            |
|           | SUBS    | XA, rpʻ         | 2               | 2+S               | ХА←ХА-гр′                                             |                      | //                |
| _         |         | rp'l, XA        | 2               | 2+S               | rp'l←rp'l−XA                                          |                      | //                |
| Operation |         | A. @HL          | 1               | 1                 | A, CY←A - (HL) - CY                                   | *1                   |                   |
| erat      | SUBC    | XA, rp'         | 2               | 2                 | XA, CY←XA-rp'-CY                                      |                      |                   |
| ŏďo       |         | rp'l,XA         | 2               | 2                 | rp'l, CY←rp'l-XA-CY                                   |                      |                   |
|           |         | A. #n4          | 2               | 2                 | A←A∧n4                                                |                      |                   |
|           | AND     | A, @HL          | 1               | 1                 | A←A∧(HL)                                              | *1                   |                   |
|           |         | XArp'           | 2               | 2                 | XA←XA∧rp′                                             |                      |                   |
|           |         | rp'l,XA         | 2               | 2                 | rp'l←rp'l∧XA                                          |                      |                   |
|           |         | A. #n4          | 2               | 2                 | A←A∨n4                                                |                      |                   |
|           | OR      | A, @HL          | 1               | 1                 | A←A∨(HL)                                              | *1                   |                   |
|           |         | XA, rp'         | 2               | 2                 | XA←XA∨rp'                                             |                      |                   |
|           |         | rp'l.XA         | 2               | 2                 | rp'1←rp'1∨XA                                          |                      |                   |
|           |         | A, #n4          | 2               | 2                 | A←A <del>∀</del> n4                                   |                      |                   |
|           | XOR     | A. @HL          | 1               | 1                 | A←A∀(HL)                                              | *1                   |                   |
|           |         | XA, rp'         | 2               | 2                 | XA←XA <del>∀r</del> p′                                |                      |                   |
|           |         | гр'1. ХА        | 2               | 2 1               | rpʻl←rpʻl∀XA                                          |                      |                   |

NOTE : Instruction Group

■ 6427525 0095247 890 ■ 10-12

| NOTE 1    | Mnemonic | Operands | No. of<br>Bytes | Machine<br>Cycles | Operation                                                      | Address-<br>ing Area | Skip<br>Condition |
|-----------|----------|----------|-----------------|-------------------|----------------------------------------------------------------|----------------------|-------------------|
| NOTE<br>2 | RORC     | A        | 1               | 1                 | $CY \leftarrow A_0, A_3 \leftarrow CY, A_{n-1} \leftarrow A_n$ |                      |                   |
| 2v        | NOT      | A        | 2               | 2                 | A←Ā                                                            |                      |                   |
|           |          | reg      | 1               | 1+S               | reg←reg+1                                                      |                      | reg=0             |
|           | INCS     | rpl      | 1               | 1+S.              | rpl←rpl+l                                                      |                      | rpl=00H           |
| а<br>1    | INCS     | @HL      | 2               | 2+S               | $(HL) \leftarrow (HL) + 1$                                     | *1                   | (HL)=0            |
| NOTE      |          | mem      | 2               | 2 <b>+</b> \$     | $(mem) \leftarrow (mem) + 1$                                   | *3                   | (mem) =0          |
|           | DECS     | reg      | 1               | 1+S               | reg←reg-l                                                      |                      | reg=FH            |
|           | DECS     | rpʻ      | 2               | 2+S               | rp'←rp'−l                                                      |                      | rp'=FFH           |
|           |          | reg, #n4 | 2               | 2+S               | Skip if reg=n4                                                 |                      | reg=n4            |
|           |          | @HL, #n4 | 2               | 2 <b>+</b> S      | Skip if (HL)=n4                                                | *1                   | (HL) = n4         |
| are       | SKE      | a, @hl   | 1               | 1+S               | Skip if A= (HL)                                                | *1                   | A = (HL)          |
| Compare   | SAL      | XA, @HL  | 2               | 2+S               | Skip if XA = (HL)                                              | *1                   | XA = (HL)         |
| Ŭ         |          | A, reg   | 2               | 2+S               | Skip if A=reg                                                  |                      | A=reg             |
|           |          | XA, rp'  | 2               | 2+S               | Skip if XA=rp'                                                 |                      | XA=rp'            |
|           | SET1     | CY       | 1               | 1                 | Сү+1                                                           |                      |                   |
| Е<br>4    | CLR1     | СҮ       | 1               | 1                 | СҮ⊷О                                                           |                      |                   |
| NOTE      | SKT      | СҮ       | 1               | 1+S               | Skip if CY=1                                                   |                      | CY=1              |
|           | NOT1     | СҮ       | 1               | 1                 | CY+ <del>C</del> Y                                             |                      |                   |

NOTE 1: Instruction Group 2: Accumulator Operating 3: Increment/decrement 4: Carry flag manipulating

🖬 6427525 0095248 727 🔳 10-13

| amOM             | Mnemoni | C Operands      | No. Of<br>Bytes | Machine<br>Cycles | Operation                                                                | Address-<br>ing Area | Skip<br>Condition  |
|------------------|---------|-----------------|-----------------|-------------------|--------------------------------------------------------------------------|----------------------|--------------------|
|                  |         | mem, bit        | 2               | 2                 | (mem. bit) ←1                                                            | *3                   | -                  |
|                  | SET1    | fmem. bit       | 2               | 2                 | (fmem. bit) ←1                                                           | *4                   |                    |
|                  |         | pmem. @L        | 2               | 2                 | $(pmem_{7-2}+L_{3-2}, bit (L_{1-0})) \leftarrow 1$                       | *5                   |                    |
|                  |         | @H+mem.bit      | 2               | 2                 | $(H + mem_{3-0}, bit) \leftarrow 1$                                      | *1                   |                    |
|                  | 1       | mem. bit        | 2               | 2                 | (mem. bit) ←0                                                            | *3                   |                    |
|                  | CLR1    | fmem. bit       | 2               | 2                 | (fmem. bit) ←0                                                           | *4                   |                    |
|                  |         | pmem. @L        | 2               | 2                 | $(pmem_{7-2}+L_{3-2}, bit(L_{1-0})) \leftarrow 0$                        | *5                   |                    |
|                  |         | @H+mem.bit      | 2               | 2                 | (H+mem <sub>3-0</sub> bit) ←0                                            | *1                   |                    |
|                  |         | mem. bit        | 2               | 2+S               | Skip if (mem. bit) = 1                                                   | *3                   | (mem. bit) = 1     |
|                  | SKT     | fmem. bit       | 2               | 2+S               | Skip if (fmem, bit) = 1                                                  | *4                   | (fmem. bit) = 1    |
| ing              |         | pmem. @L        | 2               | 2+S               | Skip if $(pmem_{7-2}+L_{3-2}, bit(L_{1-0})) = 1$                         | *5                   | (pmem. @L) = 1     |
| Iat              |         | @H+mem_bit      | 2               | 2+S               | Skip if $(H + mem_{3-0}, bit) = 1$                                       | *1                   | (@H+mem.bit)=1     |
| bit manipulating |         | mem. bit        | 2               | 2+S               | Skip if (mem. bit) = 0                                                   | *3                   | (mem. bit) =0      |
| mai              | SKF     | fmem, bit       | 2               | 2+S               | Skip if (fmem. bit) =0                                                   | *4                   | (fmem. bit) =0     |
| bit              |         | pmem. @L        | 2               | 2+S               | Skip if $(pmem_{7-2}+L_{3-2}, bit (L_{i-0})) = 0$                        | *5                   | (pmem.@L)=0        |
|                  |         | @H+mem. bit     | 2               | 2+S               | Skip if $(H + mem_{3-0}, bit) = 0$                                       | *1                   | (@H+mem.bit)=0     |
| Метогу           |         | fmem. bit       | 2               | 2+S               | Skip if (fmem, bit) = 1 and clear                                        | *4                   | (fmem. bit) = 1    |
| 2                | SKTCLR  | pmem. @L        | 2               | 2+S               | Skip if $(pmem_{7-2}+L_{3-2}, bit(L_{1-3})=i$ and clear                  | *5                   | (pmem.@L) = 1      |
|                  |         | @H+mem. bit     | 2               | 2+S               | Skip if $(H + mem_{3-0}, bit) = 1$ and clear                             | *1                   | $(@H+mem_bit) = 1$ |
|                  |         | CY, fmem. bit   | 2               | 2                 | CY←CY∧(fmem. bit)                                                        | *4                   |                    |
|                  | AND1    | CY, pmem. @L    | 2               | 2                 | $CY \leftarrow CY \land (pmem_{7-2} + L_{5-2}, bit (L_{1-0}))$           | *5                   |                    |
|                  |         | CY, @H+mem. bit | 2               | 2                 | $CY \leftarrow CY \land (H + mem_{3-0}, bit)$                            | *1                   |                    |
|                  |         | CY, fmem. bit   | 2               | 2                 | CY←CY∨ (fmem. bit)                                                       | *4                   |                    |
|                  | ORI     | CY, pmem. @L    | 2               | 2                 | $CY - CY \vee (pmem_{7-2} + L_{3-2}, bit(L_{1-0}))$                      | *5                   |                    |
|                  |         | CY, @H+mem. bit | 2               | 2                 | $CY \leftarrow CY \lor (H + mem_{3-0}, bit)$                             | *1                   |                    |
|                  |         | CY, fmem. bit.  | 2               | 2                 | CY←CY∀ (fmem. bit)                                                       | *4                   |                    |
|                  | XORI    | CY, pmem. @L    | 2               | 2                 | $CY \leftarrow CY \forall (pmem_{7-2} + L_{3-2} \text{ bit } (L_{1-0}))$ | *5                   |                    |
|                  |         | CY, @H+mem. bit | 2               | 2                 | CY←CY∀(H+mem <sub>3-0</sub> , bit)                                       | *1                   |                    |

NOTE: Instruction Group

**6**427525 0095249 663 **6** 

| NOTE             | Mnemonic | Operands | No. of<br>Bytes | Machine<br>Cycles | Operation                                                                                                                                                                            | Address-<br>ing Area | Skip<br>Condition |
|------------------|----------|----------|-----------------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|-------------------|
| Branch           | BR       | addr     |                 |                   | PC <sub>13-0</sub> ←addr<br>Most appropriate<br>instruction of BR<br>!addr, BRCB ! caddr<br>and BR Saddr is<br>selected by<br>assembler.                                             | *6                   |                   |
| Bre              |          | ! addr   | 3               | 3                 | PC <sub>13-0</sub> ←addr                                                                                                                                                             | *6                   |                   |
|                  |          | \$ addr  | 1               | 2                 | PC <sub>13-0</sub> ←addr                                                                                                                                                             | *7                   |                   |
|                  |          | PÇDE     | 2               | 3                 | PC <sub>13-0</sub> ←PC <sub>13-8</sub> +DE                                                                                                                                           |                      |                   |
|                  |          | PCXA     | 2               | 3                 | PC <sub>13-0</sub> ←PC <sub>13-8</sub> +XÅ                                                                                                                                           |                      |                   |
|                  | BRCB     | ! caddr  | 2               | 2                 | PC <sub>13-0</sub> ←PC <sub>13</sub> , PC <sub>12</sub> +caddr <sub>11-0</sub>                                                                                                       | *8                   |                   |
|                  | CALL     | ! addr   | 3               | 3                 | $(SP-4) (SP-1) (SP-2) \leftarrow PC_{11-0}$<br>$(SP-3) \leftarrow MBE, RBE, PC_{13}, PC_{12}$<br>$PC_{13-0} \leftarrow addr, SP \leftarrow SP-4$                                     | *6                   |                   |
| 01               | CALLF    | ! faddr  | 2               | 2                 | $(SP-4)(SP-1)(SP-2) \leftarrow PC_{11-0}$<br>$(SP-3) \leftarrow MBE, RBE, PC_{13}, PC_{12}$<br>$PC_{13-0} \leftarrow 000 + faddr, SP \leftarrow SP - 4$                              | *9                   |                   |
| ack control      | RET      |          | 1               | 3                 | MBE, RBE, PC <sub>13</sub> , PC <sub>12</sub> $\leftarrow$ (SP+1)<br>PC <sub>11-0</sub> $\leftarrow$ (SP) (SP+3) (SP+2)<br>SP $\leftarrow$ SP+4                                      |                      |                   |
| Subroutine/stack | RETS     |          | 1               | 3+5               | MBE, RBE, PC <sub>13</sub> , PC <sub>12</sub> $\leftarrow$ (SP + 1)<br>PC <sub>11-0</sub> $\leftarrow$ (SP) (SP + 3) (SP + 2)<br>SP $\leftarrow$ SP + 4<br>then skip unconditionally |                      | Unconditional     |
|                  | RETI     |          | 1               | 3                 | MBE, RBE, PC <sub>13</sub> , PC <sub>12</sub> , $\leftarrow$ (SP+1)<br>PC <sub>11-0</sub> $\leftarrow$ (SP) (SP+3) (SP+2)<br>PSW $\leftarrow$ (SP+4) (SP+5), SP $\leftarrow$ SP+6    |                      |                   |
|                  |          | rp       | 1               | 1                 | (SP-1) (SP-2) ← rp, SP ← SP - 2                                                                                                                                                      |                      |                   |
|                  | PUSH     | BS       | 2               | 2                 | (SP-1)←MBS, (SP-2)←RBS, SP←SP-2                                                                                                                                                      |                      |                   |
|                  |          | тр       | 1               | 1                 | $rp \leftarrow (SP+1) (SP), SP \leftarrow SP+2$                                                                                                                                      |                      |                   |
|                  | POP      | BS       | 2               | 2                 | $MBS \leftarrow (SP+1), RBS \leftarrow (SP), SP \leftarrow SP+2$                                                                                                                     |                      |                   |

NOTE: Instruction Group

■ 6427525 0095250 385 ■ 10-15

| NOTE 1  | Mnemonic | Operands  | No. of<br>Bytes | Machine<br>Cycles | Operation                                                                                                                                                                                                                                  | Address-<br>ing Area | Skip<br>Condition                         |
|---------|----------|-----------|-----------------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|-------------------------------------------|
| ~       | EI       |           | 2               | 2                 | IME (IPS. 3) ←1                                                                                                                                                                                                                            |                      |                                           |
| NOTE    |          | ΙΕ×××     | 2               | 2                 | $IE \times \times \times \leftarrow 1$                                                                                                                                                                                                     |                      |                                           |
| ĝ       | DI       |           | 2               | 2                 | IME (IPS. 3) ←0                                                                                                                                                                                                                            |                      |                                           |
|         |          | IE×××     | 2               | 2                 | IE×××←0                                                                                                                                                                                                                                    |                      |                                           |
|         | IN*      | A, PORTn  | 2               | 2                 | A←PORTn (n=0-8)                                                                                                                                                                                                                            | 1                    |                                           |
| 1       |          | XA. PORTn | 2               | 2                 | XA←PORTn+1, PORTn (n=4,6)                                                                                                                                                                                                                  |                      |                                           |
| NOTE    | OUT*     | PORTn, A  | 2               | 2                 | PORTn $\leftarrow A$ (n=2-8)                                                                                                                                                                                                               |                      |                                           |
|         |          | PORTn, XA | 2               | 2                 | PORTn+1, PORTn+XA (n=4,6)                                                                                                                                                                                                                  |                      |                                           |
| 4       | HALT     |           | 2               | 2                 | Set HALT Mode (PCC. 2-1)                                                                                                                                                                                                                   |                      |                                           |
| NOTE    | STOP     |           | 2               | 2                 | Set STOP Mode (PCC. 3-1)                                                                                                                                                                                                                   |                      |                                           |
| Ž       | NOP      |           | 1               | 1                 | No Operation                                                                                                                                                                                                                               |                      |                                           |
|         | SEL      | RBn       | 2               | 2                 | RBS←n (n=0-3)                                                                                                                                                                                                                              |                      |                                           |
|         |          | MBn       | 2               | 2                 | MBS←n (n=0, 1, 2, 15)                                                                                                                                                                                                                      |                      |                                           |
|         |          |           |                 |                   | With TBR instruction<br>PC <sub>13-0</sub> (taddr) <sub>5-0</sub> + (taddr + 1)                                                                                                                                                            |                      |                                           |
| Special | GETI     | taddr     | 1               | 3                 | With TCALL instruction<br>$(SP-4)(SP-1)(SP-2)+PC_{11-0}$<br>$(SP-3)+MBE, RBE, PC_{13}, PC_{12}$<br>$PC_{13-0}+(taddr)_{5-0}+(taddr+1)$<br>SP+SP-4<br>With other than TBR<br>and TCALL instructions<br>(taddr) + 1<br>instruction execution | * 10                 | Depending on<br>referenced<br>instruction |

\*: When an IN/OUT instruction is executed, it is necessary to set MBE = 0 or MBE = 1 and MBS = 15.

Remarks: The TBR and TCALL instructions are

assembler pseudo-instruction for GETI instruction table definition.

- NOTE 1: Instruction Group 2: Interrupt control 3: Input/output 4: CPU control

🗖 6427525 0095251 211 🖿 10-16

#### 10.3 INSTRUCTION OPERATION CODES

### (1) Explanation of operation code symbols

| $R_2 R_1 R_0$ | reg   |        | -              |     | P2 | $P_1$ | Po | reg-pa | ir _          |
|---------------|-------|--------|----------------|-----|----|-------|----|--------|---------------|
| 000           | A     |        |                |     | 0  | 0     | 0  | XA     |               |
| 001           | x     |        | Ī              |     | 0  | 0     | 1  | XA'    |               |
| 010           | L     |        |                |     | Ō  | 1     | 0  | HL.    |               |
| 011           | н     |        |                |     | 0  | 1     | 1  | HL′    |               |
| 100           | Е     | re     | regl           |     | 1  | 0     | 0  | DE     | rp'<br>  rp'l |
| 101           | D     |        |                |     | 1  | 0     | 1  | DE'    |               |
| 1 1 0         | с     |        |                |     | 1  | 1     | 0  | BC     |               |
| 1 1 1         | в     |        | , [            |     | 1  | 1     | 1  | BC'    |               |
|               |       | ر      | - <del>-</del> | -   |    |       |    |        |               |
| $Q_2 Q_1 Q_0$ | addre | essing | -              | -   | P2 | $P_1$ | re | g-pair | т             |
| 000           | @H    | L      |                | Ī   | 0  | 0     |    | XA     |               |
| 010           | @H    | L+     |                |     | 0  | 1     |    | HI.    |               |
| 011           | @H    | L-     | _ @:           | rpa | 1  | 0     |    | DE     | rp1<br>rp2    |
| 100           | @D    | E      | ¶<br>@rpal     |     | 1  | 1     |    | BC     |               |
| 101           | @D    | L      | erpar          | •   |    |       |    |        |               |
|               |       |        |                |     |    |       |    |        |               |

| N₅ | $N_2$ | $N_1$ | No | Έ×××  |
|----|-------|-------|----|-------|
| 0  | 0     | 0     | 0  | IEBT  |
| 0  | 0     | 1     | 0  | IEW   |
| 0  | 1     | 0     | 0  | IETO  |
| 0  | 1     | 0     | 1  | IECSI |
| 0  | 1     | 1     | 0  | IEO   |
| 0  | 1     | 1     | 1  | IE2   |
| 1  | 0     | 0     | 0  | IE4   |
| 1  | 1     | 0     | 0  | IET1  |
| 1  | 1     | 1     | 0  | Εl    |

- Sn: Immediate data for one's complement of
   [relative address distance (15 to 1) from
   branch destination address]
- (2) Bit manipulation addressing operation codes

\*1 in the operand field indicates that the following 3 kinds of addressing are possible:

- . fmem.bit
- . pmem.@L
- . @H+mem.bit

The 2nd byte \*2 of the operation code for the above addressing methods is as shown in the table below.

| *1         | 2nd | Byt | e c            | of (           | Ope:           | rat            | ion            | Code           | Accessible Bits                            |
|------------|-----|-----|----------------|----------------|----------------|----------------|----------------|----------------|--------------------------------------------|
| fmem.bit   | 1   | 0   | B <sub>1</sub> | Bo             | F <sub>3</sub> | F <sub>2</sub> | F <sub>1</sub> | F <sub>0</sub> | Manipulable bits of<br>FBOH through FBFH   |
|            | . 1 | 1   | Β <sub>1</sub> | B <sub>0</sub> | F <sub>3</sub> | F <sub>2</sub> | F <sub>1</sub> | F <sub>0</sub> | Manipulable bits of<br>FFOH through FFFH   |
| pmem.@L    | 0   | 1   | 0              | 0              | G <sub>3</sub> | G₂             | Gı             | G <sub>0</sub> | Manipulable bits of<br>FCOH through FFFH   |
| @H+mem.bit | 0   | 0   | B <sub>1</sub> | B <sub>0</sub> | D 3            | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | Manipulable bits of accessible memory bank |

- B<sub>n</sub>: Immediate data for "bit"
- G<sub>n</sub>: Immediate data for "pmem" (indicates bits 5 through 2
   of address)
- D<sub>n</sub>: Immediate data for "mem" (indicates low-order 4 bits of address)

6427525 0095253 094 **6** 10-18

| ш           | Mnemonic | Operands           | Operation Code                                                                      |  |  |  |  |
|-------------|----------|--------------------|-------------------------------------------------------------------------------------|--|--|--|--|
| N<br>N      |          |                    | B <sub>1</sub> B <sub>2</sub> B <sub>3</sub>                                        |  |  |  |  |
|             |          | A, #n4             | 0 1 1 1 I <sub>3</sub> I <sub>2</sub> I <sub>1</sub> I <sub>0</sub>                 |  |  |  |  |
|             |          | regl, ≢n4          | $1 \ 0 \ 0 \ 1 \ 1 \ 0 \ 1 \ 0 \ I_3 \ I_2 \ I_1 \ I_0 \ 1 \ R_2 \ R_1 \ R_0$       |  |  |  |  |
|             |          | rp. #n8            | $1 \ 0 \ 0 \ 0 \ 1 \ P_2 \ P_1 \ 1 \ I_7 \ I_6 \ I_5 \ I_4 \ I_3 \ I_2 \ I_1 \ I_0$ |  |  |  |  |
|             |          | A, @rpa            | $1 \ 1 \ 1 \ 0 \ 0 \ Q_2 \ Q_1 \ Q_0$                                               |  |  |  |  |
|             |          | XA, @HL            | 1010101000011000                                                                    |  |  |  |  |
|             |          | @HL. A             | 1 1 1 0 1 0 0 0                                                                     |  |  |  |  |
|             |          | @hl, Xa            | 1010101000010000                                                                    |  |  |  |  |
|             | MOV      | A, mem             | $1 \ 0 \ 1 \ 0 \ 0 \ 0 \ 1 \ 1 \ D_7 \ D_6 \ D_5 \ D_4 \ D_3 \ D_2 \ D_1 \ D_0$     |  |  |  |  |
|             |          | XĂ, mem            | $1 \ 0 \ 1 \ 0 \ 0 \ 0 \ 1 \ 0 \ D_7 \ D_6 \ D_5 \ D_4 \ D_3 \ D_2 \ D_1 \ 0$       |  |  |  |  |
|             |          | mem, Å             | $1 \ 0 \ 0 \ 1 \ 0 \ 0 \ 1 \ 1 \ D_7 \ D_6 \ D_5 \ D_4 \ D_3 \ D_2 \ D_1 \ D_0$     |  |  |  |  |
| er          |          | mem, XA            | $1 \ 0 \ 0 \ 1 \ 0 \ 0 \ 1 \ 0 \ D_7 \ D_6 \ D_5 \ D_4 \ D_3 \ D_2 \ D_1 \ 0$       |  |  |  |  |
| Transfér    |          | A, reg             | 1001100101111R <sub>2</sub> R <sub>1</sub> R <sub>0</sub>                           |  |  |  |  |
| Tre         |          | XA. m              | 1010101001011P <sub>2</sub> P <sub>1</sub> P <sub>0</sub>                           |  |  |  |  |
|             |          | regl.A             | 1001100101110R <sub>2</sub> R <sub>1</sub> R <sub>0</sub>                           |  |  |  |  |
|             |          | rp'l.XA            | 1010101001010P <sub>2</sub> P <sub>1</sub> P <sub>0</sub>                           |  |  |  |  |
|             | хсн      | Ă. @rpa            | $1 \ 1 \ 1 \ 0 \ 1 \ Q_2 Q_1 Q_0$                                                   |  |  |  |  |
|             |          | XA. @HL            | 101010100010001                                                                     |  |  |  |  |
|             |          | Ă, mem             | $1 \ 0 \ 1 \ 1 \ 0 \ 0 \ 1 \ 1 \ D_7 \ D_6 \ D_5 \ D_4 \ D_3 \ D_2 \ D_1 \ D_0$     |  |  |  |  |
|             |          | XA, mem            | $1 \ 0 \ 1 \ 1 \ 0 \ 0 \ 1 \ 0 \ D_7 \ D_6 \ D_5 \ D_4 \ D_3 \ D_2 \ D_1 \ 0$       |  |  |  |  |
|             |          | A. regl            | 1 1 0 1 1 R <sub>2</sub> R <sub>1</sub> R <sub>0</sub>                              |  |  |  |  |
|             |          | XA. rp'            | 10101010000P <sub>2</sub> P <sub>1</sub> P <sub>0</sub>                             |  |  |  |  |
| Ш<br>Ц<br>Ц | MOVT     | XA. @PCDE          | 1 1 0 1 0 1 0 0                                                                     |  |  |  |  |
| N.          |          | XA, @PCXA          | 1 1 0 1 0 0 0 0                                                                     |  |  |  |  |
| TE          | MOV1     | CY. * 1            | 10111101 *2                                                                         |  |  |  |  |
| NOTE<br>3   |          | ( <u>* 1</u> ), CY | 10011011 *2                                                                         |  |  |  |  |

NOTE 1: Instruction Group

2: Table reference

3: Bit transfer

■ 6427525 0095254 T20 ■ 10-19

| <b>F</b>  | Mnemoni | c Operands | Operation Code                                                      |                                                        |                |  |  |
|-----------|---------|------------|---------------------------------------------------------------------|--------------------------------------------------------|----------------|--|--|
| Amon N    | 2       | operands   | Bi                                                                  | B <sub>2</sub>                                         | B <sub>3</sub> |  |  |
|           |         | A, #n4     | 0 1 1 0 I <sub>3</sub> I <sub>2</sub> I <sub>1</sub> I <sub>0</sub> |                                                        |                |  |  |
|           |         | XA, #n8    | 10111001                                                            | I7 I6 I5 L4 I3 I2 I1 I0                                |                |  |  |
|           | ĀDDS    | A. @HL     | 11010010                                                            |                                                        |                |  |  |
| 1         |         | ХА, гр'    | 10101010                                                            | $1 1 0 0 1 P_2 P_1 P_0$                                |                |  |  |
|           |         | rp'l, XA   | 10101010                                                            | 1 1 0 0 0 P <sub>2</sub> P <sub>1</sub> P <sub>0</sub> |                |  |  |
|           |         | A, @HL     | 10101001                                                            |                                                        |                |  |  |
|           | ADDC    | ХА, гр'    | 10101010                                                            | 1 1 0 1 1 P <sub>2</sub> P <sub>1</sub> P <sub>0</sub> |                |  |  |
|           |         | rp'1, XA   | 10101010                                                            | 1 1 0 1 0 P <sub>2</sub> P <sub>1</sub> P <sub>0</sub> |                |  |  |
|           |         | A, @HL     | 10101000                                                            |                                                        |                |  |  |
|           | SUBS    | XA, rpʻ    | 10101010                                                            | 1 1 1 0 1 P <sub>2</sub> P <sub>1</sub> P <sub>0</sub> |                |  |  |
|           |         | rp'l, XA   | 10101010                                                            | 1 1 1 0 0 P <sub>2</sub> P <sub>1</sub> P <sub>0</sub> |                |  |  |
| ۶         |         | A, @HL     | 10111000                                                            |                                                        |                |  |  |
| ati       | SUBC    | XA, rp'    | 10101010                                                            | $1 \ 1 \ 1 \ 1 \ 1 \ P_2 \ P_1 \ P_0$                  |                |  |  |
| Operation |         | rp'l.XA    | 10101010                                                            | $1 \ 1 \ 1 \ 1 \ 0 \ P_2 \ P_1 \ P_0$                  |                |  |  |
|           |         | A. #n4     | 100110010                                                           | $0  0  1  1  I_3  I_2  I_1  I_0$                       |                |  |  |
|           | AND     | A. @HL     | 10010000                                                            |                                                        |                |  |  |
|           |         | XA. rp'    | 10101010                                                            | $1 0 0 1 1 P_2 P_1 P_0$                                |                |  |  |
|           | <br>    | rp'1, XA   | 101010101                                                           | $1 0 0 1 0 P_2 P_1 P_0$                                |                |  |  |
|           |         | A. #n4     | 100110010                                                           | $1 0 0 I_3 I_2 I_1 I_0$                                |                |  |  |
|           | OR      | A, @HL     | 10100000                                                            |                                                        |                |  |  |
|           |         | XA, rp'    | 101010101                                                           | $0 1 0 1 P_2 P_1 P_0$                                  |                |  |  |
|           |         | rp'l.XA    | 101010101                                                           | $0 1 0 0 P_2 P_1 P_0$                                  |                |  |  |
|           |         | A, #n4     | 100110010                                                           | $1 0 1 I_3 I_2 I_1 I_0$                                |                |  |  |
|           | XOR     | A. @HL     | 10110000                                                            |                                                        |                |  |  |
|           |         | XA. rp'    | 101010101                                                           | 0 1 1 1 P <sub>2</sub> P <sub>1</sub> P <sub>0</sub>   |                |  |  |
| ~         |         | rp'l, XA   | 101010101                                                           | 0 1 1 0 P <sub>2</sub> P <sub>1</sub> P <sub>0</sub>   |                |  |  |
| re 2      | RORC    | A          | 10011000                                                            |                                                        |                |  |  |
| NOTE      | NOT     | A          | 100110010                                                           | 1011111                                                |                |  |  |

NOTE 1 : Instruction Group 2 : Accumulator operating

🖬 6427525 OO95255 967 🔲 10-20

| NOTE                       | Mnemonic | Operands       | Operation Code                                         |                                                        |                |  |  |
|----------------------------|----------|----------------|--------------------------------------------------------|--------------------------------------------------------|----------------|--|--|
| Ŋ.                         |          |                | Bı                                                     | B <sub>2</sub>                                         | B <sub>3</sub> |  |  |
| t                          |          | reg            | 1 1 0 0 0 R <sub>2</sub> R <sub>1</sub> R <sub>0</sub> |                                                        |                |  |  |
| eme                        | INCS     | rpl            | $1 0 0 0 1 P_2 P_1 0$                                  |                                                        |                |  |  |
| decı                       |          | @HL            | 10011001                                               | 0 0 0 0 0 0 1 0                                        |                |  |  |
| ent/                       |          | mem            | 10000010                                               | $D_7 D_6 D_5 D_4 D_3 D_2 D_1 D_0$                      |                |  |  |
| Increment/decrement        | DECS     | reg            | $1 1 0 0 1 R_2 R_1 R_0$                                |                                                        |                |  |  |
| Inc                        | DLCS     | rp'            | 10101010                                               | $0 1 1 0 1 P_2 P_1 P_0$                                |                |  |  |
|                            |          | reg. ‡n4       | 10011010                                               | $I_3 I_2 I_1 I_0 O R_2 R_1 R_0$                        |                |  |  |
|                            |          | @HL, #n4       | 1 0 0 1 1 0 0 1                                        | $0  1  1  0  I_3  I_2  I_1  I_0$                       |                |  |  |
| are                        | GTT      | A. @HL         | 10000000                                               |                                                        |                |  |  |
| Compare                    | SKE      | XA, @HL        | 10101010                                               | 0 0 0 1 1 0 0 1                                        |                |  |  |
|                            |          | A. reg         | 10011001                                               | $0 \ 0 \ 0 \ 0 \ 1 \ R_2 \ R_1 \ R_0$                  |                |  |  |
|                            |          | XA, rp'        | 10101010                                               | 0 1 0 0 1 P <sub>2</sub> P <sub>1</sub> P <sub>0</sub> |                |  |  |
| 5                          | SET1     | CY             | 1 1 1 0 0 1 1 1                                        |                                                        |                |  |  |
| flag<br>lati               | CLR1     | CY             | 1 1 1 0 0 1 1 0                                        |                                                        |                |  |  |
| Carry flag<br>manipulation | SKT      | CY             | 1 1 0 1 0 1 1 1                                        |                                                        |                |  |  |
| nar<br>Mar                 | NOT1     | CY             | 1 1 0 1 0 1 1 0                                        |                                                        |                |  |  |
|                            | SET1     | mem. bit       | 1 0 B <sub>1</sub> B <sub>0</sub> 0 1 0 1              | $D_7 D_6 D_5 D_4 D_3 D_2 D_1 D_0$                      |                |  |  |
|                            |          | *1             | 10011101                                               | * 2                                                    |                |  |  |
| ion                        | CLR1     | mem. bit       | 1 0 B <sub>1</sub> B <sub>0</sub> 0 1 0 0              | $D_7 D_6 D_5 D_4 D_3 D_2 D_1 D_0$                      |                |  |  |
| manipulation               | CLRI     | *1             | 10011100                                               | * 2                                                    |                |  |  |
| Ipu                        | SKT      | mem. bit       | 1 0 B <sub>1</sub> B <sub>0</sub> 0 1 1 1              | $D_7 D_6 D_5 D_4 D_3 D_2 D_1 D_0$                      |                |  |  |
| mar                        | 361      | <u>* 1</u>     | 10111111                                               | * 2                                                    |                |  |  |
| bit                        | SKF      | mem. bit       | $1 O B_1 B_0 O 1 1 O I$                                | $D_7 D_6 D_5 D_4 D_3 D_2 D_1 D_0$                      |                |  |  |
|                            |          | *1             | 10111110                                               | * 2                                                    |                |  |  |
| Метогу                     | SKTCLR   | *1             | 10011111                                               | * 2                                                    |                |  |  |
| Σ                          | AND1     | CY. * 1        | 10101100                                               | * 2                                                    |                |  |  |
|                            | OR1      | CY. <b>*</b> 1 | 10101110                                               | * 2                                                    |                |  |  |
|                            | XORI     | CY. * 1        | 10111100                                               | * 2                                                    |                |  |  |

NOTE : Instruction Group

■ 6427525 0095256 АТЭ ■ 10-21

|                  | Mnemonic | Operands                                                                                 | Operation Code                                       |                                                                                                                 |                |  |  |
|------------------|----------|------------------------------------------------------------------------------------------|------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|----------------|--|--|
|                  |          |                                                                                          | B1                                                   | B <sub>2</sub>                                                                                                  | B <sub>3</sub> |  |  |
|                  |          | ! addr                                                                                   | 101010110                                            | 0                                                                                                               | addr           |  |  |
| 4                | BR       | $ \begin{array}{c} (+16) \\ 5 \\ \text{addr} \\ (+2) \\ (-1) \\ 5 \\ (-15) \end{array} $ | $\begin{array}{cccccccccccccccccccccccccccccccccccc$ |                                                                                                                 |                |  |  |
| Branch           |          | PCDE                                                                                     | 100110010                                            | 0000100                                                                                                         |                |  |  |
|                  | 1        | PCXA                                                                                     | 100110010                                            |                                                                                                                 |                |  |  |
|                  | BRCB     | ! caddr                                                                                  |                                                      | caddr                                                                                                           |                |  |  |
| -                | CALL     | ! addr                                                                                   | 101010110                                            | 1                                                                                                               | addr           |  |  |
| control          | CALLF    | ! faddr                                                                                  | 01000-                                               | - faddr                                                                                                         |                |  |  |
| l oo             | RET      |                                                                                          | 1 1 1 0 1 1 1 0                                      |                                                                                                                 |                |  |  |
|                  | RETS     |                                                                                          | 1 1 1 0 0 0 0 0                                      |                                                                                                                 |                |  |  |
| 'sta             | RETI     |                                                                                          | 1 1 1 0 1 1 1 1                                      |                                                                                                                 |                |  |  |
| Subroutine/stack | PUSH     | rp                                                                                       | 0 1 0 0 1 P <sub>2</sub> P <sub>1</sub> 1            |                                                                                                                 |                |  |  |
| out              | rosn     | BS                                                                                       | 100110010                                            | 0000111                                                                                                         |                |  |  |
| ubr              | POP      | rp                                                                                       | 0 1 0 0 1 P <sub>2</sub> P <sub>1</sub> 0            |                                                                                                                 |                |  |  |
|                  |          | BS                                                                                       | 100110010                                            | 0000110                                                                                                         |                |  |  |
| Input/output     | IN –     | A, PORTn                                                                                 | 101000111                                            | 1 1 1 N <sub>3</sub> N <sub>2</sub> N <sub>1</sub> N <sub>0</sub>                                               |                |  |  |
| out              |          | XA. PORTn                                                                                | 101000101                                            | the second se |                |  |  |
| ut/              | OUT      | PORTn, A                                                                                 | 100100111                                            |                                                                                                                 |                |  |  |
| Inp              |          | PORTn, XA                                                                                | 100100101                                            |                                                                                                                 |                |  |  |
| 2                | EI       |                                                                                          | 100111011                                            | 0 1 1 0 0 1 0                                                                                                   |                |  |  |
|                  |          | IE×××                                                                                    | 100111011                                            | $0 N_{5} 1 1 N_{2} N_{1} N_{0}$                                                                                 |                |  |  |
| NOTE             | DI       |                                                                                          | 100111001                                            | 0110010                                                                                                         |                |  |  |
|                  |          | ΙΈ×××                                                                                    | 1001110010                                           | $0 N_5 1 1 N_2 N_1 N_0$                                                                                         |                |  |  |
| e                | HALT     |                                                                                          | 1001110110                                           | 0100011                                                                                                         | ······         |  |  |
| NOTE             | STOP     |                                                                                          | 001110110                                            | 0110011                                                                                                         |                |  |  |
| z                | NOP      |                                                                                          | 01100000                                             |                                                                                                                 |                |  |  |
| fal              | SEL      | RBn                                                                                      | 001100100                                            | $0 1 0 0 0 N_1 N_0$                                                                                             |                |  |  |
| Special          |          | MBn                                                                                      | 001100100                                            | $0 \ 0 \ 1 \ N_3 \ N_2 \ N_1 \ N_0$                                                                             |                |  |  |
| ŝ                | GETI     | taddr (                                                                                  | $0 \ 0 \ T_5 \ T_4 \ T_3 \ T_2 \ T_1 \ T_0$          |                                                                                                                 |                |  |  |

NOTE 1: Instruction Group 2: Interrupt control 3: CPU control



#### 10.4 INSTRUCTION FUNCTIONS AND USE

#### 10.4.1 TRANSFER INSTRUCTIONS

MOV A, #n4

Function:  $A \leftarrow n4$   $n4 = I_3$  to  $I_0$ : 0 to FH

Transfers the 4-bit immediate data n4 to the A register (4-bit accumulator). This instruction has a stacking effect (Group A) and if followed by a MOV A, #n4 or MOV XA, #n8 instruction, the stacked instructions following the executed instruction are processed as NOP instructions.

Examples:

(1) To set OBH in the accumulator.

MOV A, #OBH

(2) To select data for output to port 3 from 0 through2.

AO: MOV A, #0 A1: MOV A, #1 A2: MOV A, #2 OUT PORT3, A

MOV reg1, #n4

Function: regl  $\leftarrow$  n4 n4 = I<sub>3</sub> to I<sub>0</sub> 0 to FH

Transfers the 4-bit immediate data n4 to A register regl (X, H, L, D, E, B, C).

■ 6427525 0095258 676 ■ 10-23 MOV rp, #n8

Function:  $rp + n8 = I_7$  to  $I_0$ : 00H to FFH

Transfers the 8-bit immediate data n8 to register pair rp (XA, HL, DE, BC). When XA or HL is selected as the register pair this instruction has a stacking effect. Stacking effects fall into two groups, Group A (MOV A, #n4 instruction & MOV XA, #n8 configuration) and Group B (MOV HL, #n8 instruction); if instructions of the same group are located consecutively, stacked instructions following the executed instruction are processed as NOP instructions.

Example:

To set 5FH in the DE register pair

MOV DE, #5FH

MOV A, @rpa

Function: A + (rpa)
When rpa = HL+: skip if L = 0
When rpa = HL-: skip if L = FH

Transfers the contents of the data memory addressed by register pair rpa (HL, HL+, HL-, DE, DL) to the A register.

When auto-incrementing (HL+) is specified for rpa, after the data transfer the contents of the L register are automatically adjusted by +1, and if the result is 0, the next one instruction is skipped.

MOV XA, @HL

Function:  $A \neq (HL)$ ,  $X \neq (HL + 1)$ 

Transfers the contents of the data memory addressed by register pair HL to the A register, and transfers the contents of the next memory address to the X register.

If the contents of the L register are odd, the address with the LSB ignored is transferred.

Example:

To transfer the contents of addresses 3EH and 3FH to register pair XA.

MOV HL, #3EH MOV XA, @HL

MOV @HL, A

Function: (HL) + A

Transfers the contents of the A register to the data memory addressed by register pair HL.

MOV @HL, XA

Function: (HL) + A, (HL + 1) + X

Transfers the contents of the A register to the data memory addressed by register pair HL, and transfers the contents of the X register to the next memory address.

If the contents of the L register are odd, the address with the LSB ignored is specified.

■ 6427525 0095260 224 ■ 10-25

MOV A, mem

Function:  $A \leftarrow (mem)$  mem =  $D_7$  to  $D_0$ : 00H to FFH

Transfers the contents of the data memory addressed by 8bit immediate data mem to the A register.

MOV XA, mem

Function:  $A \leftarrow (mem)$ ,  $X \leftarrow (mem + 1)$ mem =  $D_7$  to  $D_0$ : 00H to FEH

Transfers the contents of the data memory addressed by 8bit immediate data mem to the A register, and the contents of the next address to the X register.

The address specified by mem must be an even address.

Example:

To transfer the data in addresses 40H and 41H to register pair XA.

MOV XA, 40H

MOV mem, A

Function: (mem) + A mem = D7 to D0: 00H to FFH

Transfers the contents of the A register to the data memory addressed by 8-bit immediate data mem.

■ 6427525 0095261 160 ■ 10-26

MOV mem, XA

Function:  $(mem) \leftarrow A$ ,  $(mem + 1) \leftarrow X$ mem = D<sub>7</sub> to D<sub>0</sub>: 00H to FEH

Transfers the contents of the A register to the data memory addressed by 8-bit immediate data mem, and transfers the contents of the X register to the next memory address.

The address specified by mem must be an even address.

MOV A, reg

```
Function: A \leftarrow reg
```

Transfers the contents of register reg (X, A, H, L, D, E, B, C) to the A register.

MOV XA, rp'

Function: XA + rp'

Transfers the contents of register pair rp' (XA, HL, DE, BC, XA', HL', DE', BC') to the register pair XA.

Example:

To transfer the data in register pair XA' to register pair XA.

MOV XA, XA'

■ 6427525 0095262 OT7 ■ 10-27

MOV reg1, A

Function: reg1 + A

Transfers the contents of the A register to register regl (X, H, L, D, E, B, C).

MOV rp'1, XA

Function: rp'1 + XA

Transfers the contents of register pair XA to register pair rp'1 (HL, DE, BC, XA', HL', DE', BC').



XCH A, @rpa

Function: A ↔ (rpa)
When rpa = HL+: skip if L = 0
When rpa = HL-: skip if L = FH

Exchanges the contents of the A register with the contents of the data memory addressed by register pair rpa (HL, HL+, HL-, DE, DL). When auto-incrementing (HL+)is specified for rpa, after the data exchange the contents of the L register are automatically adjusted by +1, and if the result is 0, the next instruction is skipped.

When auto-decrementing (HL-) is specified for rpa, after the data exchange the contents of L register are automatically adjusted by -1 and if the result is FH, the next one instruction is skipped.

Example:

To exchange the data in data memory addresses 20H to 2FH with the data in addresses 30H to 3FH.

SEL MBO MOV D, #2 MOV HL, #30H LOOP: XCH A,  $(HL; A \rightarrow (3 x))$ XCH A,  $(HL; A \rightarrow (2 x))$ XCH A,  $(HL+; A \rightarrow (3 x))$ BR LOOP

> н∎ 6427525 0095264 97Т ■ 10-29

XCH XA, @HL

Function:  $A \leftrightarrow (HL), X \leftrightarrow (HL + 1)$ 

Exchanges the contents of the A register with the contents of the data memory addressed by register pair HL, and exchanges the contents of the X register with the contents of the next memory address.

If the contents of the L register are odd, the address with the LSB ignored is specified.

XCH A, mem

Function:  $A \leftrightarrow (mem)$  mem =  $D_7$  to  $D_0$ : 00H to FEH

Exchanges the contents of the A register with the contents of the data memory addressed by 8-bit immediate data mem.

XCH XA, mem

Function:  $A \leftrightarrow (mem)$ ,  $X \leftrightarrow (mem + 1)$ mem =  $D_7$  to  $D_n$ : 00H to FEH

Exchanges the contents of the A register with the contents of the data memory addressed by 8-bit immediate data mem, and exchanges the contents of the X register with the contents of the next memory address.

The address specified by mem must be an even address.

XCH A, reg1

Function:  $A \leftrightarrow regl$ 

Exchanges the contents of the A register with the contents of register regl (X, H, L, D, E, B, C).

10-30 ■ 6427525 0095265 806 ■ XCH XA, rp'

Function: XA  $\leftrightarrow$  rp'

Exchanges the contents of register pair XA with the contents of register pair rp' (XA, HL, DE, BC, XA', HL', DE', BC').



## 10.4.2 TABLE REFERENCING INSTRUCTIONS

MOVT XA, @PCDE

Function:  $XA + ROM (PC_{13} to PC_8 + DE)$ 

Transfers to the A register the low-order 4 bits of the table data in the program memory addressed when the low-order 8 bits (PC, to PC<sub>0</sub>) of the program counter (PC) are replaced with the contents of register pair DE, and transfers the high-order 4 bits of this table data to the X register.

The table address is determined by the contents of the program counter (PC) when this instruction is executed.

The necessary data must previously have been programmed in the table area by an assembler pseudo-instruction (DB instruction).

The program counter is not affected by the execution of this instruction.

This instruction is effective for successive table data references.

Example:



Note:

The MOVT XA, @PCDE instruction normally references table data in the page in which that instruction is located, but if the instruction is in address xxFFH, the table data in the next page, to that page, is referenced.



If, for example, the MOVT XA, @PCDE instruction is in location "a" in the above figure, the table data in page 3, not page 2, specified by the contents of register pair DE is transferred to register pair XA.

Example:

To transfer the 16-byte data in program memory addresses xxFOH through xxFFH to data memory addresses 30H through 4FH.

SUB : SEL MB0 ; HL - 30H MOV HL, #30H ; DE + FOH MOV DE, #OFOH ; XA + Table data MOVT XA, @PCDE LOOP: **@HL**, XA ; (HL) + XAMOV ; HL + HL + 2INCS HL INCS HL ; E + E + 1INCS Е BR LOOP RET ORG **xxFOH** xxH, xxH, ....; Table data DB 🖬 6427525 0095268 515 🎟 10-33

#### MOVT XA, @PCXA

Function:  $XA + ROM (PC_{13} \text{ to } PC_8 + XA)$ 

Transfers to the A register the low-order 4 bits of the table data in the program memory addressed when the low-order 8 bits (PC  $_7$  to PC $_0$ ) of the program counter (PC) are replaced with the contents of register pair XA, and transfers the high-order 4 bits of this table data to the X register.

The table address is determined by the contents of the program counter (PC) when this instruction is executed.

The necessary data must previously have been programmed in the table area by an assembler pseudo-instruction (DB instruction).

The program counter is not affected by the execution of this instruction.

Note:

As with the MOVT XA, @PCDE instruction, if this instruction is located in address xxFFH the table data in the page is transferred.

## ■ 6427525 0095269 451 ■ 10-34

10.4.3 BIT TRANSFER INSTRUCTIONS

MOV1 CY, fmem.bit

MOV1 CY, pmem.@L

MOV1 CY, @H + mem.bit

Function: CY + (bit specified by operand)

Transfers the contents of the data memory bit specified by bit manipulation addressing (fmem.bit, pmem.@L, @H + mem.bit) to the carry flag (CY).

MOV1 fmem.bit, CY

MOV1 pmem.@L, CY

MOV1 @H + mem.bit, CY

Function: (Bit specified by operand) + CY

Transfers the contents of the carry flag (CY) to the data memory bit specified by bit manipulation addressing (fmem.bit, pmem.@L, @H + mem.bit).

Example:

To output the flag at bit 3 of data memory address 3FH to bit 2 of port 3.

FLAG EQU 3FH. 3
SEL MBO
MOV H, #FLAG SHR6; H + High-order 4 bits of FLAG
MOV1 CY, @H + FLAG; CY + FLAG
MOV1 PORT3. 2, CY ; P32 + CY

■ 6427525 0095270 173 ■ 10-35

# 10.4.4 OPERATION INSTRUCTIONS

ADDS A, #n4

```
Function: A + A + n4; Skip if carry.
n4 = I_3 to I_0: 0 to FH
```

Performs binary addition of the 4-bit immediate data n4 to the contents of the A register, and skips the next instruction if a carry is generated as a result of the addition. The carry flag is not affected.

Combining the ADDC A, @HL instruction and the SUBC A, @HL instruction gives a radix adjustment instruction (see 10.1 "Special Instructions").

ADDS XA, #n8

Function:  $XA \leftarrow XA + n8$ ; Skip if carry.  $n8 = I_7$  to  $I_0$ : 00H to FFH

Performs binary addition of the 8-bit immediate data n8 to the contents of register pair XA, and skips the next instruction if a carry is generated as a result of the addition. The carry flag is not affected.

ADDS A, @HL

Function: A + A + (HL); Skip if carry.

Performs binary addition of the contents of the data memory addressed by register pair HL to the contents of the A register, and skips the next instruction if a carry is generated as a result of the addition. The carry flag is not affected.

## ■ 6427525 0095271 ООТ ■ 10-36

ADDS XA, rp'

Function: XA + XA + rp': Skip if carry.

Performs binary addition of the contents of register pair rp' (XA, HL, DE, BC, XA', HL', DE', BC') to the contents of register pair XA, and skips the next instruction if a carry is generated as a result of the addition. The carry flag is not affected.

ADDS rp'1, XA

Function: rp' + rp'1 + XA; Skip if carry.

Performs binary addition of the contents of register pair XA to the contents of register pair rp'1 (HL, DE, BC, XA', HL', DE', BC'), and skips the next instruction if a carry is generated as a result of the addition. The carry flag is not affected.

Example:

To left-shift a register pair.

MOV XA, rp'1 ADDS rp'1, XA NOP

ADDC A, @HL

Function: A, CY + A + (HL) + CY

Performs binary addition including the carry flag of the contents of the data memory addressed by register pair HL to the contents of the A register. If a carry is generated as a result of the addition the carry flag is set, and if no carry is generated the carry flag is reset.

If an ADDS A, #n4 instruction is placed after this instruction, if a carry is generated in this instruction the ADDS A, #n4 instruction is skipped. If no carry is generated the ADDS A, #n4 instruction is executed, and a function is produced whereby skipping of the ADDS A, #n4 instruction is disabled. Therefore, the combination of these instructions can be used as a radix adjustment instruction (see 10.1.4 "Radix Adjustment Instructions").

ADDC XA, rp'

Function: XA,  $CY \leftarrow XA + rp' + CY$ 

Performs binary addition including the carry flag of the contents of register pair rp' (XA, HL, DE, BC, XA', HL', DE', BC') to the contents of register pair XA. If a carry is generated as a result of the addition the carry flag is set, and if no carry is generated the carry flag is reset.

> 6427525 0095273 982 MM 10-38

ADDC rp'1, XA

Function: rp'1, CY + rp'1 + XA + CY

Performs binary addition including the carry flag of the contents of register pair XA to the contents of register pair rp'1 (HL, DE, BC, XA', HL', DE', BC'). If a carry is generated as a result of the addition the carry flag is set, and if no carry is generated the carry flag is reset.

SUBS A, @HL

Function: A + A - (HL); Skip if borrow

Subtracts the contents of the data memory addressed by register pair HL from the contents of the A register, and places the result in the A register. If a borrow is generated as a result of the subtraction, the next instruction is skipped.

The carry flag is not affected.

■ 6427525 0095274 819 ■ 10-39

SUBS XA, rp'

Function: XA + XA - rp'; Skip if borrow

Subtracts the contents of register pair rp' (XA, HL, DE, BC, XA', HL', DE', BC') from the contents of register pair XA, and places the result in register pair XA. If a borrow is generated as a result of the subtraction, the next instruction is skipped.

The carry flag is not affected.

Example:

To compare the relative size of data memory and register pair contents.

```
MOV XA, mem
SUBS XA, rp'
; (mem) ≥ rp'
; (mem) < rp'
```

SUBS rp'1, XA

Function: rp'1 + rp'1 - XA; Skip if borrow

Subtracts the contents of register pair XA from the contents of register pair rp'1 (HL, DE, BC, XA', HL', DE', BC'), and places the result in the specified register pair rp'1. If a borrow is generated as a result of the subtraction, the next instruction is skipped.

The carry flag is not affected.



SUBC A, @HL

## Function: A, CY + A - (HL) - CY

Performs subtraction including the carry flag of the contents of the data memory addressed by register pair HL from the contents of the A register, and places the result in the A register. If a borrow is generated as a result of the subtraction the carry flag is set, and if no borrow is generated the carry flag is reset.

If an ADDS A, #n4 instruction is placed after this instruction, if no borrow is generated in this instruction the ADDS A, #n4 instruction is skipped. If a borrow is generated the ADDS A, #n4 instruction is executed, and a function is produced whereby skipping of the ADDS A, #n4 instruction is disabled. Therefore, the combination of these instructions can be used as a radix adjustment instruction (see 10.1.4 "Radix Adjustment Instructions").

SUBC XA, rp'

Function: XA, CY + XA - rp' - CY

Performs subtraction including the carry flag of the contents of register pair rp' (XA, HL, DE, BC, XA', HL', DE', BC') from the contents of register pair XA, and places the result in register pair XA. If a borrow is generated as a result of the subtraction the carry flag is set, and if no borrow is generated the carry flag is reset.

■ 6427525 0095276 691 ■ 10-41 SUBC rp'1, XA

Function: rp'1, CY + rp'1 - XA - CY

Performs subtraction including the carry flag of the contents of register pair XA from the contents of register pair rp'1 (HL, DE, BC, XA', HL', DE', BC') and places the result in register pair rp'1. If a borrow is generated as a result of the subtraction the carry flag is set, and if no borrow is generated the carry flag is reset.

AND A, #n4

Function:  $A \leftarrow A \land n4$   $n4 = I_3$  to  $I_0$ : 0 to FH

Obtains the logical product of the contents of the A register and the 4-bit immediate data n4, and places the result in the A register.

Example:

To zeroize the high-order 2 bits of the accumulator.

AND A, #0011B

AND A, @HL

Function:  $A \leftarrow A \land (HL)$ 

Obtains the logical product of the contents of the A register and the contents of the data memory addressed by register pair HL, and places the result in the A register.

■ 6427525 0095277 528 ■ 10-42

AND XA, rp'

Function:  $XA + XA \wedge rp'$ 

Obtains the logical product of the contents of register pair XA and the contents of register pair rp' (XA, HL, DE, BC, XA', HL', DE', BC'), and places the result in register pair XA.

AND rp'1, XA

Function:  $rp'1 + rp'1 \wedge XA$ 

Obtains the logical product of the contents of register pair rp'l (HL, DE, BC, XA', HL', DE', BC') and the contents of register pair XA, and places the result in the specified register pair.

OR A, #n4

Function:  $A \leftarrow A \lor n4$   $n4 = I_3$  to  $I_0$ : 0 to FH

Obtains the logical sum of the contents of the A register and the 4-bit immediate data n4, and places the result in the A register.

Example:

To set the low-order 3 bits of the accumulator to 1.

OR A, #0111B

## 6427525 0095278 464 MM 10-43

OR A, @HL

Function:  $A \leftarrow A \lor (HL)$ 

Obtains the logical sum of the contents of the A register and the contents of the data memory addressed by register pair HL, and places the result in the A register.

OR XA, rp'

Function: XA + XA V rp'

Obtains the logical sum of the contents of register pair XA and the contents of register pair rp' (XA, HL, DE, BC, XA', HL', DE', BC'), and places the result in register pair XA.

OR rp'1, XA

Function: rp'1 + rp'1 V XA

Obtains the logical sum of the contents of register pair rp'l (HL, DE, BC, XA', HL', DE', BC') and the contents of register pair XA, and places the result in register pair rp'l.

## ■ 6427525 0095279 3T0 **■** 10-44

XOR A, #n4

Function: A + A + n4  $n4 = I_3$  to  $I_0$ : 0 to FH

Obtains the exclusive logical sum of the contents of the A register and the 4-bit immediate data n4, and places the result in the A register.

Example:

To invert the high-order 4 bits of the accumulator.

XOR A, #1000B

XOR A, @HL

Function:  $A \leftarrow A \forall (HL)$ 

Obtains the exclusive logical sum of the contents of the A register and the contents of the data memory addressed by register pair HL, and places the result in the A register.

XOR XA, rp'

Function: XA + XA + rp'

Obtains the exclusive logical sum of the contents of register pair XA and the contents of register pair rp' (XA, HL, DE, BC, XA', HL', DE', BC'), and places the result in register pair XA.

> ■ 6427525 0095280 012 ■ 10-45

Function: rp'1 + rp'1 + XA

Obtains the exclusive logical sum of the contents of register pair rp'1 (HL, DE, BC, XA', HL', DE', BC') and the contents of register pair XA, and places the result in register pair rp'1.

10.4.5 ACCUMULATOR MANIPULATING INSTRUCTIONS

RORC A

Function:  $CY \leftarrow A_0$ ,  $A_{n-1} \leftarrow A_n$ ,  $A_3 \leftarrow CY$  (n = 1 to 3)

Performs bit-wise right rotation including the carry flag of the contents of the A register (4-bit accumulator).



NOT A

Function:  $A + \overline{A}$ 

Obtains the one's complement (inverts each bit) of the A register (4-bit accumulator).

■ 6427525 0095281 T59 ■ 10-46

#### 10.4.6 INCREMENT/DECREMENT INSTRUCTIONS

#### INCS reg

Function: reg + reg + 1; Skip if reg = 0

Increments the contents of register reg (X, A, H, L, D, E, B, C). If reg = 0 as a result of the increment, the next instruction is skipped.

INCS rpl

Function: rpl + rpl + 1; Skip if rpl = 00H

Increments the contents of the register pair rpl (HL, DE, BC). If rpl = 00H as a result of the increment, the next instruction is skipped.

INCS @HL

Function:  $(HL) \leftarrow (HL) + 1$ ; Skip if (HL) = 0

Increments the contents of the data memory addressed by register pair HL. If the contents of that data memory are 0 as a result of the increment, the next instruction is skipped.

INCS mem

Function:  $(mem) \neq (mem) + 1$ ; Skip if (mem) = 0, mem = D<sub>7</sub> to D<sub>0</sub>: 00H to FFH

Increments the contents of the data memory addressed by the 8-bit immediate data mem. If the contents of that data memory are 0 as a result of the increment, the next instruction is skipped.

> ■ 6427525 0095282 995 ■ 10-47

#### DECS reg

Function: reg + reg - 1; Skip if reg = FH

Decrements the contents of register reg (X, A, H, L, D, E, B, C). If reg = FH as a result of the decrement, the next instruction is skipped.

DECS rp'

Function: rp' + rp' - 1; Skip if rp' = FFH

Decrements the contents of register pair rp' (XA, HL, DE, BC, XA', HL', DE', BC'). If rp' = FFH as a result of the decrement, the next instruction is skipped.



10.4.7 COMPARE INSTRUCTIONS

SKE reg, #n4

Function: Skip if reg = n4  $n4 = I_3$  to  $I_0$ : 0 to FH

Skips the next instruction if the contents of register reg (X, A, H, L, D, E, B, C) and the 4-bit immediate data n4 are equal.

SKE @HL, #n4

Function: Skip if (HL) = n4  $n4 = I_3$  to  $I_0$ : 0 to FH

Skips the next instruction if the contents of the data memory addressed by register pair HL and the 4-bit immediate data n4 are equal.

SKE A, @HL

Function: Skip if A = (HL)

Skips the next instruction if the contents of the A register and the contents of the data memory addressed by register pair HL are equal.

SKE XA, @HL

Function: Skip if A = (HL) and X = (HL + 1)

Skips the next instruction if the contents of the A register and the contents of the data memory addressed by register pair HL are equal, and the contents of the X register and the contents of the next data memory address are equal.

If the contents of the L register are odd, the address with the LSB ignored is specified.

10-49 • 6427525 0095284 768

#### SKE A, reg

Function: Skip if A = reg

Skips the next instruction if the contents of the A register and the contents of register reg (X, A, H, L, D, E, B, C) are equal.

SKE XA, rp'

Function: Skip if XA = rp'

Skips the next instruction if the contents of register pair XA and the contents of the register pair rp' (XA, HL, DE, BC, XA', HL', DE', BC') are equal.

## ■ 6427525 0095285 6T4 ■ 10-50

10.4.8 CARRY FLAG MANIPULATING INSTRUCTIONS

SET1 CY

Function: CY + 1

Sets the carry flag.

CLR1 CY

Function:  $CY \neq 0$ 

Clears the carry flag.

SKT CY

Function: Skip if CY = 1

Skips the next instruction if the carry flag is 1.

NOT1 CY

Function:  $CY \leftarrow \overline{CY}$ 

Complements the carry flag. The flag is changed from 0 to 1, or from 1 to 0.

## ■ 6427525 0095286 530 ■ 10-51

```
SET1 mem.bit
```

Function:  $(\text{mem.bit}) \leftarrow 1$  mem =  $D_7$  to  $D_0$ : 00H to FFH, bit =  $B_1$  and  $B_0$ : 0 to 3

Sets the bit specified by the 2-bit immediate data "bit" of the address indicated by the 8-bit immediate data mem.

SET1 fmem.bit

SET1 pmem.@L

SET1 @H + mem.bit

Function: (Bit specified by operand) + 1

Sets the data memory bit specified by bit manipulation addressing (fmem.bit, pmem.@L, @H + mem.bit).

CLR1 mem.bit

```
Function: (\text{mem.bit}) \neq 0 mem = D_7 to D_0: 00H to FFH,
bit = B_1 and B_0: 0 to 3
```

Clears the bit specified by the 2-bit immediate data "bit" of the address indicated by the 8-bit immediate data mem.

## ■ 6427525 0095287 477 ■ 10-52

CLR1 fmem.bit

CLR1 pmem.@L

CLR1 @H + mem.bit

Function: (Bit specified by operand) + 0

Clears the data memory bit specified by bit manipulation addressing (fmem.bit, pmem.@L, @H + mem.bit).

SKT mem.bit

```
Function: Skip if (mem.bit) = 1

mem = D_7 to D_0: 00H to FFH,

bit = B_1 and B_0: 0 to 3
```

Skips the next instruction if the bit specified by the 2bit immediate data "bit" of the address indicated by the 8-bit immediate data mem is 1.

SKT fmem.bit

SKT pmem.@L

SKT @H + mem.bit

Function: Skip if (bit specified by operand) = 1

Skips the next instruction if the data memory bit specified by bit manipulation addressing (fmem.bit, pmem.@L, @H + mem.bit) is 1.

10-53 Б427525 0095288 ЭОЗ 🎟 SKF mem.bit

Function: Skip if (mem.bit) = 0 mem =  $D_7$  to  $D_0$  : 00H to FFH, bit =  $B_1$  and  $B_0$ : 0 to 3

Skips the next instruction if the bit specified by the 2bit immediate data "bit" of the address indicated by the 8-bit immediate data mem is 0.

SKF fmem.bit

SKF pmem.@L

SKF @H + mem.bit

Function: Skip if (bit specified by operand) = 0

Skips the next instruction if the data memory bit specified by bit manipulation addressing (fmem.bit, pmem.@L, @H + mem.bit) is 0.

SKTCLR fmem.bit

SKTCLR pmem.@L

SKTCLR @H + mem.bit

Function: Skip if (bit specified by operand) = 1 then clear

Skips the next instruction if the data memory bit specified by bit manipulation addressing (fmem.bit, pmem.@L, @H + mem.bit) is 1, then clears that bit to "0".

> ■ 6427525 0095289 24T ■ 10-54

AND1 CY, fmem.bit

AND1 CY, pmem.@L

AND1 CY, @H + mem.bit

Function: CY + CY  $\Lambda$  (bit specified by operand)

Obtains the logical product of the contents of the carry flag and the contents of the data memory specified by bit manipulation addressing(fmem.bit, pmem.@L, @H + mem.bit), and places the result in the carry flag.

OR1 CY, fmem.bit

OR1 CY, pmem.@L

OR1 CY, @H + mem.bit

Function: CY + CY V (bit specified by operand)

Obtains the logical sum of the contents of the carry flag and the contents of the data memory bit specified by bit manipulation addressing (fmem.bit, pmem.@L, @H + mem.bit), and places the result in the carry flag.

XOR1 CY, fmem.bit

XOR1 CY, pmem.@L

XOR1 CY, @H + mem.bit

Function: CY + CY ¥ (bit specified by operand)

Obtains the exclusive logical sum of the contents of the carry flag and the contents of the data memory bit specified by bit manipulation addressing (fmem.bit, pmem.@L, @H + mem.bit), and places the result in the carry flag.

■ 6427525 0095290 T61 ■ 10-55

BR addr

Function:  $PC_{13}$  to  $PC_0 \neq addr$ addr = 0000H to 3F7FH

Branches to the address specified by immediate data addr.

This instruction is an assembler pseudo-instruction, and during assembly is automatically replaced by the assembler with the most suitable of the following instructions: BR !addr, BRCB !caddr, or BR Saddr.

BR !addr

Function:  $PC_{13}$  to  $PC_{0}$  + addr addr = 0000H to 3F7FH

Transfers immediate data addr to the program counter (PC), and branches to the address specified by the PC.

BR \$addr

Function:  $PC_{13}$  to  $PC_{0} \neq addr$ 

Relative branch instruction with a branching range of (-15 to -1) and (+2 to +16) from the current address. It is not affected by page boundaries or block boundaries.



BRCB !caddr

Function:  $PC_{13}$  to  $PC_{0} \neq PC_{13}$ ,  $PC_{12} + caddr_{11}$ to caddr<sub>0</sub> caddr = n000H to nFFFH n =  $PC_{13}$ ,  $PC_{12}$  = 0 to 3

Branches to the address indicated by replacing the loworder bits of the program counter (PC  $_{11}$  to PC  $_0$ ) with the 12-bit immediate data caddr.

Note:

The BRCB !caddr instruction usually branches within the block in which the instruction is located, but if the 1st byte is in address OFFEH or address OFFFH, it branches not to block 0 but to block 1.



If the BRCB !caddr instruction is located at "a" or "b" in the above diagram, the branch is performed to block 1, not to block 0.



Function:  $PC_7$  to  $PC_4 + D$ ,  $PC_3$  to  $PC_0 + E$ 

Branches to the address indicated by replacing the loworder 8 bits (PC  $_7$  to PC $_0$ ) of the program counter with the contents of register pair DE. The high-order bits of the program counter are not affected.

Note:

The BR PCDE instruction usually branches within the page in which the instruction is located, but if the 1st byte of the operation code is in address xxFEH or address xxFFH, it branches not to that page but to the next page.



If, for example, the BR PCDE instruction is located at "a" or "b" in the above diagram, the branch is performed to the low-order 8-bit address specified by the contents of register pair DE not in page 2 but in page 3.



BR PCXA

Function: PC7 to PC4 + X, PC3 to PC0 + A

Branches to the address indicated by replacing the loworder 8 bits (PC  $_7$  to PC  $_0$ ) of the program counter with the contents of register pair XA. The high-order bits of the program counter are not affected.

#### Note:

As with the BR PCDE instruction, if the 1st byte is in address xxFEH or address xxFFH, a branch is made not within the same page but to the next page.

TBR addr

Function:

An assembler pseudo-instruction or GETI instruction table definition. Used when replacing a 3-byte BR !addr instruction with a 1-byte GETI instruction. 12-bit address data is specified for addr. For details, see the "RA75X Assembler Package User's Manual, Language Volume".

aadr = 0000H to 3F7FH

10-59 🖬 6427525 0095294 607 페

10.4.11 SUBROUTINE/STACK CONTROL INSTRUCTIONS

CALL !addr

Function:

 $(SP - 1) + PC_7$  to  $PC_4$ ,  $(SP - 2) + PC_3$  to  $PC_0$ (SP - 3) + MBE, RBE,  $PC_{13}$ ,  $PC_{12}$  $(SP - 4) + PC_{11}$  to  $PC_8$ ,  $PC_{13}$  to  $PC_0 + addr$ , SP + SP - 4

addr = 0000H to 3F7FH

Saves the contents of the program counter (return address) and MBE & RBE to the data memory (stack) addressed by the stack pointer (SP), decrements the SP, and then branches to the address specified by the 14-bit immediate data addr.

CALLF !faddr

Function:

 $(SP - 1) \neq PC_7$  to  $PC_4$ ,  $(SP - 2) \neq PC_3$  to  $PC_0$  $(SP - 3) \neq MBE$ , RBE,  $PC_{13}$ ,  $PC_{12}$  $(SP - 4) \neq PC_{11}$  to  $PC_8$ ,  $SP \neq SP - 4$  $PC_{13}$  to  $PC_0 \neq 000 + faddr$ 

faddr = 0000H to 07FFH

Saves the contents of the program counter (PC; return address) and MBE & RBE to the data memory (stack) addressed by the stack pointer (SP), decrements the SP, and then branches to the address specified by the 11-bit immediate data faddr. Only addresses in the range 0000H to 07FFH (0 to 2047) can be called.

> 10-60 🖿 6427525 0095295 543 🎟

TCALL !addr

Function:

An assembler pseudo-instruction for GETI instruction table definition. Used when replacing a 3-byte CALL !addr instruction with a 1-byte GETI instruction. 12-bit address data is specified for addr. For details, see the "RA75X Assembler Package User's Manual, Language Volume".

addr = 0000H to 3F7FH

#### RET

Function:  $PC_{11}$  to  $PC_{8} \leftarrow (SP)$ , MBE, RBE,  $PC_{13}$ ,  $PC_{12} \leftarrow (SP + 1)$ ,  $PC_{3}$  to  $PC_{0} \leftarrow (SP + 2)$ ,  $PC_{7}$  to  $PC_{4} \leftarrow (SP + 3)$ ,  $SP \leftarrow SP + 4$ 

Restores the contents of the data memory (stack) addressed by the stack pointer (SP) to the program counter (PC), memory bank enable flag (MBE) and register bank enable flag (RBE), and then increments the contents of the SP.

Note:

Program status word (PSW) bits other than the MBE and RBE flags are not restored.

Function:  $PC_{11}$  to  $PC_8 + (SP)$ , MBE, RBE,  $PC_{13}$ ,  $PC_{12} + (SP + 1)$ ,  $PC_3$  to  $PC_0 + (SP + 2)$ ,  $PC_7$  to  $PC_4 + (SP + 3)$ , SP + SP + 4Then skip unconditionally

Restores the contents of the data memory (stack) addressed by the stack pointer (SP) to the program counter (PC), memory bank enable flag (MBE) and register bank enable flag (RBE), increments the contents of the SP, and then skips unconditionally.

Note:

Program status word (PSW) bits other than the MBE and RBE flags are not restored.

RETI

Function:  $PC_{11}$  to  $PC_8 + (SP)$ , MBE, RBE,  $PC_{13}$ ,  $PC_{12} + (SP + 1)$ ,  $PC_3$  to  $PC_0 + (SP + 2)$ ,  $PC_7$  to  $PC_4 + (SP + 3)$   $PSW_L + (SP + 4)$ ,  $PSW_H + (SP + 5)$ SP + SP + 6

Restores the contents of the data memory (stack) addressed by the stack pointer (SP) to the program counter (PC) and the program status word, and then increments the contents of the SP.

This instruction is used to return from an interrupt service routine.

■ 6427525 0095297 316 ■ 10-62

RETS

#### PUSH rp

Function:  $(SP - 1) + rp_H$ ,  $(SP - 2) + rp_L$ , SP + SP - 2

Saves the contents of register pair rp (XA, HL, DE, BC) to the data memory (stack) addressed by the stack pointer (SP), and then decrements the SP.

The higher register of the register pair  $(rp_H: X, H, D, B)$  is saved to the stack memory addressed by (SP - 1), and the lower register  $(rp_L: A, L, E, C)$  is saved to the stack memory addressed by (SP - 2).

#### PUSH BS

Function: (SP - 1) + MBS, (SP - 2) + RBS, SP + SP - 2

Saves the contents of the memory bank selection register (MBS) and the register bank selection register (RBS) to the data memory (stack) addressed by the stack pointer (SP), and then decrements the SP.

#### POP rp

Function:  $rp_{L} + (SP)$ ,  $rp_{H} + (SP + 1)$ , SP + SP + 2

Restores the contents of the data memory (stack) addressed by the stack pointer (SP) to register pair rp (XA, HL, DE, BC), and then increments the SP.

The contents of (SP) are restored to the lower register of the register pair ( $rp_H$ : A, L, E, C), and the contents of (SP + 1) are restored to the higher register ( $rp_H$ : X, H, D, B).

> ■ 6427525 0095298 252 ■ 10-63

#### POP BS

# Function: RBS + (SP), MBS + (SP + 1), SP + SP + 2

Restores the contents of the data memory (stack) addressed by the stack pointer (SP) to the register bank selection register (RBS) and the memory bank selection register (MBS), and then increments the SP.



EI

Function: IME (IPS. 3) + 1

Sets the interrupt master enable flag (bit 3 of the interrupt priority selection register) to "1" and enables interrupts. Whether or not interrupt acknowledgment is possible is controlled by the individual interrupt enable flags.

EI IExxx

Function: IExxx + 1 xxx =  $N_5$ ,  $N_2$  to  $N_0$ 

Sets an interrupt enable flag (IExxx) to "1", enabling interrupt acknowledgment. (xxx = BT, CSI, TO, T1, W, O, 1, 2, 4)

#### DI

Function: IME (IPS. 3)  $\neq 0$ 

Resets the interrupt master enable flag (bit 3 of the interrupt priority selection register) to "0", disabling all interrupts irrespective of the contents of the individual interrupt enable flags.

DI IExxx

Function: IExxx  $\leftarrow 0$  xxx = N<sub>5</sub>, N<sub>2</sub> to N<sub>0</sub>

Resets an interrupt enable flag (IExxx) to "0", disabling interrupt acknowledgment. (xxx = BT, CSI, TO, T1, W, 0, 1, 2, 4)

■ 6427525 0095300 730 ■ 10-65 IN A, PORTn

Function:  $A \leftarrow PORTn$   $n = N_3$  to  $N_0$ : 0 to 8

Transfers the contents of the port specified by PORTn (n = 0 to 8) to the A register.

Note:

When this instruction is executed, it is necessary for MBE = 0 or (MBE = 1, MBS = 15) to be set. A value between 0 and 8 can be specified for n.

Output latch data (output mode) or pin data (input mode) is fetched according to the input/output mode specification.

IN XA, PORTn

Function:  $A \neq PORTn$ ,  $X \neq PORTn + 1$   $n = N_3$  to  $N_0$ : 4, 6

Transfers the contents of the port specified by PORTn (n = 4 or 6) to the A register, and transfers the contents of the next port to the X register.

Note:

Only 4 or 6 can be specified for n. When this instruction is executed, it is necessary for MBE = 0 or (MBE = 1, MBS = 15) to be set.

Output latch data (output mode) or pin data (input mode) is fetched according to the input/output mode specification.

■ 6427525 0095301 677 ■ 10-66

#### OUT PORTn, A

Function: PORTn + A  $n = N_3$  to  $N_0$ : 2 to 8

Transfers the contents of the A register to the output latch of the port specified by PORTn (n = 2 to 8) to the A register.

Note:

When this instruction is executed, it is necessary for MBE = 0 or (MBE = 1, MBS = 15) to be set. A value between 2 and 8 can be specified for n.

OUT PORTn, XA

Function: PORTn + A, PORTn + 1 + X n = N<sub>3</sub> to N<sub>0</sub>: 4, 6

Transfers the contents of the A register to the output latch of the port specified by PORTn (n = 4 or 6) to the A register, and transfers the contents of the X register to the output latch of the next port.

Note:

When this instruction is executed, it is necessary for MBE = 0 or (MBE = 1, MBS = 15) to be set.

Only 4 or 6 can be specified for n.



10.4.14 CPU CONTROL INSTRUCTIONS

### HALT

Function: PCC.  $2 \neq 1$ 

The instruction which sets the HALT mode (sets bit 2 of the processor clock control register).

Note:

The instruction following the HALT instruction must be an NOP instruction.

#### STOP

Function: PCC.  $3 \neq 1$ 

The instruction which sets the STOP mode (sets bit 3 of the processor clock control register).

Note:

The instruction following the STOP instruction must be an NOP instruction.

NOP

Function:

Expends one machine cycle without performing any operation.

10-68 ■ 6427525 0095303 44T ■

#### **10.4.15 SPECIAL INSTRUCTIONS**

SEL RBn

Function: RBS + n  $n = N_1$  and  $N_0$ : 0 to 3

Places the 2-bit immediate data n in the register bank selection register (RBS).

SEL MBn

```
Function: MBS \leftarrow n
n = N<sub>3</sub> to N<sub>0</sub>: 0, 1, 2, 15
```

Transfers the 4-bit immediate data n to the memory bank selection register (MBS).

GETI taddr

Function: taddr =  $T_5$  to  $T_0$ , 0: 20 H to 7FH . When a table defined by the TBR instruction referenced  $PC_{13}$  to  $PC_0 +$  $(taddr)_{5}$  to  $(taddr)_{0}$  + (taddr + 1). When a table defined by the TCALL instruction is referenced  $(SP - 1) + PC_7$  to PC<sub>4</sub>,  $(SP - 2) + PC_3$  to PC<sub>0</sub> (SP - 3) + MBE, RBE, PC<sub>13</sub>, PC<sub>12</sub>  $(SP - 4) + PC_{11}$  to  $PC_8$ PC, to PC,+  $(taddr)_{s}$  to  $(taddr)_{o}$  + (taddr + 1)SP + SP - 4. When a table defined by other than the TBR or TCALL instruction is referenced Execute the instruction that has (taddr) (taddr + 1) as the operation code. 10-69

💻 6427525 0095304 386 🎞

This instruction references the 2-byte data in the program memory addresses specified by (taddr) and (taddr + 1), and executes that data as an instruction.

The reference table area is 0020H to 007FH, and data is written in this area in advance. When writing the data, in the case of a 1-byte or 2-byte instruction the mnemonic is written as it is. In the case of a 3-byte call instruction or a 3-byte branch instruction, it is written by means of an assembler pseudo-instruction (TCALL, TBR).

Only an even address can be specified for taddr.

Note:

Two-byte instructions which can be placed in the reference table are restricted to 2-machine-cycle instructions (with the exception of the BRCB and CALLF instructions). When two 1-byte instructions are placed in the table, only the combinations shown below are permitted.

## ■ 6427525 0095305 212 ■ 10-70

| 1st Byte Instruction                   | 2nd Byte Instruction                              |
|----------------------------------------|---------------------------------------------------|
| MOV A, @HL<br>MOV @HL, A<br>XCH A, @HL | (INCS L<br>DECS L<br>(INCS H<br>DECS H<br>INCS HL |
| MOV A, @DE<br>XCH A, @DE               | (INCS E<br>DECS E<br>(INCS D<br>DECS D<br>INCS DE |
| MOV A, @DL<br>XCH A, @DL               | (INCS L<br>DECS L<br>(INCS D<br>DECS D            |

As the PC is not incremented during execution of a GETI instruction, after execution of the referenced instruction processing continues from the address following the GETI instruction.

If the instruction before the GETI instruction has a skip function, the GETI instruction is skipped in the same way as any other 1-byte instruction. Also, if the instruction referenced by the GETI instruction has a skip function, the instruction after the GETI instruction is skipped.

When an instruction with a stacking effect is referenced by the GETI instruction, it is executed as follows:

. If the instruction before the GETI instruction is also a stacking-effect instruction of the same group, when the GETI instruction is executed the stacking effect disappears and the referenced instruction is not skipped.

> 10-71 Б427525 0095306 159 🎟

. If the instruction after the GETI instruction is also a stacking-effect instruction of the same group, the stacking effect produced by the referenced instruction is valid and the next instruction is skipped.

#### Example:

To replace the following with GETI instructions:

MOV HL, #00H) MOV XA, #FFH CALL SUB1 BR SUB2 ORG 20H HLOO : MOV HL, #00H XAFF : MOV XA, #FFH CSUB1: TCALL SUB1 BSUB2: TBR SUB2 : : : GETI HLOO; MOV HL, #OOH : : : GETI BSUB2; BR SUB2 : : : GETI CSUB1; CALL SUB1 : : : GETI XAFF ; MOV XA, #FFH

> 10-72 ■ 6427525 0095307 095 ■

# APPENDIX A. FUNCTIONAL COMPARISON OF uPD75336, uPD75P336 AND uPD75328

## A.1 FUNCTIONAL DIFFERENCES

| Product Name                |                      | uPD75336                                                                                                                              | uPD75P336                                              | uPD75328                                                                                                                                                                             |
|-----------------------------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CPU core                    |                      | 75X-High End                                                                                                                          |                                                        | 75X-Standard                                                                                                                                                                         |
| ROM (bytes)                 |                      | 16256                                                                                                                                 |                                                        | 8064                                                                                                                                                                                 |
| RAM (x 4 bits)              |                      | 768                                                                                                                                   |                                                        | 512                                                                                                                                                                                  |
| General<br>registers        |                      | 4 bits x 8 x 4 banks                                                                                                                  |                                                        | 4 bits x 8<br>x 1 bank                                                                                                                                                               |
| Instruc-<br>tion<br>cycle   | Main system<br>clock | 0.95 us, 1.91 us,<br>(at 4.19 MHz oper                                                                                                | 0.95 us, 1.91 us<br>15.3 us (at 4.19<br>MHz operation) |                                                                                                                                                                                      |
|                             | Subsystem<br>clock   | 122 us                                                                                                                                | ration)                                                |                                                                                                                                                                                      |
| A/D converter               |                      | . 8-ch x 8-bit resolution<br>(successive approximation type)<br>. Low-voltage operation<br>capability: V <sub>DD</sub> = 2.7 to 6.0 V |                                                        | <ul> <li>6-ch x 8-bit<br/>resolution<br/>(successive<br/>approximation<br/>type)</li> <li>Low-voltage<br/>operation<br/>capability:<br/>V<sub>DD</sub> = 3.5 to<br/>6.0 V</li> </ul> |
| Timer/counter               |                      | . Basic interval timer x 1<br>. Timer/event counter x 2<br>. Watch timer x 1                                                          |                                                        | <ul> <li>Basic interval<br/>timer x 1</li> <li>Timer/event<br/>counter x 1</li> <li>Watch timer x<br/>1</li> </ul>                                                                   |
| Vectored<br>inter-<br>rupts |                      | . External: 3<br>. Internal: 4                                                                                                        |                                                        | . External: 3<br>. Internal: 3                                                                                                                                                       |
| Test<br>inputs              |                      | . External: 1<br>. Internal: 1                                                                                                        |                                                        | . External: 1<br>. Internal: 1                                                                                                                                                       |

(to be continued)

A−1 ■ 6427525 0095308 T21 ■

(cont'd)

| Product Name           | uPD75336 uPD75P336                       |                                    | uPD75328  |
|------------------------|------------------------------------------|------------------------------------|-----------|
| Buzzer output (BUZ)    | 2 kHz, 4 k                               | 2 kHz                              |           |
| 8-bit data processing* | Transfer, addition increment/decrement   | Transfer                           |           |
| On-chip PROM product   | uPD75P336                                |                                    | uPD75P328 |
| Package                | . 80 pin plastic (<br>. 80 pin plastic ) | . 80 pin plastic<br>QFP ( ] 14 mm) |           |

\*: See A.2 "Differences between uPD75336 and uPD75328 Instructions" for details.



## A.2 DIFFERENCES BETWEEN uPD75336 AND uPD75328 INSTRUCTIONS

uPD75336 instructions include the following in addition to those of the uPD75328.

Current users of the uPD75328 should refer to this table.

|        | Г                                                             | MOV                 | A, @HL+         |  |
|--------|---------------------------------------------------------------|---------------------|-----------------|--|
|        | Transfer                                                      | MOV                 | A. @HL-         |  |
|        |                                                               |                     | A, @HL+         |  |
|        | 5                                                             | XCH                 | A, @HL-         |  |
|        |                                                               |                     | CY, fmem. bit   |  |
|        | fer                                                           | It transfer<br>tooM | CY, pmem. @L    |  |
|        | Bit trans:                                                    |                     | CY, @H+mem. bit |  |
|        |                                                               |                     | fmem. bit. CY   |  |
|        |                                                               |                     | pmem. @L, CY    |  |
|        |                                                               |                     | @H+mem. bit, CY |  |
|        | Е 1                                                           | INCS                | rpl             |  |
|        | 2 NOTE                                                        | DECS                | rp'             |  |
|        | n H                                                           |                     | XA. @HL         |  |
| е<br>З |                                                               |                     | XA, rp'         |  |
| NOTE   | -                                                             | SEL                 | RBn             |  |
|        | NOTE 1 : Increment/decrement<br>2 : Comparison<br>3 : Special |                     |                 |  |

| _         | · · · · · · · · · · · · · · · · · · · |          |
|-----------|---------------------------------------|----------|
| Branch    | BR                                    | PCDE     |
| Bra       |                                       | PCXA     |
|           | ADDS                                  | XA, #n8  |
|           |                                       | XA, rpʻ  |
|           |                                       | rp'l, XA |
|           | ADDC                                  | ХА, гр'  |
|           | ADDC                                  | rp'l. XA |
| CITEC     | SUBS                                  | XA, rp'  |
| fon       |                                       | rp'l, XA |
| Operation | SUBC                                  | ХА, гр'  |
| ope       | 2010                                  | rp'l, XA |
|           | AND                                   | ХА, гр'  |
|           |                                       | rpʻl, XA |
|           | OR                                    | XA, rp'  |
|           |                                       | rp'l, XA |
|           | XOR                                   | ХА, гр'  |
|           | AOII                                  | rp'l, XA |

A-3 ■ 6427525 0095310 68T ■

## APPENDIX B. DEVELOPMENT TOOLS

The following development tools are available for system development using the uPD75336.

## Language Processor

| RA75X<br>relocatable<br>assembler | Host<br>Machine             | OS                                                       | Supply<br>Medium | Ordering Code<br>(Product Name) |
|-----------------------------------|-----------------------------|----------------------------------------------------------|------------------|---------------------------------|
|                                   | PC-9800<br>series           | MS-DOS <sup>TM</sup><br>[Ver. 3.30<br>to<br>Ver. 5.00A*] | 3.5-inch<br>2HD  | uS5A13RA75X                     |
|                                   |                             |                                                          | 5-inch<br>2HD    | uS5A10RA75X                     |
|                                   | IBM PC/<br>AT <sup>TM</sup> | PC DOS <sup>TM</sup><br>(Ver. 3.1)                       | 5-inch<br>2HC    | uS7B10RA75X                     |

\*: A task swapping function is provided in Ver. 5.00/5.00A, but cannot be used with this software.

B-1 🖿 6427525 0095311 516 🔳 .

### PROM Writing Tools

| Hardwar          | PG-1500               | Via the<br>PROM of<br>microco<br>the boa                                                                                 | e keyboard or<br>5 256K bits to<br>omputer with o                       | remote cont:<br>0 4M bits or<br>on-chip PROM | y programming<br>col of a typical<br>a single-chip<br>by connecting<br>ely available |  |  |  |  |  |
|------------------|-----------------------|--------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------|----------------------------------------------|--------------------------------------------------------------------------------------|--|--|--|--|--|
| e                | PA-75P328GC           | PROM pr<br>connect                                                                                                       | PROM programmer adapter for uPD75P336GC, used connected to the PG-1500. |                                              |                                                                                      |  |  |  |  |  |
|                  | PA-75P336GK           | 1 · · · • • • •                                                                                                          | PROM programmer adapter for uPD75P336GK, used connected to the PG-1500. |                                              |                                                                                      |  |  |  |  |  |
| S<br>Of<br>t     | PG-1500<br>controller | Connects the PG-1500 and host machine via a serial and parallel interface, and controls the PG-1500 on the host machine. |                                                                         |                                              |                                                                                      |  |  |  |  |  |
| w<br>a<br>r<br>e |                       | Host<br>Machine                                                                                                          | OS                                                                      | Supply<br>Medium                             | Ordering Code<br>(Product Name)                                                      |  |  |  |  |  |
|                  |                       |                                                                                                                          | MS-DOS<br>[Ver. 3.30]<br>to                                             | 3.5-inch<br>2HD                              | uS5A13PG1500                                                                         |  |  |  |  |  |
|                  |                       |                                                                                                                          | Ver. 5.00A*                                                             | 5-inch<br>2HD                                | uS5A10PG1500                                                                         |  |  |  |  |  |
|                  |                       | IBM PC/<br>AT                                                                                                            | PC DOS<br>(Ver. 3.1)                                                    | 5-inch<br>2HC                                | uS7B10PG1500                                                                         |  |  |  |  |  |

- \*: A task swapping function is provided in Ver. 5.00/5.00A, but cannot be used with this software.
- Remarks : The operation of RA75X relocatable assembler and PG-1500 controller is available only on the host machine and operation system described above.

# Debugging Tools

| H<br>ard<br>w<br>ar<br>e | I<br>*   | E-75000-R<br>1<br>1E-75000-                                               | perform<br>the dev<br>the 75X<br>combina<br>Efficie<br>to a ho                                                                                                                                                                                                                                                                                                                                | ing hardware<br>elopment of a<br>series. The<br>tion with an<br>ant debugging<br>st machine ar | n in-circuit e<br>and software<br>application sy<br>E IE-75000-R i<br>emulation pro<br>is possible<br>ad PROM program | debugging in<br>stems using<br>s used in<br>be.<br>by connecting<br>mmer. |  |  |
|--------------------------|----------|---------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------|--|--|
|                          |          | R-EM                                                                      | systems<br>EM is u                                                                                                                                                                                                                                                                                                                                                                            | using the 75<br>sed in combin<br>5001-R. It i                                                  | ix series. The<br>ation with the<br>s incorporate                                                                     | e IE-75000-R-<br>e IE-75000-R                                             |  |  |
| IE-75001-R               |          | perform<br>the dev<br>the 75X<br>combina<br>emulati<br>emulati<br>possibl | The IE-75001-R is an in-circuit emulator for<br>performing hardware and software debugging in<br>the development of application systems using<br>the 75X series. The IE-75001-R is used in<br>combination with a separately available<br>emulation board IE-75000-R-EM and the<br>emulation probe. Efficient debugging is<br>possible by connecting to a host machine and<br>PROM programmer. |                                                                                                |                                                                                                                       |                                                                           |  |  |
|                          | E)<br>_] | P-75336GC<br>R<br>EV-<br>9200GC-80                                        | Emulation probe for the uPD75336GC. Used in<br>conjunction with the IE-75000-R, or the<br>IE-75001-R and the IE-75000-R-EM. The 80-pin<br>conversion socket EV-9200GC-80 for easy<br>connection with the user system is provided.                                                                                                                                                             |                                                                                                |                                                                                                                       |                                                                           |  |  |
|                          | E)<br>-) | P-75336GK<br>R<br>EV-                                                     | Emulation probe for the uPD75336GK. Used in conjunction with the IE-75000-R, or the IE-75001-R and the IE-75000-R-EM. The 80-pin conversion adapter EV-9500GK-80 for easy                                                                                                                                                                                                                     |                                                                                                |                                                                                                                       |                                                                           |  |  |
|                          |          | 9500GK-80                                                                 | connection with the user system is provided.                                                                                                                                                                                                                                                                                                                                                  |                                                                                                |                                                                                                                       |                                                                           |  |  |
| S Off t ¥                | program  |                                                                           | the hos<br>I/F, and                                                                                                                                                                                                                                                                                                                                                                           | t machine via                                                                                  | 0-R and the II<br>RS-232-C and<br>e IE-75000-R a<br>st machine.                                                       | Centronics                                                                |  |  |
| a<br>H<br>e              |          |                                                                           | Host<br>Machine OS                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                | Supply<br>Medium                                                                                                      | Ordering Code<br>(Product Name)                                           |  |  |
|                          |          |                                                                           | PC-9800 MS-DOS<br>series [ Ver.3.30                                                                                                                                                                                                                                                                                                                                                           |                                                                                                | 3.5-inch 2HD                                                                                                          | uS5A131E75X                                                               |  |  |
|                          |          |                                                                           | series                                                                                                                                                                                                                                                                                                                                                                                        | to<br>Ver.5.00A*2                                                                              | 5-inch 2HD                                                                                                            | uS5A10IE75X                                                               |  |  |
|                          |          |                                                                           | IBM PC<br>series                                                                                                                                                                                                                                                                                                                                                                              | PC DOS<br>(Ver.3.1)                                                                            | 5-inch 2HC                                                                                                            | uS7B10IE75X                                                               |  |  |
| ·                        | ·        |                                                                           |                                                                                                                                                                                                                                                                                                                                                                                               | 6427525 009                                                                                    | 5313 399 🔳 🦳                                                                                                          | J                                                                         |  |  |

в-3

- \*1: Maintenance product
  - 2: A task swapping function is provided in Ver. 5.00/5.00A, but cannot be used with this software.
- Remarks: The operation of IE control program is available only on the host machine and operation system described above.





#### APPENDIX C. MASK ROM ORDERING PROCEDURE

After completion of the uPD75336 program, the following procedure should be used to order the mask ROM.

(1) Mask ROM order reservation

Inform an NEC agent or NEC sales department of your intention to make a mask ROM order.

### 2 Order medium creation

The medium for a mask ROM order is UVEPROM or an 8-inch IBMformat floppy disk. When ordering using UVEPROM, 3 UVEPROMs with the same contents should be prepared (for a product with a mask option, the mask option data should be submitted on a mask option information sheet).

3 Required documents

The following documents need to be completed when ordering mask ROM.

A. Mask ROM order form

B. Mask ROM order checksheet

C. Mask option information sheet (only required for a product with a mask option)

(4) Ordering

The medium described in (2) and the documents listed in (3) above should be submitted to an NEC agent or NEC sales department by the order reservation date.

NOTE: For details, please refer to Information Document "ROM Code Ordering Procedure" (Document No.: IEM-834).

#### C-1 6427525 0095316 OT& 🖿

### APPENDIX D. INSTRUCTION INDEX

## D.1 INSTRUCTION INDEX (IN FUNCTIONAL ORDER)

|             | Instruction         | Page    |         | Instruction     | Page           |
|-------------|---------------------|---------|---------|-----------------|----------------|
| [Trans      | fer Instructions]   |         | · ·     |                 |                |
|             |                     |         | ADDS    | XA, #n8         | 10-36          |
| MOV         | A, mem              | 10-26   | SUBC    | A, QHL          | 10-41          |
| MOV         | A, reg              | 10-27   | SUBC    | rp'1, XA        | 10-42          |
| MOV         | A, #n4              | 10-23   | SUBC    | XA, rp'         | 10-41          |
| MOV         | A, @rpa             | 10-24   | SUBS    | A, QHL          | 10-39          |
| MOV         | mem, A              | 10-26   | SUBS    | rp'1, XA        | 10-40          |
| MOV         | mem, XA             | 10-27   | SUBS    | XA, rp'         | 10-40          |
| MOV         | regĺ, A             | 10-28   | AND     | A, #n4          | 10-42          |
| MOV         | regl, #n4           | 10-23   |         | A, QHL          | 10-42          |
| MOV         | rp, #n8             | 10-24   |         | XA, rp'         | 10-43          |
| MOV         | rp'1, XA            | 10-28   |         | rp'l, XA        | 10-43          |
| MOV         | XA, mem             | 10-26   |         | A, #n4          | 10-43          |
| MOV         | XA, rp'             | 10-27   | OR      | A, @HL          | 10-44          |
| MOV         | XA, QHL             | 10-25   | OR      | rp'1, XA        | 10-44          |
| MOV         | QHL, A              | 10-25   | OR      | XA, rp'         | 10-44          |
| MOV         | QHL, XA             | 10-25   | XOR     | A, #n4          | 10-45          |
| XCH         | A, @rpa             | 10-29   | XOR     | A, QHL          | 10-45          |
| XCH         | A, mem              | 10-30   | XOR     | rp'1, XA        | 10-46          |
| XCH         | A, regl             | 10-30   | XOR     | XA, rp'         | 10-45          |
| ХСН         | XA, @HL             | 10-30   |         | ,               |                |
| XCH         | XA, mem             | 10-30   | [ Accur | nulator Operat: | ina            |
| ХСН         | XA, rp'             | 10-31   |         | ructions]       | 3              |
| [Table      | Reference Instruc   | tions]· | RORC    | A               | 10-46          |
|             |                     |         | NOT     | A               | 10-46          |
| <b>IOVT</b> | XA, @PCDE           | 10-32   | -       | - 4             |                |
| IOVT        | XA, @PCXA           | 10-34   |         | ement/Decremen  | t              |
|             |                     | 1       | Insti   | ructions]       |                |
| BIT T       | ransfer Instruction | ns j    | TNOC    |                 | 10 47          |
|             |                     | 10.05   | INCS    | mem             | 10-47<br>10-47 |
| MOV1        | CY, fmem.bit        | 10-35   | INCS    | reg             |                |
| MOV1        | CY, pmem.@L         | 10-35   | INCS    | rpl             | 10-47          |
| MOV1        | CY, @H + mem.bit    |         | INCS    | <b>@HL</b>      | 10-47          |
| MOV1        | fmem.bit, CY        | 10-35   | DECS    | reg             | 10-48          |
| MOV1        | pmem.@L, CY         | 10-35   | DECS    | rp'             | 10-48          |
| MOV1        | @H + mem.bit, CY    | 10-35   | [Compa  | arison Instruct | tionsl         |
| Opera       | tion Instructions]  |         |         |                 |                |
|             |                     |         | SKE     | A, reg          | 10-50          |
| ADDC        | A, QHL              | 10-38   | SKE     | A, QHL          | 10-49          |
| ADDC        | rp'1, XA            | 10-39   | SKE     | reg, #n4        | 10-49          |
| ADDC        | XA, rp'             | 10-38   | SKE     | XA, rp'         | 10-50          |
| ADDS        |                     | 10-36   | SKE     | XA, @HL         | 10-49          |
| ADDS        |                     | 10-36   | SKE     | @HL, #n4        | 10-49          |
| ADDS        | rp'1, XA            | 10-37   |         |                 |                |
| ADDS        | XA, rp'             | 10-37   |         | (to)            | pe continued)  |

D-1 6427525 0095317 T34 🖿

| $\langle$ | ( | con | it' | d | ) |
|-----------|---|-----|-----|---|---|
|-----------|---|-----|-----|---|---|

|             |                    |       |         |                 | (cont'd |
|-------------|--------------------|-------|---------|-----------------|---------|
|             | Instruction        | Page  |         | Instruction     | Page    |
|             | y Flag Operating   |       |         | outine Stack    |         |
| Inst        | ructions]          |       | Conti   | rol Instruction | s]      |
| SET1        | CY                 | 10-51 | CALL    | !addr           | 10-60   |
| CLR1        | CY                 | 10-51 | CALLF   | !faddr          | 10-60   |
| SKT         | CY                 | 10-51 | TCALL   | laddr           | 10-61   |
| NOT1        | CY                 | 10-51 | RET     |                 | 10-61   |
|             |                    |       | RETI    |                 | 10-62   |
| [Memo       | ory Bit Manipulati | ion   | RETS    |                 | 10-62   |
| Inst        | tructions]         |       | PUSH    | BS              | 10-63   |
|             |                    |       | PUSH    | rp              | 10-63   |
|             |                    |       | POP     | BS              | 10-64   |
| SET1        | fmem.bit           | 10-52 | POP     | rp              | 10-63   |
| SET1        | mem.bit            | 10-52 |         | -               |         |
| SET1        | pmem.@L            | 10-52 | [Inter  | rupt Control    |         |
| SET1        | @H + mem.bit       | 10-52 |         | uctions]        |         |
| CLR1        | fmem.bit           | 10-53 |         | -               |         |
| CLR1        | mem.bit            | 10-52 | EI      | •               | 10-65   |
| CLR1        | pmem.@L            | 10-53 | EI      | IEXXX           | 10-65   |
| CLR1        | @H + mem.bit       | 10-53 | DI      |                 | 10-65   |
| SKT         | fmem.bit           | 10-53 | DI      | IEXXX           | 10-65   |
| SKT         | mem.bit            | 10-53 |         |                 |         |
| SKT         | pmem.@L            | 10-53 | [Input  | /Output Instruc | ctions] |
| SKT         | @H + mem.bit       | 10-53 | _       | -               |         |
| SKF         | fmem.bit           | 10-54 | IN      | A, PORTn        | 10-66   |
| SKF         | mem.bit            | 10-54 | IN      | XA, PORTn       | 10-66   |
| SKF         | pmem.@L            | 10-54 | OUT     | PORTn, A        | 10-67   |
| SKF         | @H + mem.bit       | 10-54 | OUT     | PORTn, XA       | 10-67   |
| SKTCLR      |                    | 10-54 |         |                 |         |
| SKTCLR      |                    | 10-54 | [CPU C  | ontrol Instruct | ions]   |
| SKTCLR      | •                  | 10-54 |         |                 |         |
| AND1        | CY, fmem.bit       | 10-55 | HALT    |                 | 10-68   |
| AND1        | CY, pmem.@L        | 10-55 | STOP    |                 | 10-68   |
| AND1        | CY, @H + mem.bit   |       | NOP     |                 | 10-68   |
| OR1<br>OR1  | CY, fmem.bit       | 10-55 |         | _               |         |
|             | CY, pmem.@L        | 10-55 | [Specia | al Instructions | ;]      |
| OR1<br>XOR1 | CY, @H + mem.bit   |       |         |                 |         |
| XOR1        | CY, fmem.bit       |       | SEL     | MBn             | 10-69   |
| XOR1        |                    | 10-55 | SEL     | RBn             | 10-69   |
|             | CY, @H + mem.bit   | 10-22 | GETI    | taddr           | 10-69   |
| [Brancl     | h Instructions]    |       |         |                 |         |
| BR          | addr               | 10-56 | •       |                 |         |
| BR          | !addr              | 10-56 |         | ÷               |         |
| BR          | \$addr             | 10-56 |         |                 |         |
| BR          | PCDE               | 10-58 |         |                 |         |
| BR          | PCXA               | 10-59 |         |                 |         |
| BRCB        | !caddr             | 10-57 |         |                 |         |
| <b>FBR</b>  | addr               | 10-59 |         |                 |         |
|             |                    |       |         |                 |         |
|             |                    |       |         |                 |         |

## D.2 INSTRUCTION INDEX (IN ALPHABETICAL ORDER)

|       | Instruction      | Page  |      | Instruction      | Page  |
|-------|------------------|-------|------|------------------|-------|
| ADDC  | A, @HL           | 10-38 | INCS | rp1              | 10-47 |
| ADDC  | rp'1, XA         | 10-39 | INCS | <b>@HL</b>       | 10-47 |
| ADDC  | XA, rp'          | 10-38 | MOV  | A, mem           | 10-26 |
| ADDS  | A, #n4           | 10-36 | MOV  | A, reg           | 10-27 |
| ADDS  | A, QHL           | 10-36 | MOV  | A, #n4           | 10-23 |
| ADDS  | rp'1, XA         | 10-37 | MOV  | A, @rpa          | 10-24 |
| ADDS  | XA, rp'          | 10-37 | MOV  | mem, A           | 10-26 |
| ADDS  | XA, #n8          | 10-36 | MOV  | mem, XA          | 10-27 |
| AND   | A, #n4           | 10-42 | MOV  | regl, A          | 10-28 |
| AND   | A, GHL           | 10-42 | MOV  | reg1, #n4        | 10-23 |
| AND   | rp'1, XA         | 10-43 | MOV  | rp, #n8          | 10-24 |
| AND   | XA, rp'          | 10-43 | MOV  | rp'l, XA         | 10-28 |
| AND1  | CY, fmem.bit     | 10-55 | MOV  | XA, mem          | 10-26 |
| AND1  | CY, pmem.@L      | 10-55 | MOV  | XA, rp'          | 10-27 |
| AND1  | CY, QH + mem.bit | 10-55 | MOV  | XA, QHL          | 10-25 |
| BR    | addr             | 10-56 | MOV  | QHL, A           | 10-25 |
| BR    | !addr            | 10-56 | MOV  | GHL, XA          | 10-25 |
| BR    | \$addr           | 10-56 | MOVT | XA, @PCDE        | 10-32 |
| BR    | PCDE             | 10-58 | MOVT | XA, @PCXA        | 10-34 |
| BR    | PCXA             | 10-59 | MOV1 | CY, fmem.bit     | 10-35 |
| BRCB  | !caddr           | 10-57 | MOV1 | CY, pmem.@L      | 10-35 |
| CALL  | !addr            | 10-60 | MOV1 | CY, @H + mem.bit | 10-35 |
| CALLF | !faddr           | 10-60 | MOV1 | fmem.bit, CY     | 10-35 |
| CLR1  | CY               | 10-51 | MOV1 | pmem.@L, CY      | 10-35 |
| CLR1  | fmem.bit         | 10-53 | MOV1 | QH + mem.bit, CY |       |
| CLR1  | mem.bit          | 10-52 | NOP  |                  | 10-68 |
| CLR1  | pmem.@L          | 10-53 | NOT  | A                | 10-46 |
| CLR1  | QH + mem.bit     | 10-53 | NOT1 | CY               | 10-51 |
| DECS  | reg              | 10-48 | OR   | A, #n4           | 10-43 |
| DECS  | rp'              | 10-48 | OR   | A, GHL           | 10-44 |
| DI    |                  | 10-65 | OR   | rp'1, XA         | 10-44 |
| DI    | IEXXX            | 10-65 | OR   | XA, rp'          | 10-44 |
| EI    |                  | 10-65 | OR1  | CY, fmem.bit     | 10-55 |
| EI    | IExxx            | 10-65 | OR1  | CY, pmem.@L      | 10-55 |
| GETI  | taddr            | 10-69 | OR1  | CY, QH + mem.bit | 10-55 |
| HALT  |                  | 10-68 | OUT  | PORTN, A         | 10-67 |
| IN    | A, PORTn         | 10-66 | OUT  | PORTN, XA        | 10-67 |
| IN    | XA, PORTn        | 10-66 | POP  | BS               | 10-64 |
| INCS  | mem              | 10-47 | POP  | rp               | 10-63 |
| INCS  | reg              | 10-47 | PUSH | BS               | 10-63 |
|       |                  |       | PUSH | rp               | 10-63 |
|       |                  |       |      |                  |       |

(to be continued)

D-3 🖬 6427525 0095319 807 🎟

(cont'd)

|      | Instruction  | Page  |        | Instruction      | Page  |
|------|--------------|-------|--------|------------------|-------|
| RET  |              | 10-61 | SKTCLR | fmem.bit         | 10-54 |
| RETI |              | 10-62 | SKTCLR | pmem.@L          | 10-54 |
| RETS |              | 10-62 |        | QH + mem.bit     | 10-54 |
| RORC | A            | 10-46 | STOP   | -                | 10-68 |
| SEL  | MBn          | 10-69 | SUBC   | A, QHL           | 10-41 |
| SEL  | RBn          | 10-69 | SUBC   | rp'1, XA         | 10-42 |
| SET1 | CY           | 10-51 | SUBC   | XA, rp'          | 10-41 |
| SET1 | fmem.bit     | 10-52 | SUBS   | A, QHL           | 10-39 |
| SET1 | mem.bit      | 10-52 | SUBS   | rp'1, XA         | 10-40 |
| Set1 | pmem.@L      | 10-52 | SUBS   | XA, rp'          | 10-40 |
| SET1 | @H + mem.bit | 10-52 | TBR    | addr             | 10-59 |
| SKE  | A, reg       | 10-50 | TCALL  | !addr            | 10-61 |
| SKE  | A, QHL       | 10-49 | XCH    | A, @rpa          | 10-29 |
| SKE  | reg, #n4     | 10-49 | XCH    | A, mem           | 10-30 |
| SKE  | XA, rp'      | 10-50 | XCH    | A, regl          | 10-30 |
| SKE  | XA, QHL      | 10-49 | ХСН    | XA, QHL          | 10-30 |
| SKE  | @HL, #n4     | 10-49 | XCH    | XA, mem          | 10-30 |
| SKF  | fmem.bit     | 10-54 | ХСН    | XA, rp'          | 10-31 |
| SKF  | mem.bit      | 10-54 | XOR    | A, #n4           | 10-45 |
| SKF  | pmem.@L      | 10-54 | XOR    | A, QHL           | 10-45 |
| SKF  | @H + mem.bit | 10-54 | XOR    | rp'l, XA         | 10-46 |
| SKT  | CY           | 10-51 | XOR    | XA, rp'          | 10-45 |
| SKT  | fmem.bit     | 10-53 | XOR1   | CY, fmem.bit     | 10-55 |
| SKT  | mem.bit      | 10-53 | XOR1   | CY, pmem.@L      | 10-55 |
| SKT  | pmem.GL      | 10-53 | XOR1   | CY, QH + mem.bit | 10-55 |
| SKT  | QH + mem.bit | 10-53 | . –    |                  |       |

■ 6427525 0095320 529 ■ D-4

### APPENDIX E. HARDWARE INDEX (ALPHABETICAL ORDER)

## Hardware Index

## [A]

| Acknowledge Detection Bit (ACKD)   | 5-86  |
|------------------------------------|-------|
| Acknowledge Enable Bit(ACKE)       | 5-86  |
| Acknowledge Trigger Bit (ACKT)     | 5-85  |
| A/D Conversion Mode Register (ADM) | 5-201 |

## [B]

| Bit Port Output 0 to 7 (BPO to BP7)         | 5-2   |
|---------------------------------------------|-------|
| Bit Sequential Buffer 0 to 3 (BSB0 to BSB3) | 5-209 |
| Busy Enable Bit (BSYE)                      | 5-86  |
| Basic Interval Timer (BT)                   | 5-45  |
| Basic Interval Timer Mode Register(BTM)     | 5-46  |
| BT Interrupt Enable Flag (IEBT)             | 6-7   |
| BT Interrupt Request Flag (IRQBT)           | 6-6   |
| Bus Release Detection Flag (RELD)           | 5-85  |
| Bus release Trigger Bit (REKT)              | 5-85  |

## [C]

| Clock Output Mode Register (CLOM) | 5-43 |
|-----------------------------------|------|
| Command Detection Flag (CMDD)     | 5-85 |
| Command Trigger Bit (CMDT)        | 5-85 |
| COI                               | 5-81 |
| CSIE                              | 5-79 |
| CSIM                              | 5-79 |
| Carry Flag (CY)                   | 4-18 |

## [E]

| EOC | <br> | 5-201 |
|-----|------|-------|
|     |      |       |

### [I]

| INTOO Interrupt Enable Flag O (IEO)     | 6-6  |
|-----------------------------------------|------|
| INTO1 Interrupt Enable Flag 1 (IE1)     | 6-6  |
| INTO2 Interrupt Enable Flag 2 (IE2)     | 6-6  |
| INTO4 Interrupt Enable Flag 4 (IE4)     | 6-6  |
| INTO Edge Detection Mode Register (IMO) | 6-15 |

## E-1 ■ 6427525 0095321 465 ■

| INT1 Edge Detection Mode Register (IM1)INT2 Edge Detection Mode Register (IM2)Interrupt Master Enable Flag (IME)INT0 Interrupt Request Flag (IRQ0) | 6-15<br>6-15<br>6-9<br>6-6<br>6-6 |
|----------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|
| Interrupt Master Enable Flag (IME)                                                                                                                 | 6-9<br>6-6                        |
|                                                                                                                                                    | 6-6                               |
| INTO Interrupt Request Flag (IPOO)                                                                                                                 |                                   |
| INTO Interrupt Request Flag (IRQO)                                                                                                                 | 6-6                               |
| INT1 Interrupt Request Flag (IRQ1)                                                                                                                 |                                   |
| INT2 Interrupt Request Flag (IRQ2)                                                                                                                 | 6-6                               |
| INT4 Interrupt Request Flag (IRQ4)                                                                                                                 | 6-6                               |
| Interrupt Status Flag (ISTO, IST1)                                                                                                                 | 4-20                              |
|                                                                                                                                                    | 6-20                              |
|                                                                                                                                                    |                                   |
| [K]                                                                                                                                                |                                   |
| Key Interrupt 0 to 7 (KRO to KR7)                                                                                                                  | 6-16                              |
|                                                                                                                                                    |                                   |
| [L]                                                                                                                                                |                                   |
| LCD Control Register (LCDC)                                                                                                                        | 5-165                             |
| LCD Mode Register (LCDM)                                                                                                                           | 5-163                             |
|                                                                                                                                                    |                                   |
| [M]                                                                                                                                                |                                   |
| Memory Bank Enable Flag (MBE)                                                                                                                      | 4-21                              |
| Memory Bank Selection Register (MBS)                                                                                                               | 4-23                              |
|                                                                                                                                                    | - 20                              |
| [P]                                                                                                                                                |                                   |
| Program Counter (PC)                                                                                                                               | 4-1                               |
| Processor Clock Control Register (PCC)                                                                                                             | 5-30                              |
| Port Mode Register Group A, B, C                                                                                                                   | 0.00                              |
| (PMGA, PMGB, PMGC)                                                                                                                                 | 5-10                              |
| Pull-up Resistor Specification Group A, B POGA, POGB                                                                                               | 5-10                              |
|                                                                                                                                                    | 5-19                              |
| Post (POPTO 1 FOFTO)                                                                                                                               | 5-2                               |
| Program Status Word (PSW)                                                                                                                          | 5-2<br>4-17                       |
|                                                                                                                                                    | ₩~I/                              |

## [R]

| Memory Bank Enable Flag (RBE)        | 4-21 |
|--------------------------------------|------|
| Memory Bank Selection Register (RBS) | 4-22 |

■ 6427525 0095322 3T1 ■ E-2

# [S]

| SA Register (SA)                                | 5-202 |
|-------------------------------------------------|-------|
| Serial Bus Interface Control Register (SBIC)    | 5-84  |
| Serial Interface Interrupt Enable Flag (IECSI)  | 6-7   |
| Serial Interface Interrupt Request Flag (IRQCSI | 6-6   |
| System Clock Control Register (SCC)             | 5-31  |
| Shift Register (SIO)                            | 5-87  |
| Skip Flag 0 to 2 (SKO to SK2)                   | 4-19  |
| Conversion Start Specification Bit (SOC)        | 5-201 |
| Stack Pointer (SP)                              | 4-16  |
| Slave Address Register (SVA)                    | 5-89  |

# [T]

| Timer/Event Counter Register (T0,T1)                 | 5-58 |
|------------------------------------------------------|------|
| Timer/Event Counter Output Enable Flag (TOEO, TOE1)  | 5-61 |
| Timer/Event Counter Mode Register (TMO, TM1)         | 5-59 |
| Timer/Event Counter Modulo Register(TMODO, TMOD1)    | 5-58 |
| Timer/Event Counter 0 Interrupt Enable Flag (IET0)   | 6-7  |
| Timer/Event Counter 0 Interrupt Request Flag (IRQT0) | 6-6  |
| Timer/Event Counter 1 Interrupt Request Flag (IRQT1) | 6-6  |

## [W]

| Watch Mode Register (WM)                  | 5-54 |
|-------------------------------------------|------|
| Natch Timer Interrupt Enable Flag (IEW)   | 6-7  |
| Watch Timer Interrupt Request Flag (IRQW) | 6-6  |
| Wake Up Function Specification Bit (WUP)  | 5-81 |

E-3 · 🖿 6427525 0095323 238 🎟