# Old Company Name in Catalogs and Other Documents

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

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

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

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

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

# Notice

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

# RENESAS

# **Application Note**

# 78K0/Kx2-L

# Sample Program (Serial Interface IICA)

# **Master Communication**

This document describes an operation overview of the sample program and how to use it, as well as how to set up and use serial interface IICA. In the sample program, 16 bytes of data are transmitted and received via the l<sup>2</sup>C bus in master operation. Communication starts at intervals of about 5 ms, alternating between transmission and reception.

Target devices 78K0/KY2-L microcontroller 78K0/KA2-L microcontroller 78K0/KB2-L microcontroller 78K0/KC2-L microcontroller

# CONTENTS

| CHAPTER 1 OVERVIEW                           | 3  |
|----------------------------------------------|----|
| 1.1 Primary Initial Settings                 |    |
| 1.2 Processing After Main Loop               |    |
| CHAPTER 2 CIRCUIT DIAGRAM                    |    |
| 2.1 Circuit Diagram                          | 5  |
| 2.2 Used Device Other than Microcontroller   |    |
| CHAPTER 3 SOFTWARE                           | 7  |
| 3.1 Included Files                           | 7  |
| 3.2 Internal Peripheral Functions to Be Used | 7  |
| 3.3 Initial Settings and Operation Overview  |    |
| 3.4 Flow Charts                              | 9  |
| CHAPTER 4 SETTING METHODS                    |    |
| 4.1 Setting Up Serial Interface IICA         | 12 |
| 4.2 Software Coding Example                  | 24 |
| CHAPTER 5 RELATED DOCUMENTS                  | 30 |
| APPENDIX A PROGRAM LIST                      | 31 |
| APPENDIX B USING 78K0/KC2-L 44-PIN PRODUCTS  | 60 |
| APPENDIX C REVISION HISTORY                  | 61 |
|                                              |    |

Document No. U19690EJ1V0AN00 (1st edition) Date Published August 2009 N

© NEC Electronics Corporation 2009

- The information in this document is current as of May, 2009. The information is subject to change without notice. For actual design-in, refer to the latest publications of NEC Electronics data sheets, etc., for the most up-to-date specifications of NEC Electronics products. Not all products and/or types are available in every country. Please check with an NEC Electronics sales representative for availability and additional information.
- No part of this document may be copied or reproduced in any form or by any means without the prior written consent of NEC Electronics. NEC Electronics assumes no responsibility for any errors that may appear in this document.
- NEC Electronics does not assume any liability for infringement of patents, copyrights or other intellectual property rights of third parties by or arising from the use of NEC Electronics products listed in this document or any other liability arising from the use of such products. No license, express, implied or otherwise, is granted under any patents, copyrights or other intellectual property rights of NEC Electronics or others.
- Descriptions of circuits, software and other related information in this document are provided for illustrative purposes in semiconductor product operation and application examples. The incorporation of these circuits, software and information in the design of a customer's equipment shall be done under the full responsibility of the customer. NEC Electronics assumes no responsibility for any losses incurred by customers or third parties arising from the use of these circuits, software and information.
- While NEC Electronics endeavors to enhance the quality and safety of NEC Electronics products, customers agree and acknowledge that the possibility of defects thereof cannot be eliminated entirely. In addition, NEC Electronics products are not taken measures to prevent radioactive rays in the product design. When customers use NEC Electronics products with their products, customers shall, on their own responsibility, incorporate sufficient safety measures such as redundancy, fire-containment and anti-failure features to their products in order to avoid risks of the damages to property (including public or social property) or injury (including death) to persons, as the result of defects of NEC Electronics products.
- NEC Electronics products are classified into the following three quality grades: "Standard", "Special" and "Specific".

The "Specific" quality grade applies only to NEC Electronics products developed based on a customerdesignated "quality assurance program" for a specific application. The recommended applications of an NEC Electronics product depend on its quality grade, as indicated below. Customers must check the quality grade of each NEC Electronics product before using it in a particular application.

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

The quality grade of NEC Electronics products is "Standard" unless otherwise expressly specified in NEC Electronics data sheets or data books, etc. If customers wish to use NEC Electronics products in applications not intended by NEC Electronics, they must contact an NEC Electronics sales representative in advance to determine NEC Electronics' willingness to support a given application.

(Note)

- (1) "NEC Electronics" as used in this statement means NEC Electronics Corporation and also includes its majority-owned subsidiaries.
- (2) "NEC Electronics products" means any product developed or manufactured by or for NEC Electronics (as defined above).

### **CHAPTER 1 OVERVIEW**

This sample program shows an example of using serial interface IICA. 16 bytes of data are transmitted and received via the l<sup>2</sup>C bus in master operation. Communication starts at intervals of about 5 ms, alternating between transmission and reception.



Caution For a definition of the I<sup>2</sup>C bus, refer to the <u>78K0/Kx2-L User's Manual</u>.

### 1.1 Primary Initial Settings

The primary initial settings are as follows.

<Option byte settings>

- Allowing the internal low-speed oscillator to be programmed to stop
- Disabling the watchdog timer
- Setting the internal high-speed oscillation clock frequency to 8 MHz
- Disabling LVI from being started by default

<Settings during initialization immediately after a reset ends>

- Specifying the ROM and RAM sizes
- Setting up I/O ports
- Checking whether VDD is 2.7 V or more by using the low-voltage detector<sup>Note 1</sup>
- Specifying that the CPU clock and peripheral hardware clock run on the internal high-speed oscillation clock (8 MHz)
- Disabling peripheral hardware not to be used
- Setting up serial interface IICA
  - Specifying fast mode as the operating mode and setting the transfer clock frequency to 400 kHz
  - Specifying 50H as the local address
  - Specifying that P60/SCLA0 and P61/SDAA0 are used for the I<sup>2</sup>C bus
  - Enabling the INTIICA0 interrupt<sup>Note 2</sup>
- Specifying that 8-bit timer H1<sup>Note 3</sup> runs in intervals of about 5 ms to trigger I<sup>2</sup>C communication

Notes 1. For details about the low-voltage detector, refer to the <u>78K0/Kx2-L User's Manual</u>.

- 2. In this sample program, the HALT mode is entered while the system waits for data communication to end, and the HALT mode is exited when the INTIICA0 interrupt is generated at the end of data communication. When adding other interrupts to this sample program, make sure that these interrupts do not affect the HALT mode from being exited when the INTIICA0 interrupt occurs.
- 3. For details about 8-bit timer H1, refer to the <u>78K0/Kx2-L User's Manual</u>.

# 1.2 Processing After Main Loop

After the initial settings have been specified, the STOP mode is entered. Next, the STOP mode is exited when the INTTMH1 interrupt is generated at intervals of about 5 ms, and I<sup>2</sup>C transmission starts. The transmission data is assumed to be 16 bytes and the slave address to which the data is transmitted is assumed to be A0H. If transmission does not end normally, transmission restarts up to three times. After transmission ends, the STOP mode is entered again. The STOP mode is exited when the INTTMH1 interrupt is generated at intervals of about 5 ms, and I<sup>2</sup>C reception starts. 16 bytes of data are received and then saved in RAM.

In the same way, transmission and reception alternate at intervals of about 5 ms.

### **CHAPTER 2 CIRCUIT DIAGRAM**

This chapter provides a circuit diagram used in this sample program.

#### 2.1 Circuit Diagram

A circuit diagram is shown below.



Notes 1. This is shared with AVss in the 78K0/KY2-L and 78K0/KA2-L.

2. This is provided only in the 78K0/KB2-L and 78K0/KC2-L.

Cautions 1. Use the microcontroller at a voltage in the range of 2.94 V  $\leq$  V DD  $\leq$  5.5 V.

- 2. Connect REGC to Vss via a capacitor (0.47 to 1  $\mu$ F).
- 3. For the 78K0/KY2-L and 78K0/KA2-L, Vss is also used as the ground potential for the A/D converter. Be sure to connect Vss to a stable GND.
- 4. Make the AVss pin have the same potential as Vss and connect it directly to GND (only for the 78K0/KB2-L and 78K0/KC2-L microcontrollers).
- 5. Connect the AVREF pin directly to VDD.
- 6. Handle unused pins that are not shown in the circuit diagram as follows:
  - I/O ports: Set them to output mode and leave them open (unconnected).
    - Input ports: Connect them independently to VDD or Vss via a resistor.
- 7. Adjust the resistance of the pull-up resistors connected to the serial clock line and serial data bus line (enclosed in the dotted lines above) in accordance with the voltage and capacitance of the  $l^2C$  bus and the transfer clock. In this sample program, resistors with a resistance of 2 to 10 k $\Omega$  are used.
- In this sample program, the P121/X1/TOOLC0 and P122/X2/EXCLK/TOOLD0 pins are used for onchip debugging.

# 2.2 Used Device Other than Microcontroller

The following device is used in addition to the microcontroller:

### (1) Slave device

A device that performs slave transmission and reception is used as the other party of I<sup>2</sup>C master communication.

# **CHAPTER 3 SOFTWARE**

This chapter describes the files included in the compressed file to be downloaded, internal peripheral functions of the microcontroller to be used, and initial settings and provides an operation overview of the sample program and the flow charts.

# 3.1 Included Files

The following table shows the files included in the compressed file to be downloaded.

| File Name                                                                 | Description                                                                                                                                                                                                           | Compressed (*.zip) File Included |                   |  |
|---------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|-------------------|--|
|                                                                           |                                                                                                                                                                                                                       | ŝ                                | ₽₩<br>3101        |  |
| main.asm<br>(Assembly language version)<br>main.c<br>(C language version) | Source file for hardware initialization processing and main processing of microcontroller                                                                                                                             | ● <sup>Note</sup>                | ● <sup>Note</sup> |  |
| op.asm                                                                    | Assembler source file for setting the option byte<br>(This file is used for setting up the watchdog timer and internal<br>low-speed oscillator and selecting the internal high-speed<br>oscillation clock frequency.) | •                                | •                 |  |
| Kx2-L_IICAM.prw                                                           | Work space file for integrated development environment PM+                                                                                                                                                            |                                  | •                 |  |
| Kx2-L_IICAM.prj                                                           | Project file for integrated development environment PM+                                                                                                                                                               |                                  | •                 |  |

Note "main.asm" is included with the assembly language version, and "main.c" with the C language version.



: Only the source file is included.

: The files to be used with integrated development environment PM+ are included.

# 3.2 Internal Peripheral Functions to Be Used

The following internal peripheral functions of the microcontroller are used in this sample program.

#### (1) Peripheral hardware

Qр,

- 8-bit timer H1: Triggers I<sup>2</sup>C communication.
- Low-voltage detector: Checks whether VDD is 2.7 V or more.
- (2) Pin functions
  - SCLA0/P60: Used as the I<sup>2</sup>C serial clock pin.
  - SDAA0/P61: Used as the I<sup>2</sup>C serial data bus pin.

### 3.3 Initial Settings and Operation Overview

In this sample program, initial settings including the selection of the clock frequency, setting of the I/O ports, and setting of serial interface IICA are performed. After the initial settings have been specified, the STOP mode is entered. Next, the STOP mode is exited when the INTTMH1 interrupt is generated at intervals of about 5 ms, and I<sup>2</sup>C transmission starts. The transmission data is assumed to be 16 bytes and the slave address to which the data is transmitted is assumed to be A0H. If transmission does not end normally, transmission restarts up to three times. After transmission ends, the STOP mode is entered again. The STOP mode is exited when the INTTMH1 interrupt is generated at intervals of about 5 ms, and I<sup>2</sup>C reception starts. 16 bytes of data are received and then saved in RAM.

In the same way, transmission and reception alternate at intervals of about 5 ms.

The details are described in the state transition diagram shown below.





#### 3.4 Flow Charts

The flow charts for the sample program are shown below.





- **Notes 1.** The option byte is automatically referenced by the microcontroller immediately after a reset ends. In this sample program, the following settings are specified using the option byte:
  - Allowing the internal low-speed oscillator to be programmed to stop
  - Disabling the watchdog timer
  - Setting the internal high-speed oscillation clock frequency to 8 MHz
  - Disabling LVI from being started by default
  - 2. P60/SCLA0 and P61/SDAA0 are specified as input ports so that port output does not affect the I<sup>2</sup>C bus.
  - **3.** The low-voltage detector is enabled, and then the system is made to wait at least 10  $\mu$ s until the low-voltage detector stabilizes.
  - **4.** The STOP mode is exited when the INTTMH1 interrupt is generated at intervals of about 5 ms by using 8-bit timer H1.
  - 5. The HALT mode is entered during communication, and then exited when the INTIICA0 interrupt occurs at the end of communication.
  - **6.** Make the system wait about 10  $\mu$ s before executing a restart.

# **CHAPTER 4 SETTING METHODS**

This chapter describes how to set up serial interface IICA and provides software coding examples.

For other initial settings, refer to the <u>78K0/Kx2-L Sample Program (Initial Settings) LED Lighting Switch Control</u> <u>Application Note</u>.

For how to set registers, refer to the <u>78K0/Kx2-L User's Manual</u>.

For assembler instructions, refer to the <u>78K/0 Series Instructions User's Manual</u>.

# 4.1 Setting Up Serial Interface IICA

Serial interface IICA uses the following eight registers.

- IICA control register 0 (IICACTL0)
- IICA flag register 0 (IICAF0)
- IICA control register 1 (IICACTL1)
- IICA low-level width setting register (IICWL)
- IICA high-level width setting register (IICWH)
- Port output mode register 6 (POM6)
- Port mode register 6 (PM6)
- Port register 6 (P6)

#### [Example of the setup procedure when using serial interface IICA for I<sup>2</sup>C master communication]

(The same procedure is used in the sample program.)

- <1> Set bits 0 and 1 (PM60 and PM61) of PM6 to 1 (input mode).<sup>Note</sup>
- <2> Set up the transfer clock by using IICWL and IICWH.
- <3> Specify the local address by using SVA0.
- <4> Specify the conditions for starting I<sup>2</sup>C communication by using bit 1 (STCEN) of IICAF0.
- <5> Set bit 2 (ACKE0) of IICACTL0 to 1 (to enable acknowledge signals).
- <6> Set bit 3 (WTIM0) of IICACTL0 to 1 (to generate an interrupt request at the falling edge of the ninth clock cycle).
- <7> Specify the operating mode and operation of the digital filter by using bit 3 (SMC0) and bit 2 (DFC0) of IICACTL1, respectively.
- <8> Set bit 7 (IICE0) of IICACTL0 to 1 (to enable the  $I^2C$  bus).
- <9> Set bits 0 and 1 (POM60 and POM61) of POM6 to 1 (N-ch open-drain output (VDD withstand voltage) mode).
- <10> Set bits 0 and 1 (P60 and P61) of P6 to 1 (to output 1).
- <11> Clear bits 0 and 1 (PM60 and PM61) of PM6 to 0 (output mode).
- <12> Clear the INTIICA0 interrupt request (clear IICAIF0 to 0).
- <13> Enable the INTIICA0 interrupt (clear IICAMK0 to 0).
- Note P60/SCLA0 and P61/SDAA0 are specified as input ports so that port output does not affect the I<sup>2</sup>C bus.

# (1) IICA control register 0 (IICACTL0)

Γ

This register is used to enable/stop I<sup>2</sup>C operations, set wait timing, and set other I<sup>2</sup>C operations.

| IICE0 | LREL0                                                         | WREL0                                                                 | SPIE0                                                                                            | WTIM0                                                                                                                                                                                                                                                                                                                                                                                 | ACKE0                       | STT0                             | SPT0                             |  |  |
|-------|---------------------------------------------------------------|-----------------------------------------------------------------------|--------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|----------------------------------|----------------------------------|--|--|
|       |                                                               |                                                                       |                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                       |                             |                                  |                                  |  |  |
|       | WREL0 <sup>Note 1</sup>                                       | ı                                                                     |                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                       |                             |                                  |                                  |  |  |
|       |                                                               |                                                                       | l                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                       | Wait cancellat              | ion                              |                                  |  |  |
|       | 0                                                             |                                                                       | Do not cancel wait<br>Cancel wait. This setting is automatically cleared after wait is canceled. |                                                                                                                                                                                                                                                                                                                                                                                       |                             |                                  |                                  |  |  |
|       | · · · ·                                                       | 1                                                                     |                                                                                                  | -                                                                                                                                                                                                                                                                                                                                                                                     | -                           |                                  | in the transmission status       |  |  |
|       |                                                               |                                                                       | ,                                                                                                | •                                                                                                                                                                                                                                                                                                                                                                                     | ance state (TR              | •                                |                                  |  |  |
|       | Condition for                                                 | or clearing (W                                                        | REL0 = 0)                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                       | Condition for               | r setting (WRE                   | L0 = 1)                          |  |  |
|       | <ul><li>Automatic</li><li>Reset</li></ul>                     | ally cleared a                                                        | fter execution                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                       | Set by instr                | ruction                          |                                  |  |  |
|       | LREL0 <sup>Note 1</sup>                                       |                                                                       |                                                                                                  | Exit                                                                                                                                                                                                                                                                                                                                                                                  | from commun                 | ications                         |                                  |  |  |
|       | 0                                                             | Normal op                                                             | peration                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                       |                             |                                  |                                  |  |  |
|       | 1                                                             | automatic<br>Its uses in<br>The SCLA<br>The follow<br>cleared to      | ally cleared to<br>clude cases in<br>0 and SDAA0<br>ring flags of IIC<br>0.                      | om the current communications and sets standby mode. This setting is<br>y cleared to 0 after being executed.<br>ude cases in which a locally irrelevant extension code has been received.<br>and SDAA0 lines are set to high impedance.<br>g flags of IICA control register 0 (IICACTL0) and IICA status register 0 (IICAS0) are<br>. PT0 • MSTS0 • EXC0 • COI0 • TRC0 • ACKD0 • STD0 |                             |                                  |                                  |  |  |
|       | entry condit<br>• After a sto<br>• An addres<br>Condition for | ions are met.<br>op condition is<br>as match or ex<br>or clearing (LF | s detected, resi                                                                                 | tart is in maste                                                                                                                                                                                                                                                                                                                                                                      | r mode.<br>rs after the sta | rt condition.<br>r setting (LREL | Ilowing communications<br>0 = 1) |  |  |
|       |                                                               |                                                                       |                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                       |                             |                                  |                                  |  |  |
|       | IICE0                                                         |                                                                       |                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                       | C operation er              |                                  |                                  |  |  |
|       | 0                                                             |                                                                       |                                                                                                  | ne IICA status                                                                                                                                                                                                                                                                                                                                                                        | register 0 (IICA            | ASO) <sup>Note 2</sup> . Stop    | internal operation.              |  |  |
|       | 1<br>De euro te e                                             | Enable op                                                             |                                                                                                  | A0 and 00 A A                                                                                                                                                                                                                                                                                                                                                                         |                             | igh love!                        |                                  |  |  |
|       |                                                               |                                                                       |                                                                                                  | AU and SDAA                                                                                                                                                                                                                                                                                                                                                                           | 0 lines are at h            | -                                | ( _ 1)                           |  |  |
|       |                                                               | or clearing (IIC<br>y instruction                                     | JEO = 0)                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                       | Set by inst                 | r setting (IICE0<br>ruction      | = 1)                             |  |  |

#### Figure 4-1. Format of IICA Control Register 0 (IICACTL0) (1/4)

- **Notes 1.** The signal of this bit is invalid while IICE0 is 0.
  - 2. The IICAS0 register, the STCF and IICBSY bits of the IICAF0 register, and the CLD0 and DAD0 bits of the IICACTL1 register are reset.
- Caution The start condition is detected immediately after I<sup>2</sup>C is enabled to operate (IICE0 = 1) while the SCLA0 line is at high level and the SDAA0 line is at low level. Immediately after enabling I<sup>2</sup>C to operate (IICE0 = 1), set LREL0 (1) by using a 1-bit memory manipulation instruction.
- **Remark** The values written in red in the above figure are specified in this sample program.

| IICE0 | LREL0                                                                                                  | WREL0                                                             | SPIE0                                                                      | WTIM0                                                    | ACKE0                                              | STT0                                                  | SPT0                                                                                           |                                    |  |  |
|-------|--------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------|----------------------------------------------------------------------------|----------------------------------------------------------|----------------------------------------------------|-------------------------------------------------------|------------------------------------------------------------------------------------------------|------------------------------------|--|--|
|       |                                                                                                        |                                                                   |                                                                            |                                                          |                                                    |                                                       |                                                                                                |                                    |  |  |
|       |                                                                                                        |                                                                   |                                                                            |                                                          |                                                    |                                                       |                                                                                                |                                    |  |  |
|       | ACKE0 <sup>Notes 1, 2</sup>                                                                            |                                                                   |                                                                            | Ack                                                      | nowledgment                                        | control                                               |                                                                                                |                                    |  |  |
|       | 0                                                                                                      |                                                                   | Disable acknowledgment.                                                    |                                                          |                                                    |                                                       |                                                                                                |                                    |  |  |
|       | 1                                                                                                      | Enable ac                                                         | knowledgmen                                                                | t. During the n                                          | inth clock peri                                    | od, the SDAA0                                         | ) line is set to lo                                                                            | w level.                           |  |  |
|       | Condition for                                                                                          | r clearing (A                                                     | CKE0 = 0)                                                                  |                                                          | Condition fo                                       | r setting (ACK                                        | E0 = 1)                                                                                        |                                    |  |  |
|       | <ul><li>Cleared by</li><li>Reset</li></ul>                                                             | instruction                                                       |                                                                            |                                                          | Set by inst                                        | ruction                                               |                                                                                                |                                    |  |  |
|       | WTIM0 <sup>Note 1</sup>                                                                                |                                                                   |                                                                            | Control of wait                                          | and interrupt                                      | request genera                                        | ition                                                                                          |                                    |  |  |
|       | 0                                                                                                      | Master r                                                          | node: After ou                                                             | put of eight cloo                                        | ocks, clock ou                                     | tput is set to lo                                     | w level and wai<br>vel and wait is s                                                           |                                    |  |  |
|       | 1                                                                                                      | Master r                                                          | node: After ou                                                             | •                                                        | cks, clock out                                     | put is set to lov                                     | v level and wait<br>el and wait is s                                                           |                                    |  |  |
|       | setting of this<br>mode, a wait<br>has received                                                        | s bit. The se<br>t is inserted a<br>I a local addr<br>ued. Howeve | tting of this bir<br>at the falling e<br>ress, a wait is<br>er, when the s | t is valid when t<br>dge of the ninth<br>inserted at the | the address tra<br>clock during<br>falling edge of | ansfer is compl<br>address transfe<br>the ninth clock | fer independen<br>leted. When in<br>ers. For a slave<br>k after an ackno<br>a, a wait is inser | master<br>e device that<br>owledge |  |  |
|       | Condition for                                                                                          | r clearing (W                                                     | TIM0 = 0)                                                                  |                                                          | Condition fo                                       | r setting (WTIN                                       | /10 = 1)                                                                                       |                                    |  |  |
|       | <ul><li>Cleared by</li><li>Reset</li></ul>                                                             | instruction                                                       |                                                                            |                                                          | Set by inst                                        | ruction                                               |                                                                                                |                                    |  |  |
|       | SPIE0 <sup>Note 1</sup> Enable/disable generation of interrupt request when stop condition is detected |                                                                   |                                                                            |                                                          |                                                    |                                                       |                                                                                                |                                    |  |  |
|       | 0                                                                                                      | Disable                                                           | Disable                                                                    |                                                          |                                                    |                                                       |                                                                                                |                                    |  |  |
|       | 1                                                                                                      | Enable                                                            |                                                                            |                                                          |                                                    |                                                       |                                                                                                |                                    |  |  |
|       | Condition for                                                                                          | r clearing (SI                                                    | PIE0 = 0)                                                                  |                                                          | Condition fo                                       | r setting (SPIE                                       | 0 = 1)                                                                                         |                                    |  |  |
|       | <ul><li>Cleared by</li><li>Reset</li></ul>                                                             | instruction                                                       |                                                                            |                                                          | <ul> <li>Set by inst</li> </ul>                    | ruction                                               |                                                                                                |                                    |  |  |

### Figure 4-1. Format of IICA Control Register 0 (IICACTL0) (2/4)

Notes 1. The signal of this bit is invalid while IICE0 is 0. Set this bit during that period.

The set value is invalid during address transfer and if the code is not an extension code.
 When the device serves as a slave and the addresses match, an acknowledgment is generated regardless of the set value.

| IICE0 LRELO WRELO SPIEO WTIMO ACKEO STTO SPTO |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                |                                                        |                                                                         |                                                                          |                                                                |                                     |                |    |  |  |  |  |
|-----------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------|--------------------------------------------------------|-------------------------------------------------------------------------|--------------------------------------------------------------------------|----------------------------------------------------------------|-------------------------------------|----------------|----|--|--|--|--|
| Г                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                |                                                        |                                                                         |                                                                          |                                                                |                                     |                |    |  |  |  |  |
|                                               | STT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 0 <sup>Note</sup>                                              |                                                        |                                                                         |                                                                          | Start c                                                        | ondition trigger                    |                |    |  |  |  |  |
|                                               | (                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | C                                                              | Do no                                                  | Do not generate a start condition.                                      |                                                                          |                                                                |                                     |                |    |  |  |  |  |
|                                               | <ul> <li>When bus is released (in STOP mode):<br/>Generate a start condition (for starting as master). When the SCLA0 line is high level, the SDAA0 line is changed from high level to low level and then the start condition is generated. Next, after the rated amount of time has elapsed, SCLA0 is changed to low level (wait state).</li> <li>When a third party is communicating:         <ul> <li>When communication reservation function is enabled (IICRSV = 0)</li> <li>Functions as the start condition reservation flag. When set to 1, automatically generates a start condition after the bus is released.</li> <li>When communication reservation function is disabled (IICRSV = 1)</li> <li>STCF is set to 1 and information that is set (1) to STT0 is cleared. No start condition is generated.</li> <li>In the wait state (when master device):</li> <li>Generates a restart condition after releasing the wait.</li> </ul> </li> </ul> |                                                                |                                                        |                                                                         |                                                                          |                                                                |                                     |                |    |  |  |  |  |
|                                               | <ul> <li>F</li> <li>F</li> <li>di</li> <li>C</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | or mast<br>een clea<br>or mast<br>uring the<br>annot b         | er rece<br>ared to<br>er trans<br>e wait  <br>e set to | 0 and slave h<br>smission: A sta<br>period that follo<br>o 1 at the sam | as been notifie<br>art condition ca<br>ows output of t<br>e time as SPT( | ed of final recept<br>annot be gener<br>the ninth clock.<br>0. | ated normally                       | during the ack |    |  |  |  |  |
|                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                |                                                        | g (STT0 = 0)                                                            |                                                                          | 1                                                              | Condition for se                    |                | 1) |  |  |  |  |
|                                               | rese<br>• Clea<br>• Clea<br>devi<br>• Clea                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | ervation<br>ared by<br>ared afte<br>ice<br>ared by<br>en IICE( | is prof<br>loss in<br>er start<br>LRELC                | nibited.<br>arbitration<br>condition is g                               | ile communica<br>enerated by ma<br>communicatic                          | aster                                                          | <ul> <li>Set by instruct</li> </ul> | tion           |    |  |  |  |  |

# Figure 4-1. Format of IICA Control Register 0 (IICACTL0) (3/4)

٦

Note The signal of this bit is invalid while IICE0 is 0.

Remarks 1. Bit 1 (STT0) becomes 0 when it is read after data setting.

2. IICRSV: Bit 0 of IICA flag register 0 (IICAF0) STCF: Bit 7 of IICA flag register 0 (IICAF0)

| ICE0 LREL0 WREL0 SPIE0                                                                                                                                                                                           |                                                            |                                        |                                                                                                                                                                                                                                                                                                                                             |                                                                      |                                                                           | WTIM0                                                                  | ACKE0                                                                         | STT0                            | SPT0         |        |  |  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------|----------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------|---------------------------------------------------------------------------|------------------------------------------------------------------------|-------------------------------------------------------------------------------|---------------------------------|--------------|--------|--|--|
|                                                                                                                                                                                                                  |                                                            |                                        |                                                                                                                                                                                                                                                                                                                                             |                                                                      |                                                                           |                                                                        |                                                                               |                                 |              |        |  |  |
| SPT0 Stop condition trigger                                                                                                                                                                                      |                                                            |                                        |                                                                                                                                                                                                                                                                                                                                             |                                                                      |                                                                           |                                                                        |                                                                               |                                 |              |        |  |  |
|                                                                                                                                                                                                                  | 0                                                          |                                        | Do not generate a stop condition.                                                                                                                                                                                                                                                                                                           |                                                                      |                                                                           |                                                                        |                                                                               |                                 |              |        |  |  |
|                                                                                                                                                                                                                  | 1                                                          |                                        | Generate a stop condition (termination of master device's transfer).<br>After the SDAA0 line goes to low level, either set the SCLA0 line to high level or wait until it goes to high<br>level. Next, after the rated amount of time has elapsed, the SDAA0 line changes from low level to high<br>level and a stop condition is generated. |                                                                      |                                                                           |                                                                        |                                                                               |                                 |              |        |  |  |
| <ul> <li>Cautions concerning set timing</li> <li>For master reception: Cannot be set to 1 during transfer.<br/>Can be set to 1 only in the wait period when ACKE0 has been cleared to 0 and slave has</li> </ul> |                                                            |                                        |                                                                                                                                                                                                                                                                                                                                             |                                                                      |                                                                           |                                                                        |                                                                               |                                 |              |        |  |  |
|                                                                                                                                                                                                                  |                                                            |                                        |                                                                                                                                                                                                                                                                                                                                             | smission: A sto                                                      | refore, set it du                                                         | innot be gener<br>iring the wait p                                     | rated normally period that follo                                              | 0                               | 0 1          | od.    |  |  |
|                                                                                                                                                                                                                  | <ul> <li>W</li> <li>no</li> <li>ch</li> <li>the</li> </ul> | hen WT<br>te that<br>anged<br>e wait p | TIM0 h<br>a stop<br>from 0<br>period t                                                                                                                                                                                                                                                                                                      | condition will to<br>to 1 during the<br>that follows the             | ed to 0, if SPTC<br>be generated c<br>e wait period fo<br>e output of the | ) is set to 1 du<br>luring the high<br>ollowing the ou<br>ninth clock. | ring the wait pe<br>-level period of<br>tput of eight clo<br>red to 0 is proh | the ninth cloc<br>ocks, and SPT | k. WTIM0 sho | uld be |  |  |
| (                                                                                                                                                                                                                | Condit                                                     | ion for                                | clearin                                                                                                                                                                                                                                                                                                                                     | g (SPT0 = 0)                                                         |                                                                           |                                                                        | Condition for se                                                              | etting (SPT0 =                  | 1)           |        |  |  |
|                                                                                                                                                                                                                  | <ul><li>Autor</li><li>Clear</li></ul>                      | matical<br>red by I<br>n IICE0         | ly clea<br>_REL0                                                                                                                                                                                                                                                                                                                            | arbitration<br>red after stop o<br>= 1 (exit from<br>operation stop) | communicatio                                                              | <ul> <li>Set by instruct</li> </ul>                                    | tion                                                                          |                                 |              |        |  |  |

#### Figure 4-1. Format of IICA Control Register 0 (IICACTL0) (4/4)

**Note** Set SPT0 to 1 only in master mode. However, SPT0 must be set to 1 and a stop condition generated before the first stop condition is detected following the switch to the operation enabled status.

# Caution When bit 3 (TRC0) of the IICA status register 0 (IICAS0) is set to 1, WREL0 is set to 1 during the ninth clock and wait is canceled, after which TRC0 is cleared and the SDAA0 line is set to high impedance.

Remark Bit 0 (SPT0) becomes 0 when it is read after data setting.

### (2) IICA flag register 0 (IICAF0)

This register sets the operating mode of I<sup>2</sup>C and indicates the status of the I<sup>2</sup>C bus.

| STCF <sup>Note</sup> | IICBSY <sup>Note</sup>                                         | 0                                     | 0                                                                                                      | 0              | 0                                                                                                                                                  | STCEN              | IICRSV                        |  |  |  |  |
|----------------------|----------------------------------------------------------------|---------------------------------------|--------------------------------------------------------------------------------------------------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|-------------------------------|--|--|--|--|
|                      |                                                                |                                       | L                                                                                                      | 1              |                                                                                                                                                    |                    |                               |  |  |  |  |
|                      | <b></b>                                                        |                                       |                                                                                                        |                |                                                                                                                                                    |                    |                               |  |  |  |  |
|                      | licrsv                                                         |                                       | Communication reservation function disable bit                                                         |                |                                                                                                                                                    |                    |                               |  |  |  |  |
|                      | 0                                                              | Enable co                             | mmunication r                                                                                          | eservation     |                                                                                                                                                    |                    |                               |  |  |  |  |
|                      | 1                                                              | Disable co                            | mmunication i                                                                                          | reservation    |                                                                                                                                                    |                    |                               |  |  |  |  |
|                      | Condition for                                                  | clearing (IIC                         | CRSV = 0)                                                                                              |                | Condition                                                                                                                                          | for setting (IIC   | RSV = 1)                      |  |  |  |  |
|                      | <ul><li>Cleared by</li><li>Reset</li></ul>                     | instruction                           |                                                                                                        |                | Set by in                                                                                                                                          | nstruction         |                               |  |  |  |  |
|                      | STCEN                                                          |                                       |                                                                                                        | Ir             | itial start enab                                                                                                                                   | le trigger         |                               |  |  |  |  |
|                      | 0                                                              | After oper<br>stop cond               |                                                                                                        | d (IICE0 = 1), | enable genera                                                                                                                                      | ation of a start o | condition upon detection of a |  |  |  |  |
|                      | 1                                                              |                                       | After operation is enabled (IICE0 = 1), enable generation of a start condition without stop condition. |                |                                                                                                                                                    |                    |                               |  |  |  |  |
|                      | Condition for                                                  | <sup>r</sup> clearing (S <sup>-</sup> | TCEN = 0)                                                                                              |                | Condition for setting (STCEN = 1)                                                                                                                  |                    |                               |  |  |  |  |
|                      | <ul><li>Cleared by</li><li>Detection c</li><li>Reset</li></ul> |                                       | tion                                                                                                   |                | Set by instruction                                                                                                                                 |                    |                               |  |  |  |  |
|                      | IICBSY                                                         |                                       | I <sup>2</sup> C bus status flag                                                                       |                |                                                                                                                                                    |                    |                               |  |  |  |  |
|                      | 0                                                              | Bus releas                            | se status (com                                                                                         | munication ini | tial status whe                                                                                                                                    | n STCEN = 1)       |                               |  |  |  |  |
|                      | 1                                                              | Bus comn                              | nunication state                                                                                       | us (communic   | ation initial sta                                                                                                                                  | tus when STCE      | EN = 0)                       |  |  |  |  |
|                      | Condition for                                                  | <sup>r</sup> clearing (IIC            | CBSY = 0)                                                                                              |                | Condition                                                                                                                                          | for setting (IIC   | BSY = 1)                      |  |  |  |  |
|                      | <ul><li>Detection c</li><li>When IICE</li><li>Reset</li></ul>  | •                                     |                                                                                                        |                | <ul> <li>Detection of start condition</li> <li>Setting of IICE0 when STCEN = 0</li> </ul>                                                          |                    |                               |  |  |  |  |
|                      | STCF                                                           |                                       |                                                                                                        |                | STT0 clear                                                                                                                                         | flag               |                               |  |  |  |  |
| L                    | 0                                                              | Generate                              | start condition                                                                                        |                | 0110000                                                                                                                                            |                    |                               |  |  |  |  |
|                      | 1                                                              |                                       | lition generatio                                                                                       | n unsuccessfu  | ul: clear STT0                                                                                                                                     | ear STT0 flag      |                               |  |  |  |  |
|                      | Condition for                                                  |                                       | •                                                                                                      |                |                                                                                                                                                    | for setting (ST    | CF = 1)                       |  |  |  |  |
|                      | Cleared by     When IICE     Reset                             | STT0 = 1                              |                                                                                                        |                | <ul> <li>Generating start condition unsuccessful and STT0<br/>cleared to 0 when communication reservation is<br/>disabled (IICRSV = 1).</li> </ul> |                    |                               |  |  |  |  |

#### Figure 4-2. Format of IICA Flag Register 0 (IICAF0)

**Note** Bits 7 and 6 are read-only.

Cautions 1. Write to STCEN only when the operation is stopped (IICE0 = 0).

- As the bus release status (IICBSY = 0) is recognized regardless of the actual bus status when STCEN = 1, when generating the first start condition (STT0 = 1), it is necessary to verify that no third party communications are in progress in order to prevent such communications from being destroyed.
- 3. Write to IICRSV only when the operation is stopped (IICE0 = 0).
- 4. Be sure to clear bits 5 to 2 to "0".
- Remarks 1. STT0: Bit 1 of IICA control register 0 (IICACTL0)

IICE0: Bit 7 of IICA control register 0 (IICACTL0)

2. The values written in red in the above figure are specified in this sample program.

# (3) IICA control register 1 (IICACTL1)

This register is used to set the operating mode of I<sup>2</sup>C and detect the statuses of the SCLA0 and SDAA0 pins.

| WUP | 0                                                                                                                                                                                                                                                                                                                                                                                  | CLD0 <sup>Note 1</sup> | DAD0 <sup>Note 1</sup>                                                                                                                                                                                                      | SMC0            | DFC0                         | 0                                                       | 0                                 | 1        |  |  |  |
|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------------------------------|---------------------------------------------------------|-----------------------------------|----------|--|--|--|
|     | -                                                                                                                                                                                                                                                                                                                                                                                  |                        |                                                                                                                                                                                                                             |                 |                              | -                                                       | -                                 | ]        |  |  |  |
|     |                                                                                                                                                                                                                                                                                                                                                                                    |                        |                                                                                                                                                                                                                             |                 |                              |                                                         |                                   |          |  |  |  |
|     |                                                                                                                                                                                                                                                                                                                                                                                    |                        |                                                                                                                                                                                                                             |                 |                              |                                                         |                                   |          |  |  |  |
|     | DFC0                                                                                                                                                                                                                                                                                                                                                                               |                        | Digital filter operation control                                                                                                                                                                                            |                 |                              |                                                         |                                   |          |  |  |  |
|     | 0                                                                                                                                                                                                                                                                                                                                                                                  | Digital f              | ilter off                                                                                                                                                                                                                   | 9.              |                              |                                                         |                                   |          |  |  |  |
|     | 1                                                                                                                                                                                                                                                                                                                                                                                  |                        | Digital filter off Digital filter on                                                                                                                                                                                        |                 |                              |                                                         |                                   |          |  |  |  |
|     | Digital filter                                                                                                                                                                                                                                                                                                                                                                     | can be use             | ed only in fast r                                                                                                                                                                                                           | node.           |                              |                                                         |                                   |          |  |  |  |
|     |                                                                                                                                                                                                                                                                                                                                                                                    |                        |                                                                                                                                                                                                                             |                 |                              | FC0 bit being                                           | set (1) or clear                  | red (0). |  |  |  |
|     | The digital                                                                                                                                                                                                                                                                                                                                                                        | filter is used         | d for noise elim                                                                                                                                                                                                            | ination in fast | mode.                        |                                                         |                                   |          |  |  |  |
|     | SMC0                                                                                                                                                                                                                                                                                                                                                                               |                        |                                                                                                                                                                                                                             | Op              | erating mode s               | witching                                                |                                   |          |  |  |  |
|     | 0                                                                                                                                                                                                                                                                                                                                                                                  | Operate                | es in standard i                                                                                                                                                                                                            | mode.           |                              |                                                         |                                   |          |  |  |  |
|     | 1                                                                                                                                                                                                                                                                                                                                                                                  | Operate                | es in fast mode                                                                                                                                                                                                             |                 |                              |                                                         |                                   |          |  |  |  |
|     | D 4 D 4                                                                                                                                                                                                                                                                                                                                                                            |                        |                                                                                                                                                                                                                             |                 |                              |                                                         |                                   |          |  |  |  |
|     | DADO                                                                                                                                                                                                                                                                                                                                                                               | The 07                 |                                                                                                                                                                                                                             |                 | 0 pin level (val             | lid only when                                           | IICE0 = 1)                        |          |  |  |  |
|     | 0                                                                                                                                                                                                                                                                                                                                                                                  |                        | AA0 pin was d                                                                                                                                                                                                               |                 |                              |                                                         |                                   |          |  |  |  |
|     | Condition f                                                                                                                                                                                                                                                                                                                                                                        |                        | AA0 pin was d                                                                                                                                                                                                               | elected at higi |                              | for setting (D                                          | AD0 – 1)                          |          |  |  |  |
|     |                                                                                                                                                                                                                                                                                                                                                                                    |                        | n is at low level                                                                                                                                                                                                           | 1               |                              | 0.                                                      | ,                                 |          |  |  |  |
|     |                                                                                                                                                                                                                                                                                                                                                                                    |                        | eration stop)                                                                                                                                                                                                               | <u>.</u>        |                              | <ul> <li>When the SDAA0 pin is at high level</li> </ul> |                                   |          |  |  |  |
|     | <ul> <li>Reset</li> </ul>                                                                                                                                                                                                                                                                                                                                                          |                        |                                                                                                                                                                                                                             |                 |                              |                                                         |                                   |          |  |  |  |
|     | CLD0                                                                                                                                                                                                                                                                                                                                                                               |                        | Detection of SCLA0 pin level (valid only when $IICE0 = 1$ )                                                                                                                                                                 |                 |                              |                                                         |                                   |          |  |  |  |
|     | 0                                                                                                                                                                                                                                                                                                                                                                                  | The SC                 | The SCLA0 pin was detected at low level.                                                                                                                                                                                    |                 |                              |                                                         |                                   |          |  |  |  |
|     | 1                                                                                                                                                                                                                                                                                                                                                                                  | The SC                 | LA0 pin was d                                                                                                                                                                                                               | etected at high | ı level.                     |                                                         |                                   |          |  |  |  |
|     | Condition f                                                                                                                                                                                                                                                                                                                                                                        | or clearing (          | (CLD0 = 0)                                                                                                                                                                                                                  |                 | Condition                    | for setting (C                                          | LD0 = 1)                          |          |  |  |  |
|     |                                                                                                                                                                                                                                                                                                                                                                                    |                        | is at low level                                                                                                                                                                                                             |                 | <ul> <li>When the</li> </ul> | When the SCLA0 pin is at high level                     |                                   |          |  |  |  |
|     | When IIC     Reset                                                                                                                                                                                                                                                                                                                                                                 | E0 = 0 (ope            | eration stop)                                                                                                                                                                                                               |                 |                              |                                                         |                                   |          |  |  |  |
|     |                                                                                                                                                                                                                                                                                                                                                                                    |                        |                                                                                                                                                                                                                             |                 |                              |                                                         |                                   |          |  |  |  |
|     | WUP                                                                                                                                                                                                                                                                                                                                                                                |                        |                                                                                                                                                                                                                             | Contro          | l of address ma              | atch wakeup                                             |                                   |          |  |  |  |
|     | 0                                                                                                                                                                                                                                                                                                                                                                                  | Stops o                | peration of add                                                                                                                                                                                                             | dress match w   | akeup function               | in STOP mo                                              | de.                               |          |  |  |  |
|     | 1                                                                                                                                                                                                                                                                                                                                                                                  | Enables                | s operation of a                                                                                                                                                                                                            | address match   | wakeup function              | on in STOP n                                            | node.                             |          |  |  |  |
|     | communica                                                                                                                                                                                                                                                                                                                                                                          | ation can be           | entered by cle                                                                                                                                                                                                              | earing (0) WU   |                              |                                                         | eceived. The s<br>ed and transmit | -        |  |  |  |
|     | be written after WUP has been cleared (0).)<br>The interrupt timing when the address has matched or when an extension code has been received, while<br>WUP = 1, is identical to the interrupt timing when WUP = 0. (A delay of the difference of sampling by the<br>clock will occur.) Furthermore, when WUP = 1, a stop condition interrupt is not generated even if the SPIEC    |                        |                                                                                                                                                                                                                             |                 |                              |                                                         |                                   |          |  |  |  |
|     | bit is set to 1.<br>When WUP = 0 is set by a source other than an interrupt from serial interface IICA, operation as the master device cannot be performed until the subsequent start condition or stop condition is detected. Do not output a start condition by setting (1) the STT0 bit, without waiting for the detection of the subsequent start condition or stop condition. |                        |                                                                                                                                                                                                                             |                 |                              |                                                         |                                   |          |  |  |  |
|     | Condition f                                                                                                                                                                                                                                                                                                                                                                        | or clearing            | (WUP = 0)                                                                                                                                                                                                                   |                 | Condition                    | for setting (W                                          | /UP = 1)                          |          |  |  |  |
|     |                                                                                                                                                                                                                                                                                                                                                                                    | •                      | r clearing (WUP = 0)       Condition for setting (WUP = 1)         / instruction (after address match or code reception)       • Set by instruction (when MSTS0 are "0", and STD0 also "0" (com entered)) <sup>Note 2</sup> |                 |                              |                                                         |                                   |          |  |  |  |

Figure 4-3. Format of IICA Control Register 1 (IICACTL1)

Notes 1. Bits 5 and 4 are read-only.

2. The status of IICAS0 must be checked and WUP must be set during the period shown below.



### Caution Be sure to clear bits 6, 1, and 0 to "0".

Remarks 1. IICE0: Bit 7 of IICA control register 0 (IICACTL0)

2. The values written in red in the above figure are specified in this sample program.

#### (4) IICA low-level width setting register (IICWL), IICA high-level width setting register (IICWH)

The IICA low-level width setting register (IICWL) is used to set the low-level width (tLow) of the SCLA0 pin signal that is output by serial interface IICA being in master mode.

The IICA high-level width setting register (IICWH) is used to set the high-level width (thigh) of the SCLA0 pin signal that is output by serial interface IICA being in master mode.





Figure 4-5. Format of IICA High-Level Width Setting Register (IICWH)



The master transfer clock is set up as follows by using the IICWL and IICWH registers:

| Transfer clock = | IICWL + IICWH + fprs (tr + tr) |
|------------------|--------------------------------|
|                  | fprs                           |

The ideal values for IICWL and IICWH are shown below. (The values are rounded to the nearest integer.)

• Fast mode

$$IICWL = \frac{0.52}{Transfer clock} \times f_{PRS}$$

IICWH = 
$$(\frac{0.48}{\text{Transfer clock}} - \text{tr} - \text{tr}) \times \text{fprs}$$

Standard mode

$$IICWL = \frac{0.47}{Transfer clock} \times f_{PRS}$$

$$IICWH = (\frac{0.53}{Transfer clock} - t_R - t_F) \times f_{PRS}$$

Caution The transfer clock frequency range that can be specified varies depending on the operating mode. Standard mode: 0 to 100 kHz Fast mode: 0 to 400 kHz

- Remarks 1. tF: Falling time of the SDAA0 and SCLA0 signals
  - tR: Rising time of the SDAA0 and SCLA0 signals (For details about tr and tr, see the electrical specifications in the <u>78K0/Kx2-L User's Manual</u>.)
     fPRs: Peripheral hardware clock frequency
  - 2. In this sample program, IICWL is set to 11 and IICWH is set to 8.

#### (5) Port output mode register 6 (POM6)

This register sets the output mode of P60 and P61 in 1-bit units. During  $I^2C$  communication, set SCLA0/P60 and SDAA0/P61 to N-ch open drain output (VDD tolerance) mode.



#### Figure 4-6. Format of Port Output Mode Register 6 (POM6)

Note 78K0/KC2-L only

# Caution Be sure to clear the following bits to 0:

78K0/KY2-L, 78K0/KA2-L, 78K0/KB2-L: Bits 7 to 2 78K0/KC2-L: Bits 7 to 4

#### (6) Port register 6 (P6)

This register writes the data to be output from the chip if port 6 is specified to output data. If using the P60/SCLA0 pin as a clock signal I/O pin and the P61/SDAA0 pin as a serial data I/O pin, set the P60 and P61 output latches to 1.

| Figure 4-7. | Format of Port | Register 6 (P6) |
|-------------|----------------|-----------------|
|-------------|----------------|-----------------|

| 0 | 0 | ( | C    | 0                  | P63 <sup>Note</sup> | P62 <sup>Note</sup> | P61                             | P60             |             |
|---|---|---|------|--------------------|---------------------|---------------------|---------------------------------|-----------------|-------------|
|   |   |   |      |                    |                     |                     |                                 |                 | -           |
|   |   |   |      |                    |                     |                     |                                 | J               |             |
|   |   |   | P61  | , 60               | Output data cont    | rol (in output m    | ode) Inpu                       | t data read (in | input mode) |
|   |   |   |      | 0 Output 0.        |                     | Input lo            | w level.                        |                 |             |
|   |   |   |      | 1                  | Output 1.           |                     | Input hi                        | gh level.       |             |
|   |   |   |      |                    |                     |                     |                                 |                 |             |
|   |   |   | P63, | 62 <sup>Note</sup> | Output data cont    | ode) Inpu           | Input data read (in input mode) |                 |             |
|   |   |   | 0    |                    | Output 0.           | Input lo            | w level.                        |                 |             |
|   |   |   |      | 1                  | Output 1.           |                     | Input hi                        | gh level.       |             |

Note 78K0/KC2-L only

Caution Be sure to clear the following bits to 0: 78K0/KY2-L, 78K0/KA2-L, 78K0/KB2-L: Bits 7 to 2 78K0/KC2-L: Bits 7 to 4

# (7) Port mode register 6 (PM6)

This register sets the input/output of port 6 in 1-bit units.

If using the P60/SCLA0 pin as a clock signal I/O pin and the P61/SDAA0 pin as a serial data I/O pin, clear PM60 and PM61 to 0.

Set IICE0 (bit 7 of IICA control register 0 (IICACTL0)) to 1 before setting the output mode because the P60/SCLA0 and P61/SDAA0 pins output a low level (fixed) when IICE0 is 0.

Figure 4-8. Format of Port Mode Register 6 (PM6)



Note 78K0/KC2-L only

```
Caution Be sure to set the following bits to 1:
78K0/KY2-L, 78K0/KA2-L, 78K0/KB2-L: Bits 7 to 2
78K0/KC2-L: Bits 7 to 4
```

# 4.2 Software Coding Example

The initialization of serial interface IICA, master transmission, and master reception performed by the 78K0/KC2-L source program are shown below as a software coding example.

#### (1) Assembly language

<1> Initializing serial interface IICA (common to master transmission and master reception)





RET



#### (2) C language

<1> Initializing serial interface IICA (common to master transmission and master reception)











# CHAPTER 5 RELATED DOCUMENTS

The related documents indicated in this publication may include preliminary versions. However, preliminary versions are not marked as such.

| Document Name                           |                                                               |           | English    |
|-----------------------------------------|---------------------------------------------------------------|-----------|------------|
| 78K0/Kx2-L User's Manual                |                                                               |           | <u>PDF</u> |
| 78K/0 Series Instructions User's Manual |                                                               |           | <u>PDF</u> |
|                                         |                                                               | Language  | <u>PDF</u> |
|                                         |                                                               | Operation | <u>PDF</u> |
|                                         |                                                               | Language  | <u>PDF</u> |
|                                         |                                                               | Operation | <u>PDF</u> |
| PM+ Project Manager User's Manual       |                                                               |           | <u>PDF</u> |
| 78K0/Kx2-L<br>Application Note          | Sample Program (Initial Settings) LED Lighting Switch Control |           | PDF        |

#### APPENDIX A PROGRAM LIST

As a program list example, the 78K0/KC2-L microcontroller source program is shown below.

```
    main.asm (assembly language version)

 ;
     NEC Electronics 78K0/KC2-L Series
 ;
 78K0/KC2-L Series Sample Program (Serial Interface IICA)
 Master Communication
 ;<<History>>
     2009.1.--
               Release
 ;
 ;<<Overview>>
 ; This sample program presents an example of using serial interface IICA.
 ; 16 bytes of data are transmitted and received via the I2C bus in master operation.
 ; Communication starts at intervals of about 5 ms, alternating between transmission
 ; and reception.
 ;
 ;
 ; <Primary initial settings>
 :
 ; (Option byte settings)
 ; - Allowing the internal low-speed oscillator to be programmed to stop
 ; - Disabling the watchdog timer
 ; - Setting the internal high-speed oscillation clock frequency to 8 MHz
 ; - Disabling LVI from being started by default
 ; (Settings during initialization immediately after a reset ends)
 ; - Specifying the ROM and RAM sizes
 ; - Setting up I/O ports
 ; - Checking whether VDD is 2.7 V or more by using the low-voltage detector
 ; - Specifying that the CPU clock and peripheral hardware clock run on the internal
     high-speed oscillation clock (8 MHz)
 ; - Disabling peripheral hardware not to be used
 ; - Setting up serial interface IICA
     \rightarrow Specifying fast mode as the operating mode and setting the transfer clock
 ;
frequency to 400 kHz
     \rightarrow Specifying 50H as the local address
 ;
 ;
     \rightarrow Specifying that P60/SCLA0 and P61/SDAA0 are used for the I2C bus
     \rightarrow Enabling the INTIICA0 interrupt
 ;
```

```
; - Specifying that 8-bit timer H1 runs in intervals of about 5 ms to trigger I2C
```

communication

```
;
;
; <Communication format>
;
   [Transmission] ST + ADR/W + DT*16 + SP
;
   [Reception]
              ST + ADR/R + DT*16 + SP
;
;
    ST
       : Start condition
;
    SP : Stop condition
;
    ADR/W : Slave address + W
;
    ADR/R : Slave address + R
;
    DT : Data
;
:
;
; <Address and data>
;
  Slave address
                : A0H
;
  Transmission data : 16 bytes (00H, 01H, 02H, ... 0DH, 0EH, 0FH)
;
   Reception data : 16 bytes (any)
;
;
;
; <I/O port settings>
; Output: P60, P61
 * Set all unused ports that can be specified as output ports as output ports.
;
;_____
;
   Vector table
;
;
XVECT1
              CSEG AT
                        0000H
   DW
         RESET_START
                        ;0000H RESET input, POC, LVI, WDT
XVECT2
             CSEG AT
                      0004H
         IINIT
                        ;0004H INTLVI
   DW
   DW
         IINIT
                         ;0006H INTP0
   DW
         IINIT
                        ;0008H INTP1
                         ;000AH INTP2
    DW
         IINIT
                         ;000CH INTP3
    DW
         IINIT
                        ;000EH INTP4
    DW
         IINIT
                        ;0010H INTP5
    DW
         IINIT
                         ;0012H INTSRE6
    DW
         IINIT
         IINIT
                        ;0014H INTSR6
    DW
   DW
         IINIT
                        ;0016H INTST6
   DW
         IINIT
                         ;0018H INTCSI10
```

```
;001AH INTTMH1
     DW
          IINIT
                          ;001CH INTTMH0
     DW
          IINIT
     DW
          IINIT
                          ;001EH INTTM50
                          ;0020H INTTM000
     DW
          IINIT
          IINIT
                          ;0022H INTTM010
     DW
                          ;0024H INTAD
          IINIT
     DW
          IINIT
                          ;0026H INTP6
     DW
     DW
          IINIT
                          ;0028H INTRTCI
                          ;002AH INTTM51
     DW
          IINIT
          IINIT
                          ;002CH INTKR
     DW
     DW
          IINIT
                          ;002EH INTRTC
          IINIT
                          ;0030H INTP7
     DW
          IINIT
                          ;0032H INTP8
     DW
                          ;0034H INTIICA0
     DW
          IINIT
     DW
          IINIT
                          ;0036H INTCSI11
          IINIT
                          ;0038H INTP9
     DW
                          ;003AH INTP10
          IINIT
     DW
     DW
          IINIT
                          ;003CH INTP11
     DW
          IINIT
                          ;003EH BRK
 ;
     Define the ROM data table
 ;
 XTBL CSEG AT
               0200H
 ; Transmission data table (16 bytes)
 TTXDATA:
               00H,01H,02H,03H,04H,05H,06H,07H,08H,09H,0AH,0BH,0CH,0DH,0EH,0FH
         DB
 TTXDATAE:
                          ; Last address of the transmission data table + 1
 ;
     Define variables and constants
 DRAM DSEG
         SADDRP
 RRXBUF:
               DS
                    16
                               ; Reception data save area (16 bytes)
  CDATANUM
         EQU
               16
                          ; Number of data units (common to transmission and
reception)
 RTRSMOD:
          DS
               1
                         ; Next operation
  CTXMOD
               EQU
                    0
                               ; Transmission
  CRXMOD
               EQU
                    1
                               ; Reception
 CSLVADR
               EQU
                    0A0H
                              ; Slave address
 CRESTRT
               EQU
                    3
                               ; Number of restarts if no acknowledge signal is
detected
```

Define the memory stack area ; ; DSTK DSEG IHRAM STACKEND: DS 20H ; Memory stack area = 32 bytes ; Start address of the memory stack area STACKTOP: ; ; Servicing interrupts by using unnecessary interrupt sources XMATN CSEG UNIT IINIT: ; If an unnecessary interrupt occurred, the processing branches to this line. The processing then returns to the initial original processing because no ; processing is performed here. RETI ; Initialization after RESET ; RESET\_START: ;------; Disable interrupts DI ; Disable interrupts Set up the register bank ;------SEL RBO ; Set up the register bank ;------: Specify the ROM and RAM sizes ;-----Note that the values to specify vary depending on the model. Enable the settings for the model to use. (The uPD78F0588 is the default model.) ; Setting when using uPD78F0581 or uPD78F0586

;MOV IMS, #042H ; Specify the ROM and RAM sizes ; Setting when using uPD78F0582 or uPD78F0587 ; MOV IMS, #004H ; Specify the ROM and RAM sizes ; Setting when using uPD78F0583 or uPD78F0588 IMS, #0C8H ; Specify the ROM and RAM sizes MOV ;------Initialize the stack pointer ;-----MOVW SP, #STACKTOP ; Initialize the stack pointer Initialize port 0 ;------#0000000B ; Set the P00 to P02 output latches to low level MOV P0, MOV PMO, #11111000B ; Specify P00 to P02 as output ports ; POO to PO2: Unused ;-----Initialize port 1 ;------ADPC1, #00000111B ; Specify P10 to P12 as digital I/O ports MOV MOV P1, #0000000B ; Set the P10 to P17 output latches to low level MOV PM1, #0000000B ; Specify P10 to P17 as output ports ; P10 to P17: Unused ; Initialize port 2 ;-----MOV ADPCO, #11111111B ; Specify P20 to P27 as digital I/O ports MOV P2, #0000000B ; Set the P20 to P27 output latches to low level РМ2, #0000000В ; Specify P20 to P27 as output ports MOV ; P20 to P27: Unused Initialize port 3 ;------MOV P3, #0000000B ; Set the P30 to P33 output latches to low level MOV PM3, #11110000B ; Specify P30 to P33 as output ports ; P30 to P33: Unused Initialize port 4 ;-----P4, #0000000B ; Set the P40 to P42 output latches to low level MOV ; Specify P40 to P42 as output ports MOV PM4, #11111000B

; P40 to P42: Unused ;-------Initialize port 6 ;-----MOV PM6, #11110011B ; Specify P60 and P61 as input ports (to prevent the I2C bus from being affected) ; Specify P62 and P63 as output ports ; Set the P60 to P63 output latches to low level MOV Ρб, #00000000B ; P60: Use as SCLA0 ; P61: Use as SDAA0 ; P62 and P63: Unused \_\_\_\_\_ Initialize port 7 ;------#00000000B ; Set the P70 to P75 output latches to low level MOV Ρ7, MOV PM7, #11000000B ; Specify P70 to P75 as output ports ; P70 to P75: Unused ;------Initialize port 12 ;------MOV P12, #0000000B ; Set the P120 output latch to low level MOV PM12, #11111110B ; Specify P120 as an output port ; P120 to P125: Unused ;------Low-voltage detection ;------The low-voltage detector is used to check whether VDD is 2.7 V or more. ;------; Set up the low-voltage detector SET1 LVIMK ; Disable the INTLVI interrupt CLR1 LVISEL ; Specify VDD as the detection voltage MOV LVIS, #00001001B ; Set the low-voltage detection level (VLVI) to 2.84 ±0.1 V CLR1 LVIMD ; Specify that an interrupt signal is generated when a low voltage is detected SET1 LVION ; Enable low-voltage detection ; Make the system wait until the low-voltage detector stabilizes (10 us or more) MOV в, #5 ; Specify the number of counts HINI100: NOP DBNZ B, \$HINI100 ; Has the wait period ended? No, ; Make the system wait until VLVI is less than or equal to VDD

```
HINI110:
     NOP
     ВT
          LVIF, $HINI110
                         ; VDD < VLVI? Yes,
     CLR1
          LVION
                          ; Stop the low-voltage detector
 Specify the clock frequency
 ;------
     Specify the clock frequency so that the device can run on the internal high-speed
oscillation clock.
 ;------
          OSCCTL, #0000000B ; Clock operation mode
     MOV
                 ||||+||+----- Be sure to clear this bit to 0
 ;
                 |||| ++----- RSWOSC/AMPHXT
 ;
 ;
                 [XT1 oscillator oscillation mode selection]
                 00: Low power consumption oscillation
 ;
                 01: Normal oscillation
 ;
                 1x: Ultra-low power consumption oscillation
                 | | ++----- EXCLKS/OSCSELS
 ;
                            [Subsystem clock pin operation setting]
                 :
                 (P123/XT1,P124/XT2/EXCLKS)
 ;
                 Specify the use of the pin as an I/O port pin by
specifying 000 by also using XTSTART
                 ++---- EXCLK/OSCSEL
 ;
 ;
                            [High-speed system clock pin operation setting]
                            (P121/X1,P122/X2/EXCLK)
 ;
                             00: Input port
 ;
                             01: X1 oscillation mode
 ;
                             10: Input port
 ;
 ;
                             11: External clock input mode
                          ; Select the CPU clock (fCPU)
     MOV
          PCC,
                #0000000B
 ;
                |||+|+++----- CSS/PCC2/PCC1/PCC0
                [CPU clock (fCPU) selection]
 :
                             0000:fXP
                ;
                0001:fXP/2
                             0010:fXP/2^2
                :
                             0011:fXP/2^3
                :
                 0100:fXP/2^4
                1000:fSUB/2
 :
                            1001:fSUB/2
 ;
                1010:fSUB/2
                1011:fSUB/2
                1100:fSUB/2
 ;
                (Other than the above: Setting prohibited)
                ||| +----- Be sure to clear this bit to 0
                ||+----- CLS
 ;
 ;
                [CPU clock status]
```

| ;      |     |      | + XTSTART                                                                                                                |
|--------|-----|------|--------------------------------------------------------------------------------------------------------------------------|
| ;      |     |      | [Subsystem clock pin operation setting]                                                                                  |
| ;      |     |      | Specify the use of the pin by also using EXCLKS and                                                                      |
| OSCSE: | LS. |      |                                                                                                                          |
| ;      |     |      | + Be sure to clear this bit to 0                                                                                         |
| ;      | MOV | RCM, | #0000000B ; Select the operating mode of the internal oscillator                                                         |
| ;<br>; |     |      | [Internal high-speed oscillator oscillating/stopped]                       0: Internal high-speed oscillator oscillating |
| ;<br>; |     |      | <pre>        1: Internal high-speed oscillator stopped       + LSRSTOP</pre>                                             |
| ;<br>; |     |      | [Internal low-speed oscillator oscillating/stopped]                      0: Internal low-speed oscillator oscillating    |
| ;<br>; |     |      | <pre>       1: Internal low-speed oscillator stopped  +++++ Be sure to clear this bit to 0</pre>                         |
| ;<br>; |     |      | + RSTS<br>[Status of internal high-speed oscillator]                                                                     |
| clock  | MOV | MOC, | #10000000B ; Select the operating mode of the high-speed system                                                          |
|        |     |      | ++++++ Be sure to clear this bit to 0                                                                                    |
| ;<br>; |     |      | + MSTOP                                                                                                                  |
| ;      |     |      | [Control of high-speed system clock operation]                                                                           |
| ;      |     |      | 0: X1 oscillator operating/external clock from                                                                           |
| ;      |     |      | EXCLK pin is enabled                                                                                                     |
| ;      |     |      | 1: X1 oscillator stopped/external clock from                                                                             |
| ;      |     |      | EXCLK pin is disabled                                                                                                    |
| ;      | MOV | MCM, | #0000000B ; Select the clock to supply      + + XSEL/MCM0:                                                               |
| :      |     |      | [Clock supplied to main system and                                                                                       |
| ;      |     |      | peripheral hardware]                                                                                                     |
| ;      |     |      | 00: Main system clock (fXP)                                                                                              |
| ;      |     |      | = internal high-speed oscillation clock (fIH)                                                                            |
| ;      |     |      | Peripheral hardware clock (fPRS)                                                                                         |
| ;      |     |      | = internal high-speed oscillation clock (fIH)                                                                            |
| ;      |     |      | 01: Main system clock (fXP)                                                                                              |
| ;      |     |      | = internal high-speed oscillation clock (fIH)                                                                            |
| ;      |     |      | Peripheral hardware clock (fPRS)                                                                                         |
| ;      |     |      | = internal high-speed oscillation clock (fIH)                                                                            |
| ;      |     |      | 10: Main system clock (fXP)                                                                                              |
| ;      |     |      | = internal high-speed oscillation clock (fIH)                                                                            |
| ;      |     |      | Peripheral hardware clock (fPRS)                                                                                         |
| ;      |     |      | <pre>      = high-speed system clock (fIH)</pre>                                                                         |
| ;      |     |      | 11: Main system clock (fXP)                                                                                              |
| ;      |     |      | <pre>      = high-speed system clock (fIH)</pre>                                                                         |
| ;      |     |      | Peripheral hardware clock (fPRS)                                                                                         |

; = high-speed system clock (fIH) |||| +---- MCS ; ; [Main system clock status] +++++ Description ++++++----- Be sure to clear this bit to 0 ; PER0, #0000000B ; Control the real-time counter control clock MOV +++++++----- Be sure to clear this bit to 0 ; +---- RTCEN: ; [Real-time counter control clock] ; 0: Stop supply of control clock ; 1: Supply control clock ; ;-----Disable peripheral hardware not to be used ; 16-bit timer/event counter 00 TMC00, #0000000B ; Disable the counter MOV ; 8-bit timer/event counters 50 and 51 TMC50, #00000000B ; Disable timer 50 MOV TMC51, #0000000B ; Disable timer 51 MOV ; 8-bit timer H0 MOV TMHMD0, #0000000B ; Stop the timer ; Real-time counter MOV RTCC0, #0000000B ; Stop the counter ; Clock output controller #0000000B MOV CKS, ; Stop the clock frequency divider ; A/D converter MOV ADM0, #0000000B ; Stop A/D conversion ; Operational amplifiers MOV AMPOM, #0000000B ; Stop operational amplifier 0 AMP1M, #0000000B ; Stop operational amplifier 1 MOV ; Serial interface UART6 MOV ASIM6, #0000001B ; Disable the interface ; Serial interfaces CSI10 and CSI11 #00000000B ; Disable CSI10 MOV CSIM10, MOV CSIM11, #0000000B ; Disable CSI11 ; Interrupts MOVW ; Disable all interrupts MK0, #OFFFFH MOVW MK1, #0FFFFH ;

```
EGPCTL0,#00000000B ; Disable the detection of all external interrupts
     MOV
          EGPCTL1,#0000000B ;
     MOV
     ; Key interrupts
     MOV
          KRM,
                #0000000B
                         ; Disable all key interrupts
 Set up serial interface IICA
 - Specify fast mode as the operating mode and set the transfer clock frequency to
 ;
400 kHz
     - Specify 50H as the local address
 ;
 ; Set up the transfer clock
     MOV
          IICWL, #11
                      ; Specify the low-level width
     MOV
          IICWH, #8
                          ; Specify the high-level width
     MOV
          SVA0, #50H
                          ; Specify the local address
     MOV
          IICAF0,#0000000B ; IICA flag register 0
                 ||||||+----- IICRSV
 ;
 ;
                 [Communication reservation function disable bit]
                             0: Enable communication reservation
 :
                 1: Disable communication reservation
 ;
                 | | | | | +---- STCEN
 ;
                 [Initial start enable trigger]
                 0: After operation is enabled (IICE0 = 1), enable
 ;
                 generation of a start condition upon detection
                 of a stop condition
                             1: After operation is enabled (IICE0 = 1), enable
 ;
                 generation of a start condition without
                                detecting a stop condition
                 ||++++----- Be sure to clear this bit to 0
 ;
                 +----- IICBSY <Read only>
                            [I2C bus status flag]
 ;
                             0: Bus release status (communication initial status
 ;
when STCEN = 1)
 ;
                             1: Bus communication status (communication initial
status when STCEN = 0)
 ;
                 +----- STCF <Read only>
 ;
                            [STT0 clear flag]
                             0: Generate start condition
 ;
 ;
                             1: Start condition generation unsuccessful:
                                clear STT0 flag
 ;
     MOV
          IICACTL0,#00001100B ; IICA control register 0
 ;
                   ||||||+----- SPT0
 ;
                   [Stop condition trigger]
```

| ;                    |              | 0: Do not generate a stop condition                |
|----------------------|--------------|----------------------------------------------------|
| ,                    |              | 1: Generate a stop condition                       |
| ;                    | +            |                                                    |
| ;                    |              | [Start condition trigger]                          |
| ;                    |              | 0: Do not generate a start condition               |
| ;                    |              | 1: Generate a start condition                      |
| ;                    | +            |                                                    |
| ;                    |              | [Acknowledgment control]                           |
| ;                    |              | 0: Disable acknowledgment                          |
| ;                    |              | 1: Enable acknowledgment                           |
| ;                    | +            |                                                    |
| ;                    |              | [Control of wait and interrupt request generation] |
| ;                    |              | 0: Interrupt request is generated at the eighth    |
| clock's falling edge |              |                                                    |
| ;                    |              | 1: Interrupt request is generated at the ninth     |
| clock's falling edge |              |                                                    |
| ;                    | +            | SPIEO                                              |
| ;                    |              | [Enable/disable generation of interrupt request    |
| ;                    |              | when stop condition is detected]                   |
| ;                    |              | 0: Disable                                         |
| ;                    |              | 1: Enable                                          |
| ;                    | +            | WRELO                                              |
| ;                    |              | [Wait cancellation]                                |
| ;                    |              | 0: Do not cancel wait                              |
| ;                    |              | 1: Cancel wait                                     |
| ;                    | +            | LRELO                                              |
| ;                    |              | [Exit from communications]                         |
| ;                    |              | 0: Normal operation                                |
| ;                    |              | 1: This exits from the current communications and  |
| sets standby mode    |              |                                                    |
| i                    | +            | IICE0                                              |
| ;                    |              | [I2C operation enable]                             |
| ;                    |              | 0: Stop operation                                  |
| ;                    |              | 1: Enable operation                                |
|                      |              |                                                    |
| MOV IICACTL1,        | #00001100B ; | IICA control register 1                            |
| ;                    | ++           | Be sure to clear this bit to 0                     |
| ;                    | +            | DFC0                                               |
| ;                    |              | [Digital filter operation control]                 |
| ;                    |              | 0: Digital filter off                              |
| ;                    |              | 1: Digital filter on                               |
| ;                    | +            |                                                    |
| ;                    |              | [Operating mode switching]                         |
| ;                    |              | 0: Operates in standard mode                       |
| ;                    |              | 1: Operates in fast mode                           |
| ;                    | +            |                                                    |
| ;                    |              | [Detection of SDA0 pin level (valid only when IICE |
| 1)]                  |              |                                                    |
|                      |              |                                                    |

=

; 0: The SDA0 pin was detected at low level 1: The SDA0 pin was detected at high level ; ||+----- CLD0 : ; [Detection of SCL0 pin level (valid only when IICE = 1)] 0: The SCL0 pin was detected at low level ; 1: The SCLO pin was detected at high level ; +----- Be sure to clear this bit to 0 +---- WUP [Control of address match wakeup] ; 0: Stop operation of address match wakeup function in STOP mode ; 1: Enable operation of address match wakeup ; function in STOP mode : ; Enable I2C SET1 IICE0 ; Enable I2C bus output MOV POM6, #00000011B ; Set P60/SCLA0 and P61/SDAA0 to N-ch open-drain ; output mode #00000011B ; Set the P60/SCLA0 and P61/SDAA0 output latches to high MOV P6, level MOV РМ6, #11110000В ; Specify P60/SCLA0 and P61/SDAA0 as output ports CLR1 IICAIF0 ; Clear the INTIICA0 interrupt request CLR1 IICAMK0 ; Enable the INTIICA0 interrupt ;------Set up 8-bit timer H1 SET1 TMMKH1 ; Disable the INTTMH1 interrupt MOV TMHMD1, #01110000B ; Count clock fIL (= 30 kHz) MOV CMP01, #(150-1) ; Interval of about 5 ms (= 150/fIL) TMIFH1 ; Clear the INTTMH1 interrupt request CLR1 SET1 TMHE1 ; Start 8-bit timer H1 BR MMAIN\_LOOP ; Go to the main loop ; Main loop ; MMAIN\_LOOP: ; Initialize the variables to use MOV RTRSMOD, #CTXMOD ; Specify that transmission is performed next

```
; Prepare to start communication (generate a stop condition)
    BΤ
         STCEN, $LMAIN100
                        ; Has the bus been released? Yes,
    SET1
         SPT0
                        ; Generate a stop condition
 LMAIN050:
    BF
         SPDO, $LMAIN050
                      ; Has a stop condition been detected? No,
    ; Communication standby status
 LMAIN100:
    CLR1
         TMMKH1
                        ; Enable the INTTMH1 interrupt
    STOP
                        ; Enter the STOP mode (Exit the STOP mode by generating
an INTTMH1 interrupt)
    SET1
                        ; Disable the INTTMH1 interrupt
         TMMKH1
    CLR1
                        ; Clear the INTTMH1 interrupt request
         TMIFH1
 ;------
    Prepare to start I2C communication
 #CRESTRT
                       ; Specify the number of restarts if no acknowledge
    MOV
        в,
signal is detected
     ; Prepare to start communication (generate a start condition)
 LMAIN150:
    SET1
         STT0
                        ; Generate a start condition
 LMAIN160:
    BF
                      ; Has a start condition been detected? No,
         STDO, $LMAIN160
 Transmit the address
 ; Start communication (transmitting the address and transfer direction)
        A,
                       ; Read the transfer direction (transmission
    MOV
              RTRSMOD
(0)/reception (1))
         A, #CSLVADR ; Specify an address and the transfer direction
    OR
    CALL !SIICTX
                        ; Call transmission processing
    BF
         ACKD0, $LMAIN500 ; Has an acknowledge signal been detected? No,
         TRC0, $LMAIN600 ; Is data being received? Yes,
    BF
 ;-----
    Transmit data
 MOVW
        HL,
              #TTXDATA
                       ; Specify the start address of the transmission data
table
    MOV
         C,
              #CDATANUM ; Specify the number of data units
 LMAIN300:
    MOV
         Α,
             [HL]
                        ; Read the transmission data
                        ; Call transmission processing
    CALL !SIICTX
    BF
         ACKD0, $LMAIN500 ; Has an acknowledge signal been detected? No,
```

INCW HL; Go to the next transmission data DBNZ C, \$LMAIN300 ; Has all transmission data been transmitted? No, MOV RTRSMOD, #CRXMOD ; Perform reception next time LMAIN800 BR Identify restarts LMAIN500: DEC В ; Update the number of restarts \$LMAIN800 ; Has a restart ended? Yes, ΒZ ; Make the system wait upon a restart (about 10 us) MOV С, #10 ; Specify the number of counts LMAIN550: NOP ; DBNZ C, \$LMAIN550 ; Has the wait period ended? No, BR LMAIN150 ; Go to preparing to start communication Receive data ;-----LMAIN600: MOVW ; Specify the start address of the reception data save HL, #RRXBUF area C, #CDATANUM ; Specify the number of data units MOV ; Enable acknowledge signals SET1 ACKE0 CLR1 WTIMO ; Generate an interrupt request at the falling edge of the eighth clock cycle LMAIN700: ; Start reception SET1 WREL0 ; Make the system exit the wait status HALT ; Enter the HALT mode (Exit the HALT mode by generating an INTIICA0 interrupt) CLR1 IICAIF0 ; Clear the INTIICA0 interrupt request ; Read the received data MOV A, IICA MOV [HL], A ; Save the received data INCW HL; Go to the next reception data save area DBNZ C, \$LMAIN700 ; Has all reception data been received? No, ; When reception ends CLR1 ACKE0 ; Disable acknowledge signals ; Generate an interrupt request at the falling edge of SET1 WTIM0 the ninth clock cycle SET1 WREL0 ; Make the system exit the wait status

```
HALT
                    ; Enter the HALT mode (Exit the HALT mode by generating
an INTIICA0 interrupt)
    CLR1
       IICAIF0
                   ; Clear the INTIICA0 interrupt request
    MOV
        RTRSMOD, #CTXMOD ; Perform transmission next time
 ;-----
    Generate a stop condition
 ;-----
 LMAIN800:
    SET1
       SPT0
                    ; Generate a stop condition
 LMAIN810:
    BF
       SPD0, $LMAIN810 ; Has a stop condition been detected? No,
    BR
       LMAIN100
 ;
   Transmission
 ;
 ;------
    [IN] A
           : 8-bit data to transmit
 ;
    [OUT] -
 :
 SIICTX:
                   ; Start transmission
   MOV IICA, A
    ; Make the system wait until communication ends
    HALT
                    ; Enter the HALT mode (Exit the HALT mode by generating
an INTIICAO interrupt)
    CLR1
       IICAIF0
                   ; Clear the INTIICA0 interrupt request
    RET
 end
```

| • main.c (C language vers<br>/************************************ | sion)<br>************************************                   |
|--------------------------------------------------------------------|-----------------------------------------------------------------|
| NEC Electronics                                                    | 78K0/KC2-L Series                                               |
| * * * * * * * * * * * * * * * * * * * *                            | **********                                                      |
| 78K0/KC2-L Series                                                  | Sample Program (Serial Interface IICA)                          |
| * * * * * * * * * * * * * * * * * * * *                            | *************                                                   |
| Master Communicati                                                 | on                                                              |
| * * * * * * * * * * * * * * * * * * * *                            | ***********                                                     |
| < <history>&gt;</history>                                          |                                                                 |
| 2009.1 Release                                                     |                                                                 |
| ******                                                             | ********************                                            |
| < <overview>&gt;</overview>                                        |                                                                 |
| This sample program                                                | presents an example of using serial interface IICA.             |
| 16 bytes of data are                                               | e transmitted and received via the I2C bus in master operation. |
| Communication starts                                               | at intervals of about 5 ms, alternating between transmission    |
| and reception.                                                     |                                                                 |
| <primary initial="" se<="" th=""><th></th></primary>               |                                                                 |
| (Option byte settin                                                | -                                                               |
| -                                                                  | ernal low-speed oscillator to be programmed to stop             |
| - Disabling the wat                                                | -                                                               |
| -                                                                  | mal high-speed oscillation clock frequency to 8 MHz             |
| -                                                                  | m being started by default                                      |
|                                                                    | nitialization immediately after a reset ends)                   |
| - Specifying the RC                                                |                                                                 |
| - Setting up I/O po                                                |                                                                 |
| -                                                                  | VDD is 2.7 V or more by using the low-voltage detector          |
|                                                                    | the CPU clock and peripheral hardware clock run on the internal |
|                                                                    | lation clock (8 MHz)<br>eral hardware not to be used            |
| - Setting up serial                                                |                                                                 |
|                                                                    |                                                                 |
| requency to 400 kHz                                                | ast mode as the operating mode and setting the transfer clock   |
|                                                                    | I as the local address                                          |
|                                                                    | at P60/SCLA0 and P61/SDAA0 are used for the I2C bus             |
|                                                                    | INTIICA0 interrupt                                              |
| _                                                                  | 8-bit timer H1 runs in intervals of about 5 ms to trigger I2C   |
| ommunication                                                       | o bit timer in faile in intervals of about 5 mb to trigger ize  |
|                                                                    |                                                                 |
| <communication form<="" td=""><td>nat&gt;</td></communication>     | nat>                                                            |
|                                                                    |                                                                 |

```
[Transmission] ST + ADR/W + DT*16 + SP
  [Reception]
           ST + ADR/R + DT*16 + SP
   ST
       : Start condition
   SP
       : Stop condition
   ADR/W : Slave address + W
   ADR/R : Slave address + R
   DT
      : Data
<Address and data>
 Slave address
             : A0H
 Transmission data : 16 bytes (00H, 01H, 02H, ... 0DH, 0EH, 0FH)
 Reception data
            : 16 bytes (any)
<I/O port settings>
 Output: P60, P61
 * Set all unused ports that can be specified as output ports as output ports.
/*_____
Preprocessing directive (#pragma)
*/
                /* SFR names can be described at the C source level */
#pragma SFR
               /* DI instructions can be described at the C source level */
#pragma DI
#pragma EI
               /* EI instructions can be described at the C source level */
#pragma NOP
               /* NOP instructions can be described at the C source level */
                /* HALT instructions can be described at the C source level */
#pragma HALT
                /* STOP instructions can be described at the C source level */
#pragma STOP
/*_____
 Declare function prototypes
*/
static void fn_IICTx(unsigned char ucTxData); /* Transmission */
/*_____
Define the ROM data table
-----*/
```

```
static const unsigned char aTxData[16]=
 { /* Transmission data (16 bytes) */
  0x00,0x01,0x02,0x03,0x04,0x05,0x06,0x07,0x08,0x09,0x0A,0x0B,0x0C,0x0D,0x0E,0x0F
 };
 /*_____
  Define variables and constants
 -----*/
 static unsigned char ucTransmissionMode; /* Next operation (0: transmission, 1:
reception) */
 static unsigned char ucRestartCounter; /* Number of times to execute a restart */
                   /* Number of restarts if no acknowledge signal is
 #define CRESTART 3
detected */
 static unsigned char ucDataCounter;
                           /* Number of transmission and reception
data units */
 #define CSLAVEADDR 0xA0 /* Slave address */
 Initialization after RESET
 void hdwinit( void )
 {
  unsigned char ucCounter; /* Count variable */
 /*_____
  Disable interrupts
 */
  DI();
             /* Disable interrupts */
 /*-----
  Specify the ROM and RAM sizes
 _____
  Note that the values to specify vary depending on the model.
  Enable the settings for the model to use. (The uPD78F0588 is the default model.)
 -----*/
  /* Setting when using uPD78F0581 or uPD78F0586 */
  /*IMS = 0x42;*/
                 /* Specify the ROM and RAM sizes */
  /* Setting when using uPD78F0582 or uPD78F0587 */
  /*IMS = 0x04;*/
                 /* Specify the ROM and RAM sizes */
```

```
/* Setting when using uPD78F0583 or uPD78F0588 */
              /* Specify the ROM and RAM sizes */
  IMS = 0xC8;
 /*-----
  Initialize port 0
 -----*/
      = 0b00000000; /* Set the P00 to P02 output latches to low level */
  P0
  PM0
      = Ob11111000; /* Specify P00 to P02 as output ports */
              /* P00 to P02: Unused */
 /*_____
  Initialize port 1
 -----*/
  ADPC1 = 0b00000111; /* Specify P10 to P12 as digital I/O ports */
  P1
     = Ob00000000; /* Set the P10 to P17 output latches to low level */
      = 0b0000000; /* Specify P10 to P17 as output ports */
  PM1
              /* P10 to P17: Unused */
 /*-----
  Initialize port 2
 -----*/
  ADPC0 = 0b11111111; /* Specify P20 to P27 as digital I/O ports */
      = 0b00000000; /* Set the P20 to P27 output latches to low level */
  P2
  PM2
      = Ob0000000; /* Specify P20 to P27 as output ports */
              /* P20 to P27: Unused */
 /*_____
  Initialize port 3
 -----*/
  P٦
      = Ob00000000; /* Set the P30 to P33 output latches to low level */
      = Ob11110000; /* Specify P30 to P33 as output ports */
  PM3
              /* P30 to P33: Unused */
 /*-----
  Initialize port 4
   -----*/
  P4
      = Ob00000000; /* Set the P40 to P42 output latches to low level */
  PM4
      = Ob11111000; /* Specify P40 to P42 as output ports */
              /* P40 to P42: Unused */
 /*_____
  Initialize port 6
 -----*/
  PM6
      = 0b11110011; /* Specify P60 and P61 as input ports (to prevent the I2C bus from
being affected) */
              /* Specify P62 and P63 as output ports */
  P6
      = 0b00000000;/* Set the P60 to P63 output latches to low level */
              /* P60: Use as SCLA0 */
```

```
/* P61: Use as SDAA0 */
               /* P62 and P63: Unused */
 /*_____
  Initialize port 7
 */
  P7
      = 0b00000000; /* Set the P70 to P75 output latches to low level */
  PM7
      = Ob11000000; /* Specify P70 to P75 as output ports */
               /* P70 to P75: Unused */
 /*_____
  Initialize port 12
 -----*/
      = 0b00000000;/* Set the P120 output latch to low level */
  P12
  PM12 = 0b11111110; /* Specify P120 as an output port */
               /* P120 to P125: Unused */
 /*-----
  Low-voltage detection
 _____
  The low-voltage detector is used to check whether VDD is 2.7 V or more.
 -----*/
  /* Set up the low-voltage detector */
  LVIMK = 1;
              /* Disable the INTLVI interrupt */
  LVISEL = 0;
               /* Specify VDD as the detection voltage */
  LVIS = 0b00001001; /* Set the low-voltage detection level (VLVI) to 2.84 ±0.1 V */
  LVIMD = 0;
               /* Specify that an interrupt signal is generated when a low
voltage is detected */
  LVION = 1;
               /* Enable low-voltage detection */
  /* Make the system wait until the low-voltage detector stabilizes (10 us or more) */
  for( ucCounter = 0; ucCounter < 2; ucCounter++ ){</pre>
    NOP();
  }
  /* Make the system wait until VLVI is less than or equal to VDD */
  while(LVIF){
    NOP();
  }
  LVION = 0;
              /* Stop the low-voltage detector */
 /*-----
  Specify the clock frequency
 _____
  Specify the clock frequency so that the device can run on the internal high-speed
oscillation clock.
 -----*/
  OSCCTL = 0b0000000; /* Clock operation mode */
```

/\* ||||+||+---- Be sure to clear this bit to 0 \*/ /\* |||| ++---- RSWOSC/AMPHXT \*/ /\* [XT1 oscillator oscillation mode selection] \*/ /\* 00: Low power consumption oscillation \*/ /\* 01: Normal oscillation \*/ /\* 1x: Ultra-low power consumption oscillation \*/ /\* | | ++----- EXCLKS/OSCSELS \*/ /\* [Subsystem clock pin operation setting] \*/ (P123/XT1,P124/XT2/EXCLKS) \*/ /\* /\* Specify the use of the pin as an I/O port pin by specifying 000 by also using XTSTART \*/ /\* ++---- EXCLK/OSCSEL \*/ /\* [High-speed system clock pin operation setting] \*/ /\* (P121/X1,P122/X2/EXCLK) \*/ /\* 00: Input port \*/ /\* 01: X1 oscillation mode \*/ /\* 10: Input port \*/ /\* 11: External clock input mode \*/ PCC = 0b0000000; /\* Select the CPU clock (fCPU) \*/ /\* |||+|+++---- CSS/PCC2/PCC1/PCC0 \*/ /\* [CPU clock (fCPU) selection] \*/ /\* 0000:fXP \*/ /\* 0001:fXP/2 \*/ /\* 0010:fXP/2^2 \*/ /\* 0011:fXP/2^3 \*/ /\* 0100:fXP/2^4 \*/ /\* 1000:fSUB/2 \*/ /\* 1001:fSUB/2 \*/ /\* 1010:fSUB/2 \*/ /\* 1011:fSUB/2 \*/ /\* 1100:fSUB/2 \*/ /\* (Other than the above: Setting prohibited) \*/ /\* ||| +----- Be sure to clear this bit to 0 \*/ | |+----- CLS \*/ /\* /\* [CPU clock status] \*/ /\* +----- XTSTART \*/ /\* [Subsystem clock pin operation setting] \*/ /\* Specify the use of the pin by also using EXCLKS and OSCSELS \*/ /\* +----- Be sure to clear this bit to 0 \*/ RCM = 0b00000000; /\* Select the operating mode of the internal oscillator \*/ /\* ||||||+---- RSTOP \*/ /\* [Internal high-speed oscillator oscillating/stopped] \*/ /\* 0: Internal high-speed oscillator oscillating \*/ /\* 1: Internal high-speed oscillator stopped \*/ /\* |||||+---- LSRSTOP \*/ /\* [Internal low-speed oscillator oscillating/stopped] \*/

/\* 0: Internal low-speed oscillator oscillating \*/ /\* 1: Internal low-speed oscillator stopped \*/ /\* +++++----- Be sure to clear this bit to 0 \*/ /\* +----- RSTS \*/ /\* [Status of internal high-speed oscillator] \*/ MOC = 0b10000000; /\* Select the operating mode of the high-speed system clock \*/ |+++++++--- Be sure to clear this bit to 0 \*/ /\* +----- MSTOP \*/ /\* /\* [Control of high-speed system clock operation] \*/ /\* 0: X1 oscillator operating/external clock from EXCLK pin is enabled \*/ /\* 1: X1 oscillator stopped/external clock from EXCLK pin is disabled \*/ MCM = 0b0000000; /\* Select the clock to supply \*/ /\* ||||+++---- XSEL/MCM0 \*/ /\* [Clock supplied to main system and peripheral hardware] \*/ /\* 00: Main system clock (fXP) \*/ /\* = internal high-speed oscillation clock (fIH) \*/ Peripheral hardware clock (fPRS) \*/ /\* /\* = internal high-speed oscillation clock (fIH) \*/ /\* 01: Main system clock (fXP) \*/ /\* = internal high-speed oscillation clock (fIH) \*/ /\* Peripheral hardware clock (fPRS) \*/ /\* = internal high-speed oscillation clock (fIH) \*/ /\* 10: Main system clock (fXP) \*/ /\* = internal high-speed oscillation clock (fIH) \*/ /\* Peripheral hardware clock (fPRS) \*/ /\* = high-speed system clock (fIH) \*/ /\* 11: Main system clock (fXP) \*/ /\* = high-speed system clock (fIH) \*/ /\* Peripheral hardware clock (fPRS) \*/ /\* = high-speed system clock (fIH) \*/ /\* |||| +---- MCS \*/ /\* [Main system clock status] \*/ +++++----- Be sure to clear this bit to 0 \*/ /\* PER0 = 0b00000000; /\* Control the real-time counter control clock \*/ /\* +++++++---- Be sure to clear this bit to 0 \*/ /\* +----- RTCEN: \*/ /\* [Real-time counter control clock] \*/ /\* 0: Stop supply of control clock \*/ /\* 1: Supply control clock \*/ /\*-----Disable peripheral hardware not to be used -----\*/

```
/* 16-bit timer/event counter 00 */
  TMC00 = 0b0000000; /* Disable the counter */
   /* 8-bit timer/event counters 50 and 51 */
  TMC50 = 0b00000000; /* Disable timer 50 */
  TMC51 = 0b0000000; /* Disable timer 51 */
   /* 8-bit timer H0 */
  TMHMD0 = 0b0000000; /* Stop the timer */
   /* Real-time counter */
  RTCC0 = 0b0000000; /* Stop the counter */
   /* Clock output controller */
  CKS
      = 0b0000000; /* Stop the clock frequency divider */
   /* A/D converter */
  ADM0 = 0b0000000; /* Stop A/D conversion */
   /* Operational amplifiers */
  AMPOM = 0b00000000; /* Stop operational amplifier 0 */
  AMP1M = 0b00000000; /* Stop operational amplifier 1 */
   /* Serial interface UART6 */
  ASIM6 = 0b0000001; /* Disable the interface */
   /* Serial interfaces CSI10 and CSI11 */
  CSIM10 = 0b0000000; /* Disable CSI10 */
  CSIM11 = 0b0000000; /* Disable CSI11 */
   /* Interrupts */
  MK 0
       = 0 \times FFFF;
                  /* Disable all interrupts */
  MK1
        = 0 \times FFFF;
  EGPCTL0 = 0b00000000; /* Disable the detection of all external interrupts */
  EGPCTL1 = 0b0000000;
   /* Key interrupts */
        = Ob0000000; /* Disable all key interrupts */
  KRM
 /*-----
  Set up serial interface IICA
 _____
   - Specify fast mode as the operating mode and set the transfer clock frequency to 400
kHz
   - Specify 50H as the local address
 -----*/
   /* Set up the transfer clock */
  IICWL = 11; /* Specify the low-level width */
```

| IICWH = 8     | 3; /* Specify the high-level width */                               |              |
|---------------|---------------------------------------------------------------------|--------------|
| SVA0 = (      | Dx50; /* Specify the local address */                               |              |
| IICAF0 = (    | )b0000000;/* IICA flag register 0 */                                |              |
| /*            | + IICRSV                                                            | * /          |
| /*            | [Communication reservation function disable bit]                    | */           |
| /*            | 0: Enable communication reservation                                 | * /          |
| /*            | 1: Disable communication reservation                                | * /          |
| /*            | + STCEN                                                             | * /          |
| /*            | <pre>       [Initial start enable trigger]</pre>                    | * /          |
| /*            | <pre>       0: After operation is enabled (IICE0 = 1), enable</pre> | * /          |
| /*            | generation of a start condition upon detection                      | */           |
| /*            | of a stop condition                                                 | * /          |
| /*            | <pre>       1: After operation is enabled (IICE0 = 1), enable</pre> | * /          |
| /*            | generation of a start condition without                             | * /          |
| /*            | detecting a stop condition                                          | * /          |
| /*            | ++++ Be sure to clear this bit to 0                                 | * /          |
| /*            | + IICBSY <read only=""></read>                                      | * /          |
| /*            | [I2C bus status flag]                                               | * /          |
| /*            | 0: Bus release status (communication initial statu                  | s when STCEN |
| = 1) */       |                                                                     |              |
| /*            | 1: Bus communication status (communication initial                  | status when  |
| STCEN = 0) */ | /                                                                   |              |
| /*            | + STCF <read only=""></read>                                        | * /          |
| /*            | [STT0 clear flag]                                                   | * /          |
| /*            | 0: Generate start condition                                         | * /          |
| /*            | 1: Start condition generation unsuccessful:                         | */           |
| /*            | clear STTO flag                                                     | * /          |
| IICACTL0      | = 0b00001100; /* IICA control register 0 */                         |              |
| /*            | + SPT0                                                              | * /          |
| /*            | [Stop condition trigger]                                            | * /          |
| /*            | <pre>        0: Do not generate a stop condition</pre>              | */           |
| /*            | 1: Generate a stop condition                                        | * /          |
| /*            | + STT0                                                              | * /          |
| /*            | <pre>       [Start condition trigger]</pre>                         | * /          |
| / *           | <pre>       0: Do not generate a start condition</pre>              | */           |
| /*            | 1: Generate a start condition                                       | * /          |
| /*            | + ACKE0                                                             | * /          |
| /*            | [Acknowledgment control]                                            | * /          |
| /*            | 0: Disable acknowledgment                                           | * /          |
| /*            | 1: Enable acknowledgment                                            | * /          |
| /*            | + WTIM0                                                             | * /          |
| /*            | [Control of wait and interrupt request generation]                  | * /          |
| /*            | 0: Interrupt request is generated at the eig                        | hth clock's  |
|               |                                                                     |              |
| alling edge   | */                                                                  |              |

| edge */ |                                                       |                 |
|---------|-------------------------------------------------------|-----------------|
| /*      | + SPIE0                                               | * /             |
| /*      | [Enable/disable generation of interrupt request       | * /             |
| /*      | <pre>when stop condition is detected]</pre>           | * /             |
| /*      | 0: Disable                                            | * /             |
| /*      | 1: Enable                                             | * /             |
| /*      | + WREL0                                               | * /             |
| /*      | [Wait cancellation]                                   | * /             |
| /*      | 0: Do not cancel wait                                 | * /             |
| /*      | 1: Cancel wait                                        | * /             |
| /*      | + LREL0                                               | * /             |
| /*      | [Exit from communications]                            | * /             |
| /*      | 0: Normal operation                                   | * /             |
| /*      | 1: This exits from the current communications a       | nd sets standby |
| mode */ |                                                       |                 |
| /*      | + IICE0                                               | * /             |
| /*      | [I2C operation enable]                                | * /             |
| /*      | 0: Stop operation                                     | * /             |
| /*      | 1: Enable operation                                   | * /             |
|         |                                                       |                 |
| IICAC   | TL1 = 0b00001100; /* IICA control register 1 */       |                 |
| /*      | <pre>      ++ Be sure to clear this bit to 0</pre>    | */              |
| /*      | + DFC0                                                | * /             |
| /*      | [Digital filter operation control]                    | * /             |
| /*      | 0: Digital filter off                                 | * /             |
| /*      | 1: Digital filter on                                  | * /             |
| /*      | + SMC0                                                | * /             |
| /*      | <pre>[] [Operating mode switching]</pre>              | * /             |
| /*      | <pre>     0: Operates in standard mode</pre>          | * /             |
| /*      | <pre>     1: Operates in fast mode</pre>              | * /             |
| /*      | + DAD0                                                | * /             |
| /*      | [Detection of SDA0 pin level (valid only when IIC     | CE = 1)] */     |
| /*      | <pre>0: The SDA0 pin was detected at low level</pre>  | * /             |
| /*      | <pre>1: The SDA0 pin was detected at high level</pre> | * /             |
| /*      | + CLD0                                                | * /             |
| /*      | [Detection of SCL0 pin level (valid only when IIC     | CE = 1)] */     |
| /*      | 0: The SCLO pin was detected at low level             | * /             |
| /*      | 1: The SCLO pin was detected at high level            | * /             |
| /*      | + Be sure to clear this bit to O                      | */              |
| /*      | + WUP                                                 | * /             |
| /*      | [Control of address match wakeup]                     | * /             |
| /*      | 0: Stop operation of address match wakeup             | * /             |
| /*      | function in STOP mode                                 | * /             |
| /*      | 1: Enable operation of address match wakeup           | * /             |
| /*      | function in STOP mode                                 | * /             |
|         |                                                       |                 |

IICE0 = 1; /\* Enable I2C \*/

```
/* Enable I2C bus output */
       = 0b00000011; /* Set P60/SCLA0 and P61/SDAA0 to N-ch open-drain */
  POM6
                  /* output mode
                                                          * /
  P6
        = 0b00000011; /* Set the P60/SCLA0 and P61/SDAA0 output latches to high level */
        = 0b11110000; /* Specify P60/SCLA0 and P61/SDAA0 as output ports */
  PM6
  IICAIFO = 0;
                 /* Clear the INTIICA0 interrupt request */
  IICAMK0
          = 0;
              /* Enable the INTIICA0 interrupt */
 /*_____
  Set up 8-bit timer H1
 -----*/
  TMMKH1 = 1;
                 /* Disable the INTTMH1 interrupt */
  TMHMD1 = 0b01110000; /* Count clock fIL (= 30 kHz) */
  CMP01 = (150-1); /* Interval of about 5 ms (= 150/fIL) */
  TMIFH1 = 0;
                 /* Clear the INTTMH1 interrupt request */
  TMHE1 = 1; /* Start 8-bit timer H1 */
 }
 Main loop
 void main(void)
 {
  unsigned char ucCounter; /* Count variable */
  /* Initialize the variables to use */
  ucTransmissionMode = 0; /* Specify that transmission is performed next */
  /* If the bus is not released */
  if( !STCEN ){
     SPT0 = 1; /* Generate a stop condition */
     while( !SPD0 ){
                 /* Make the system wait until a stop condition is detected */
       NOP();
     }
  }
  while (1){
     /* Communication standby status */
     TMMKH1 = 0; /* Enable the INTTMH1 interrupt */
     STOP();
             /* Enter the STOP mode (Exit the STOP mode by generating an INTTMH1
interrupt) */
     TMMKH1 = 1; /* Disable the INTTMH1 interrupt */
     TMIFH1 = 0; /* Clear the INTTMH1 interrupt request */
```

```
/* Restart loop */
    /* * This loop is exited because no restart is necessary if transmission and
reception have been completed */
    for( ucRestartCounter = 0; ucRestartCounter < CRESTART; ucRestartCounter++){</pre>
     /*_____
       Prepare to start I2C communication
     -----*/
       /* Prepare to start communication (generate a start condition) */
       STT0 = 1;
                   /* Generate a start condition */
       while( !STD0 ){
         NOP();
                   /* Make the system wait until a start condition is detected */
       }
     /*-----
       Transmit the address
     -----*/
       /* If transmission is performed next */
       if( !ucTransmissionMode ) {
         fn_IICTx( CSLAVEADDR );
                              /* Transmit the address + W (0: data
transmission) */
       }
       /* If reception is performed next */
       else{
         fn_IICTx((CSLAVEADDR + 1)); /* Transmit the address + R (1: data
reception) */
       }
       /* If an acknowledge signal is detected */
       if( ACKD0 ){
         /* During transmission */
         if( TRC0 ){
          /*_____
            Transmit data
         -----*/
            /* Transmit the specified number of bytes */
            for( ucDataCounter = 0; ucDataCounter < 16; ucDataCounter++ ){</pre>
              fn_IICTx( aTxData[ucDataCounter] ); /* Transmit data */
              /* If an acknowledge signal is not detected */
              if( !ACKD0 ){
                 break; /* Suspend transmission */
              }
            }
         /* During reception */
         else{
          /*_____
```

```
Receive data
            -----*/
              ACKE0 = 1; /* Enable acknowledge signals */
              WTIMO = 0; /* Generate an interrupt request at the falling edge of the
eighth clock cycle */
               /* Receive the specified number of bytes */
              for( ucDataCounter = 0; ucDataCounter < 16; ucDataCounter++ ){</pre>
                 /* Start reception */
                 WRELO = 1; /* Make the system exit the wait status */
                 HALT();
                            /* Enter the HALT mode (Exit the HALT mode by generating
an INTIICA0 interrupt) */
                 IICAIF0 = 0; /* Clear the INTIICA0 interrupt request */
                 ucRxBuffer[ucDataCounter] = IICA; /* Read the received data */
              }
              /* When reception ends */
              ACKE0 = 0; /* Disable acknowledge signals */
              WTIMO = 1; /* Generate an interrupt request at the falling edge of the
ninth clock cycle */
              WRELO = 1; /* Make the system exit the wait status */
              HALT();
                         /* Enter the HALT mode (Exit the HALT mode by generating an
INTIICA0 interrupt) */
              IICAIF0 = 0; /* Clear the INTIICA0 interrupt request */
            }
         }
         /* End transmission and reception */
         /* * Exit the restart loop and proceed to generating a stop condition */
         if( ucDataCounter >= 16 ){
              ucTransmissionMode ^= 1; /*
                                             Switch
                                                       the
                                                               next
                                                                      operation
(transmission/reception) */
                                   /* Go to generating a stop condition */
              break;
         }
         /* Restart */
        else{
            /* Make the system wait upon a restart (about 10 us) */
           for( ucCounter = 0; ucCounter < 2; ucCounter++ ){</pre>
              NOP();
           }
        }
      }
   /*-----
     Generate a stop condition
   -----*/
      SPT0 = 1;
                   /* Generate a stop condition */
```

```
while( !SPD0 ){
      NOP();
            /* Make the system wait until a stop condition is detected */
    }
  }
 }
 Transmission
 _____
                             _____
  [I N] ucTxData
              : 8-bit data to transmit
  [OUT] -
 static void fn_IICTx(unsigned char ucTxData)
 {
  IICA = ucTxData; /* Start transmission */
  /* Make the system wait until communication ends */
                /* Enter the HALT mode (Exit the HALT mode by generating an
  HALT();
INTIICA0 interrupt) */
    IICAIF0 = 0; /* Clear the INTIICA0 interrupt request */
  }
```

# APPENDIX B USING 78K0/KC2-L 44-PIN PRODUCTS

All 78K0/KC2-L sample programs are intended for 48-pin products. To use a 78K0/KC2-L sample program for a 44-pin product, specify the following settings:

# (1) Initial settings of ports

- Setting up port 0 Change the value of bit 2 of port mode register 0 (PM0) from "0" to "1".
- Setting up port 4 Change the value of bit 2 of port mode register 4 (PM4) from "0" to "1".
- Setting up port 7 Change the values of bits 5 and 4 of port mode register 7 (PM7) from "00" to "11".

# (2) Disabling unused peripheral hardware

Delete the instruction used to set up the clock output selection register (CKS).

# APPENDIX C REVISION HISTORY

| Edition     | Date Published | Page | Revision |
|-------------|----------------|------|----------|
| 1st edition | August 2009    | -    | _        |

# For further information, please contact:

## **NEC Electronics Corporation**

1753, Shimonumabe, Nakahara-ku, Kawasaki, Kanagawa 211-8668, Japan Tel: 044-435-5111 http://www.necel.com/

## [America]

# NEC Electronics America, Inc.

2880 Scott Blvd. Santa Clara, CA 95050-2554, U.S.A. Tel: 408-588-6000 800-366-9782 http://www.am.necel.com/

# [Europe]

## NEC Electronics (Europe) GmbH

Arcadiastrasse 10 40472 Düsseldorf, Germany Tel: 0211-65030 http://www.eu.necel.com/

## Hanover Office Podbielskistrasse 166 B 30177 Hannover Tel: 0 511 33 40 2-0

Munich Office Werner-Eckert-Strasse 9 81829 München Tel: 0 89 92 10 03-0

# Stuttgart Office

Industriestrasse 3 70565 Stuttgart Tel: 0 711 99 01 0-0

# **United Kingdom Branch**

Cygnus House, Sunrise Parkway Linford Wood, Milton Keynes MK14 6NP, U.K. Tel: 01908-691-133

## Succursale Française

9, rue Paul Dautier, B.P. 52 78142 Velizy-Villacoublay Cédex France Tel: 01-3067-5800

# Sucursal en España

Juan Esplandiu, 15 28007 Madrid, Spain Tel: 091-504-2787

## **Tyskland Filial**

Täby Centrum Entrance S (7th floor) 18322 Täby, Sweden Tel: 08 638 72 00

# Filiale Italiana

Via Fabio Filzi, 25/A 20124 Milano, Italy Tel: 02-667541

# **Branch The Netherlands**

Steijgerweg 6 5616 HS Eindhoven The Netherlands Tel: 040 265 40 10

## [Asia & Oceania]

#### NEC Electronics (China) Co., Ltd 7th Floor, Quantum Plaza, No. 27 ZhiChunLu Haidian District, Beijing 100083, P.B. China

District, Beijing 100083, P.R.China Tel: 010-8235-1155 http://www.cn.necel.com/

#### Shanghai Branch

Room 2509-2510, Bank of China Tower, 200 Yincheng Road Central, Pudong New Area, Shanghai, P.R.China P.C:200120 Tel:021-5888-5400 http://www.cn.necel.com/

### Shenzhen Branch

Unit 01, 39/F, Excellence Times Square Building, No. 4068 Yi Tian Road, Futian District, Shenzhen, P.R.China P.C:518048 Tel:0755-8282-9800 http://www.cn.necel.com/

#### NEC Electronics Hong Kong Ltd.

Unit 1601-1613, 16/F., Tower 2, Grand Century Place, 193 Prince Edward Road West, Mongkok, Kowloon, Hong Kong Tel: 2886-9318 http://www.hk.necel.com/

#### NEC Electronics Taiwan Ltd.

7F, No. 363 Fu Shing North Road Taipei, Taiwan, R. O. C. Tel: 02-8175-9600 http://www.tw.necel.com/

#### NEC Electronics Singapore Pte. Ltd.

238A Thomson Road, #12-08 Novena Square, Singapore 307684 Tel: 6253-8311 http://www.sg.necel.com/

### **NEC Electronics Korea Ltd.**

11F., Samik Lavied'or Bldg., 720-2, Yeoksam-Dong, Kangnam-Ku, Seoul, 135-080, Korea Tel: 02-558-3737 http://www.kr.necel.com/