# Old Company Name in Catalogs and Other Documents

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

Renesas Electronics website: <a href="http://www.renesas.com">http://www.renesas.com</a>

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

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

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



#### Notice

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



## M16C/60 Series

## Clock-Synchronous Serial I/O

#### 1. Abstract

The following article introduces Clock-Synchronous Serial I/O of M16C/60 series.

### 2. Introduction

The explanation of this issue is applied of the following condition.

Applicable MCU: M16C/60 Series

#### 3.0 Contents

### 3.1 Outline of Clock-Synchronous Serial I/O

Clock-Synchronous Serial I/O uses one clock line, one data line (2 lines in bi-directional transfers), and one or two control lines (depending on the system). The data is transferred while synchronizing the data line to the clock line bit by bit. Clock-Synchronous Serial I/O enables data transfer with less wiring than parallel transfers.



Figure 1. Clock-Synchronous Serial Timing Diagram





Figure 2. Clock-Synchronous Serial Interface Example

### 3.2 Features of M16C/60 Series Clock-Synchronous Serial I/O

M16C/60 Series Clock-Synchronous Serial I/O offers sophisticated functions to communicate with various external devices as make software development easy.

**Note:** Not all serial I/Os in the M16C/60 Series are equipped with all of the following functions. In addition, certain functions cannot be used in combination with other functions

### • Programmable Data Input/Output Timing based on Transfer Clock

The I/O timing of the receive/transmit data can be selected from either the rising edge or the falling edge of the transfer clock.

#### • Programmable Data Input/Output Order

The I/O order of the receive/transmit data can be selected from either MSB (bit 7) first or LSB (bit 0) first.

### • Reversible Logic for Input/Output Data (for applicable serial I/O only)

When writing the transmit data and when reading the received data, the data can be reversed.

### • Reversible Polarity for Data I/O Pins (for applicable serial I/O only)

The level of the transmit data output pin and the receive data input pin can be reversed.

### • Selectable Transmit Interrupt Factors

The generation timing for the transmit interrupt request can be selected from either when the transmit buffer register becomes empty or when the transmit is completed.



### • CTS/RTS Function

The CTS function can be used during data transmit or the RTS function can be used during data receive

### • Receive Error Detect Function

When the serial I/O fails to receive the data, it sets the error flag, allowing the user to recognize the error (overrun error only).

### • <u>Transfer Clock Output from Dual Pins</u> (for applicable serial I/O only)

M16C/60 Series is equipped with 2 transfer clock output pins and can switch the 2 output pins. Therefore, data can be transferred to two devices on the same data line.

#### • Continuous Receive Mode

In addition to the normal method of writing dummy data to the transmit buffer register after each data receive in order to enable the next receive, you can select the continuous receive mode, which enables the next data receive, simply by reading the received data from the receive buffer register after writing dummy data to the transmit buffer register only once.



### Comparison of Clock-Synchronous Serial I/O Functions by Group/Channel

Table 1. M16C/61 Group Function

| Function/Group                       | M16C/61            |           |           |  |
|--------------------------------------|--------------------|-----------|-----------|--|
| Channel                              | Clock Sync./Async. |           |           |  |
| Gianici                              | UART0              | UART1     | UART2     |  |
| Clock Polarity Select                | Available          | Available | Available |  |
| LSB First/<br>MSB First Select       | Available          | Available | Available |  |
| Transfer Clock Output from Dual Pins |                    | Available |           |  |
| CTS/RTS Function                     | Available          | Available | Available |  |
| Serial Data<br>Logic Reverse         |                    |           | Available |  |
| RxD/TxD I/O<br>Polarity Reverse      |                    |           | Available |  |
| Continuous Receive Mode              | Available          | Available | Available |  |
| Transmit Interrupt Factor Select     | Available          | Available | Available |  |

Table2. M16C/62 Group Function

| Function / One un                    | M16C/62           |           |             |           |           |
|--------------------------------------|-------------------|-----------|-------------|-----------|-----------|
| Function/Group<br>Channel            | Clock Sync./Async |           | Clock Sync. |           |           |
| Charine                              | UART0             | UART1     | UART2       | SIO3      | SIO4      |
| Clock Polarity Select                | Available         | Available | Available   |           |           |
| LSB First/<br>MSB First Select       | Available         | Available | Available   | Available | Available |
| Transfer Clock Output from Dual Pins |                   | Available |             |           |           |
| CTS/RTS Function                     | Available         | Available | Available   |           |           |
| Serial Data<br>Logic Reverse         |                   |           | Available   |           |           |
| RxD/TxD I/O<br>Polarity Reverse      |                   |           | Available   |           |           |
| Continuous Receive Mode              | Available         | Available | Available   |           |           |
| Transmit Interrupt Factor Select     | Available         | Available | Available   |           |           |

**Note:** There are some differences concerning settings and operations between the two clock-synchronous only modules (SI03, SI04) and the three clock sync./async. modules (UART0 to UART2), as shown below.



### [Differences in Settings and Operations]

To initiate transmit/receive operation:

Clock-synchronous only: Data transfer starts by writing the data to the SI/O transmission/reception register.

Clock sync./async.: The transmit enable bit and receive enable bit must be set before writing the data.

2. Transmit/receive completion:

Clock-synchronous only: Completion is determined by the interrupt request bit only.

Clock sync./async.: Completion is determined by the interrupt request bits, transmit register empty flag, and the receive complete flag.

Continuous transmit/receive:

Clock-synchronous only: The next transmit data cannot be set and the next data cannot be received until after the previous data has been transmitted and received.

Clock sync./async.: Once the transmit buffer register or receive register is cleared, the next transmit data can be set or the next data can be received.

(UART0 to UART2 have two registers for transmit use and two registers for receive use. In comparison, SIO3 and SIO4 have only one register for each module.)

### 3.3 Clock-Synchronous Serial I/O Operation

In M16C/60 Series clock-synchronous serial I/O, you can set the mode and transfer speed and enable transfers by setting each control register. Transfers can be initiated automatically by writing transmit data or dummy data to the transmit buffer register in transmit or receive operations, respectively. Completion of a receive or transmit can be determined by the transmit register empty flag or by the receive complete flag in the control registers.

#### Internal/External Clock Selection

When outputting a transfer clock to an external device, select the internal clock. A transfer is started by setting the transfer speed (described in detail later), enabling the transfer, then writing transmit data (for a transmit) or dummy data (for a receive) to the transmit buffer register.

When inputting a transfer clock from an external device, select the external clock. After enabling the transfer, prepare for the external clock to be input by writing transmit data (for a transmit) or dummy data (for a receive) to the transmit buffer register.



#### **Setting the Transfer Speed**

Select the transfer speed while operating with the internal clock. The transfer speed is determined by the count source (f1, f8, f32) and the set value (0 to 255) of the bit rate generator. (The output from the bit rate generator is divided in half again and becomes the transfer clock.)



Figure 3. Baud Rate: fi/2(n+1) (i = 1, 8, 32)

#### **Transfer Speed Conditions**

The transfer speed must meet the serial I/O timing requirements indicated under the electrical characteristics in the user's manual.

Table3. M16C/62 Group Serial I/O Timing Requirements (Vcc=5V)

| Symbols                      | Parameters                  | Stand | Standards |      |
|------------------------------|-----------------------------|-------|-----------|------|
|                              |                             | Min.  | Max.      | Unit |
| tc(CK)                       | CLKi input cycle time       | 200   |           | ns   |
| tw(CKH)                      | CLKi input HIGH pulse width | 100   |           | ns   |
| tw(CKL)                      | CLKi input LOW pulse width  | 100   |           | ns   |
| td(C-Q)                      | TxDi output delay time      |       | 80        | ns   |
| <b>t</b> h(C-Q)              | TxDi hold time              | 0     |           | ns   |
| <b>t</b> su(D-C)             | RxDi input setup time       | 30    |           | ns   |
| th(C-D) RxDi input hold time |                             | 90    |           | ns   |

For example, when calculating the speed according to fi/2(n+1), the transfer speed will be a maximum of 8Mbps when Vcc=5V and f(XIN)=16MHz (when fi=fl and n=0). However, the minimum input cycle time of the clock, as defined in the timing requirements, is 200ns, which 8Mbps does not satisfy. In this case, the maximum value will be 4Mbps (n=1).

In regards to the connected device, please keep in consideration the maximum TxD output delay time while transmitting and the minimum RxD input setup time while receiving.



#### **Transfer Initiation**

To initiate the transmit, set the transmit enable bit then write the transmit data to the transmit buffer register. To receive, set both the transmit enable bit and the receive enable bit, and then write dummy data to the transmit buffer register.

Note: In the M16C/62 Group, TxD2 pin1 is N-channel open-drain output and must be pulled up.



Figure 4. Flowchart (Transmit)





Figure 5. Flowchart (Receive)



### 3.4 Continuous Data Transmit Using an Interrupt

When setting and transmitting continuous data in an interrupt process, you can minimize the void between each data by setting the transmit interrupt factor to "transmit buffer empty".

The 8-bit data written to the transmit buffer register will be output from the TxD pin after being transferred to the transmit register. When the interrupt factor is set to "transmit completed" by the transmit interrupt cause select bit, the interrupt request is generated when the output of 8-bit data is completed. On the other hand, when the factor is set to "transmit buffer empty", the interrupt request will be generated when data is transferred from the transmit buffer register to the transmit register, and the next data can be set in the transmit buffer register before the current transmit is complete.



Figure 6. Operation Timing Diagram for Interrupt Factor Setting "Transmit Buffer Empty"



Figure 7. Operation Timing Diagram for Interrupt Factor Setting "Transmit Completed"



### **Transmit Process Example for Using an Interrupt**

In a main routine, enable the transmit. In an interrupt process, transmit data.

#### [Outline]

- 1. Set each clock-synchronous serial I/O function.
- 2. Clear the transmit interrupt request bit to be used, set the interrupt enable flag.
- To start the transmit, set the transmit enable bit and write the first byte of transmit data to the transmit buffer register.
- 4. Write 1-byte transmit data at a time to the transmit buffer register whenever transmit interrupt is generated.
- 5. Disable the transmit interrupt after writing the last data to the transmit buffer register.



Figure8. General Flowchart: Transmit Process Example for Using an Interrupt



#### Sample Program

Transmitting data contained in addresses 500h to 503h.

```
Main Program
MAIN:
   JSR
              INIT
                               ; Go to UARTO initial settings
   FSET
                               Enable interrupt
   MOV.B
              #01h,U0C1
                               Enable transmit
   MOV.B
              [AO],UOTB
                               Write transmit data
                  UARTO Function Initial Settings
-----
INIT:
   MOV.B
              #01h,UOMR
                               : Select internal clock
              #10h,U0C0
   MOV.B
                               Disable CTS function, select count source f1
              #00h,UCON
   MOV.B
                               ; UARTO transmit interrupt cause = transmit buffer empty
              #0FFh.U0BRG
   MOV.B
                               Fransfer speed = f1/256 \times 1/2
   MOV.W
              #500h,DATA
                               Set position for reading transmit data
   MOV.W
              #500h.A0
   MOV.B
              #3,CNT
                               ; Set number of transfers (4-1)
   MOV.B
              #01h,SOTIC
                               ; Set UARTO transmit interrupt priority level
INT_END:
   RTS
                 UARTO Transmit Interrupt Process
SOT_INT:
   PUSH.W
              A0
                               : Save A0
   INC.B
              DATA
                               ; Set position for reading next transmit data
   MOV.W
              DATA,A0
   MOV.B
              [A0],U0TB
                               ; Write next transmit data
   DEC.B
              CNT
                               Count down number of transfers
   JNZ
              SOT_INT_1
                               Keep interrupt enabled if more data to transmit
   MOV.B
              #00h,S0TIC
                               ; If last data, disable transmit interrupt
SOT_INT_1:
    POP.W
              A0
                               Restore A0
    REIT
```



#### 3.5 Continuous Receive Mode

Data can be received continuously in the continuous receive mode without writing dummy data to the transmit buffer register. (You must write dummy data to the transmit buffer register or read dummy data from the receive buffer register in order to start the receive operation.)

In the normal receive method, the next data receive is enabled by writing a dummy data to the transmit buffer register after each byte of data received. However, in the continuous receive mode, the next receive is enabled when the received data is read out from the receive buffer register. It is not necessary to write to the transmit buffer register. (In other words, by reading out the receive buffer register, dummy data is automatically written to the transmit buffer register.)

**Note 1:** Do not write dummy data to the transmit buffer register when in the continuous receive mode, except for the first time in order to initialize the receive operation.

**Note 2:** The value output by the TxD pin is undetermined.



Figure 9. Receive Operation Comparison



### **Process Example in Continuous Receive Mode**

In a main routine, enable the receive. In an interrupt process, read out data.

#### [Outline]

- 1. Enable the continuous receive mode and set each clock-synchronous serial I/O function.
- 2. Clear the receive interrupt request bit to be used, set the interrupt enable flag.
- To start the receive operation, set the transmit enable bit and receive enable bit, and read a dummy data from the receive buffer register.
- 4. Read out the received data from the receive buffer register whenever receive interrupt is generated.
- 5. Disable the receive interrupt after reading the last data from the receive buffer register.



Figure 10. General Flowchart: Process Example in Continuous Receive Mode



#### Sample Program

Store received data in addresses 500h to 503h.

```
Main Program
MAIN:
              INIT
   JSR
                              ; Go to UARTO initial settings
   FSET
              ı
                              ; Enable interrupt
   MOV.B
              #05h,U0C1
                              ; Enable receive
   MOV.B
              UORB,ROL
                              ; Read dummy data = start receive
      ----- UARTO Function Initial Settings ------
INIT:
   MOV.B
              #09h,UOMR
                              ; Select external clock
   MOV.B
              #10h,U0C0
                              ; Disable RTS function
   MOV.B
              #04h,UCON
                              ; Enable UARTO continuous receive mode
   MOV.W
              #500h,DATA
                              Set position for storing received data
   MOV.B
              #4,CNT
                              Set number of transfers
              #01h,SORIC
   MOV.B
                              Set UARTO receive interrupt priority level
INT_END:
   RTS
                 UARTO Receive Interrupt Process
SOR_INT:
   PUSH.W
              A0
                              ; Save A0
              DATA, AO
   MOV.W
              UORB,[A0]
   MOV.B
                              ; Read received data
   INC.B
              DATA
                              Set position for storing next receive data
   DEC.B
              CNT
                              Count down number of transfers
              SOR_INT_1
   JNZ
                              Keep interrupt enabled if more data to receive
    MOV.B
              #00h,SORIC
                              i If last data, disable receive interrupt
SOR_INT_1:
    POP.W
              A0
                              Restore A0
    REIT
```



### 3.6 Transfer Clock Dual-Pin Output

By selecting the transfer clock dual-pin output and switching two transfer clock output pins, you can transfer data to two external ICs using a common data line on a time-sharing basis. This will reduce the required number of pins as well as reduce on-board wiring.



Figure 11. Connection Example (internal clock, data transmit only)



Figure 12. Operation Timing Diagram of Transferring Clock Dual-Pin Output



### **Process Example for Transfer Clock Dual-Pin Output**

- 1. In a main routine, enable the transmit and select CLKS1 as the transfer clock output pin.
- 2. Switch the transfer clock output pin (->CLK1 -> CLKS1 -> CLK1...) each time a transmit interrupt is generated and transmit data to two external ICs by turns.

### [Outline]

- Select the transfer clock dual-pin output and set each clock-synchronous serial I/O function.
- 2. Clear the transmit interrupt request bit to be used, set the interrupt enable flag.
- 3. To start the transmit, set the transmit enable bit and write the first byte of transmit data to the transmit buffer register. (The first data is sent to the CLKS1 side.)
- 4. Switch CLK1 and CLKS1 and write 1-byte transmit data at a time to the transmit buffer register, whenever transmit interrupt is generated.
- 5. Disable the transmit interrupt after writing the last data to the transmit buffer register.



Figure 13. General Flowchart of Transferring Clock Dual-Pin Output



#### Sample Program

Transmitting data contained in addresses 500h to 503h.

```
Main Program
MAIN:
   JSR
              INIT
                                Go to UART1 initial settings
   FSET
                               ; Enable interrupt
   MOV.B
              #01h,U1C1
                               ; Enable transmit
   MOV.B
              [A0],U1TB
                               Write transmit data
;======== UART1 Function Initial Settings  ========
INIT:
                               ; Select internal clock
   MOV.B
              #01h,U1MR
              #10h,U1C0
                               ; Disable CTS function, select count source f1
   MOV.B
   MOV.B
              #32h,UCON
                               ; Select transfer clock dual-pin output
                               ; Set clock output pin to CLKS1
   MOV.B
              #0FFh,U1BRG
                               ; Transfer speed = f1/256 \times 1/2
   MOV.W
              #500h,DATA
                               Set position for reading transmit data
   MOV.W
              #500h,A0
   MOV.B
              #3,CNT
                               ; Set number of transfers (4-1)
   MOV.B
              #01h,S1TIC
                               ; Enable transmit interrupt
INT_END:
   RES
                 UART1 Transmit Interrupt Process
S1T_INT:
   PUSH.W
              A0
                               ; Save A0
              #10h,UCON
   XOR.B
                               Switch clock output pin (CLK1, CLKS1)
   INC.B
              DATA
                               ; Set position for reading next transmit data
   MOV.W
              DATA,A0
   MOV.B
              [A0],U1TB
                               ; Write next transmit data
   DEC.B
              CNT
                               Count down number of transfers
   JNZ
              S1T_INT_1
                                Keep interrupt enabled if more data to transmit
   MOV.B
              #00H,S1TIC
                               ; If last data, disable transmit interrupt
S1T_INT_1:
   POP.W
              A0
                               Restore A0
    REIT
```



#### 3.7 CTS/RTS Functions

The CTS (Clear To Send) function detects the status of the external IC and controls data transmit accordingly. When the CTS function is selected and the input level of the CTS pin goes to "L", the transfer clock is automatically generated and the transmit is started.

Because the level of the CTS pin is confirmed at the start of the transmit, if the level goes to "H" during the transmit, the transfer clock will be stopped after the current transmit is completed. When the CTS pin returns to the "L" level, the transfer clock will be generated again.

The RTS (Request To Send) function informs the external IC that the MCU is receive-ready. With the RTS function, the RTS pin will automatically output an "L" level when the MCU is receive-ready. The RTS pin goes to the "H" level at the first falling edge of the transfer clock.

There are three selections available for the CTS/RTS functions: CTS function only, RTS function only, both functions disabled.

\*: If both functions are disabled, the CTS/RTS pin can be used as a programmable input/output port.



Figure 14. Connection Example for CTS Function





Figure 15. Operation Timing Diagram of CTS Function



Figure 16. Connection Example for RTS Function





**Note:** The RTS signal goes to "L" when the receive is completed (rising edge of clock for the 8th bit), not when the received data is read from the receive buffer register. Therefore, the next data receive may start upon completion of the current data receive. In this case, read the received data in the receive buffer register by the time the next data receive completes (in order to avoid an overrun error).

Figure 17. Operation Timing Diagram of RTS Function



#### **Process Example for RTS Function**

In a main routine, enable the receive. In an interrupt process, read out data.

- 1. Select the RTS function and set each clock-synchronous serial I/O function.
- 2. Clear the receive interrupt request bit to be used, set the interrupt enable flag.
- Set the transmit enable bit and the receive enable bit and write a dummy data to the transmit buffer register.
   The RTS pin output level will then go to "L" to inform the transmit-side that the MCU is in the receive-ready status.
- 4. Read out the received data from the receive buffer register whenever receive interrupt is generated.
- 5. In order to receive the next data, write a dummy data to the transmit buffer register until the last data receive has completed.
- 6. Disable the receive interrupt after reading the last data from the receive buffer register.



Figure 18. General Flowchart of Process Example for RTS Function



#### Sample Program

Store received data in addresses 500h to 503h.

```
====== Main Program =======
MAIN:
   JSR
              INIT
                              ; Go to UARTO initial settings
   FSET
                              ; Enable interrupt
   MOV.B
              #05h,U0C1
                              ; Enable receive
   MOV.B
              ROL, UORB
                              ; Write dummy data = start receive
;====== UARTO Function Initial Settings =======
INIT:
   MOV.B
              #09h,UOMR
                              ; Select external clock
   MOV.B
              #04h,U0C0
                              : Enable RTS function
   MOV.B
              #00h,UCON
                              ; Disable UARTO continuous receive mode
   MOV.W
              #500h,DATA
                              ; Set position for storing received data
   MOV.B
              #4,CNT
                              ; Set number of transfers
              #01h,SORIC
   MOV.B
                              Set UARTO receive interrupt priority level
INT_END:
   RTS
                 UARTO Receive Interrupt Process
SOR_INT:
   PUSH.W
              A0
                              ; Save A0
   PUSH.B
              ROL
                              ; Save ROL
   MOV.W
              DATA,A0
   MOV.B
              UORB,[A0]
                              ; Read received data
   INC.B
              DATA
                              ; Set position for storing next receive data
   DEC.B
              CNT
                              Count down number of transfers
   JNZ
              SOR_INT_1
                              ; Keep interrupt enabled if more data to receive
   MOV.B
              #00H,SORIC
                              ; If last data, disable receive interrupt
SOR_INT_1:
   POP.B
              ROL
                              ; Restore ROL
   POP.W
              A0
                              ; Restore A0
   REIT
```



#### 3.8 How to Recover from an Error

Recovery procedures, such as initialization, must be executed if an error occurs during clock-synchronous serial I/O operations. In addition, after recovering from the error, it may be necessary to execute the resend process or resend request process with software.

#### **Detection of Receive Error**

The only detectable error in M16C/60 Series clock-synchronous serial I/O is the overrun error. An overrun error occurs when new data is lined up to the receive register before the previously received data is read out from the receive buffer register. When this error occurs, the last received data is stored in the receive buffer register. Also, the receive interrupt request bit is not set to "1". An overrun error causes the overrun error flag to go to "1".

### **Recovery from Error**

Execute recovery process according to the following flowchart. Any changes in this setup order may result in MCU malfunction.

All errors other than overrun error must be detected through software.

Table5. Recovery from Error

| Cause of Error             | Error Determination             | Recovery Method                       |
|----------------------------|---------------------------------|---------------------------------------|
| Overrun error              | Reference error flag            | Initialization                        |
|                            |                                 | Resend request process                |
| Incomplete transfer due to | Time out determined by software | Initialization                        |
| synchronization corruption |                                 | Resend process/Resend request process |
|                            |                                 | p. 66666                              |
| Other (abnormal data, etc) | Data determined by software     | Resend process/Resend request process |





Figure 19. Recovery Process (Initialization, etc.) Flowchart: Receive





Figure 20. Recovery Process (Initialization, etc.) Flowchart: Transmit



# 3.9 Communications Between MCU and EEPROM using I<sup>2</sup>C Mode

I<sup>2</sup>C Bus is a bi-directional, multi-master bus communication protocol developed by Philips, utilized widely in many ICs. (For more details, please refer to the Philips I<sup>2</sup>C Bus Specification.) The M16C/60 Series UART2 includes a simple I<sup>2</sup>C mode, enabling I<sup>2</sup>C bus interfaces (single-master/multi-master) when used in combination with the appropriate software.



Figure 21. Connection Example of MCU and EEPROM using I<sup>2</sup>C Mode

### Outline of I<sup>2</sup>C Bus

The I<sup>2</sup>C Bus enables serial interfacing using 2 lines; data (SDA) line and clock (SCL) line. Interface is achieved through indications from the levels and changing points of data and clock signals. I<sup>2</sup>C Bus interfaces are executed in the following order: master sends START condition, data is sent or received by master or slave, master sends STOP condition.





Figure 22. Timing Diagram of SCL and SDA lines

Read/write formats in I<sup>2</sup>C bus transfers are: START condition, 7-bit slave address, 1-bit read/write setting, 8-bit unit data, and STOP condition. In addition, during transfer, the data-receive side returns an acknowledge (SDA = "L") after each 8-bit transfer.



Figure 23. Read/Write formats in I<sup>2</sup>C bus transfers



#### Process Example in Simple I<sup>2</sup>C Mode

Please refer to the general description of I<sup>2</sup>C bus communication protocol and multi-master communication methods found in the "M16C/62 Group Application Note: Simple I<sup>2</sup>C Bus Mode".

The following sample program describes I<sup>2</sup>C Bus interfacing with an EEPROM, using an M16C/62 Group MCU as the single-master. (The read/write format is an example.)

#### **Process Example in Write Mode**

Write 1 byte of data from the CPU (master) to the EEPROM (slave).

### [Outline]



Figure 24. Timing Diagram of SCL and SDA lines in Write Mode

- 1. Select the simple I<sup>2</sup>C mode and set each clock-synchronous serial I/O function.
- 2. Master triggers START condition.
- 3. Master outputs slave address, checks for acknowledge.
- 4. Master outputs word address (write destination), checks for acknowledge.
- 5. Master outputs data, checks for acknowledge.
- 6. Master triggers STOP condition.

**Note:** When a NACK (No Acknowledge: SDA = "H") is detected during the acknowledge check, the rewrite process, etc., must be executed by software after the STOP condition is sent.



#### Sample Program

```
; Copyright 2003 Renesas Technology America, Inc.
; AND Renesas Solutions Corporation
; All rights reserved
;
MAIN:
    JSR INIT
                      ; Function Initialization
    JSR MASTER OUT
                      ; Write Mode Process
Function Initialization
INIT:
    BCLR PD7 0
                      ; Set P7_0 to input.
    BSET P7 0
                      ; P7 0 = "H"
    BCLR PD7 1
                      ; Set P7_1 to input.
                       ; P7_1 = "H"
    BSET P7_1
;
                      ; Select IIC mode.
    MOV.B #01h,U2SMR
    MOV.B #82h,U2SMR2
                      ; Validate ACK and NACK interrupts.
                      ; Enable SCL synchronous function.
    MOV.B #40h,U2SMR3
    MOV.B #00h,U2MR
                      ; Invalidate serial I/O = Port control
    MOV.B #90h, U2C0
                      ; Disable CTS/RTS function, select MSB first.
    MOV.B #10h,U2C1
                      ; Disable transfer
    MOV.B \#(80-1), U2BRG ; Transfer speed = 100Kbps
INIT_END:
    RTS
```



```
Write Mode Process
MASTER OUT:
      JSR MAKE_START ; START Condition Generation
MOV.B #0A0h,R0L ; Slave address + Data direct
JSR OUTPUT_DATA ; Slave address and data direct
                                  ; Slave address + Data direction bit (W) \,
            OUTPUT_DATA ; Slave address and data direction bit (W) output.

MASTER_OUT_10 ; C=1: No Acknowledge is detected.

ABORT ; Go to error process.
       JNC
             ABORT
       JSR
       FSET C
                                   ; C=1 -> Go to rewrite process, etc.
       RTS
MASTER OUT 10:
                                  ; Word address
       MOV.B #80h,R0L
       JSR OUTPUT_DATA
                                  ; Word address output.
            MASTER_OUT_11
                                  ; C=1: No Acknowledge is detected.
       JSR ABORT
                                  ; Go to error process.
       FSET C
                                   ; C=1 -> Go to rewrite process, etc.
       RTS
MASTER OUT 11:
                                  ; Write data (55H)
       MOV.B #55h,R0L
       MOV.B #55h,R0L
JSR OUTPUT_DATA
                                 ; Write data output.
; C=1: No Acknowledge is detected.
       JNC MASTER OUT 12
       JSR ABORT
                                   ; Go to error process.
       RTS
MASTER OUT 12:
       BTST
            P7 1
       JNC MASTER_OUT_12 ; Wait while SCL (P7_1) is "L".

BCLR TE_U2C1 ; Disable transmit

JSR MAKE_STOP ; STOP Condition Generation
       RTS
```



```
START Condition Generation
MAKE START:
         WAIT_5microSEC
    JSR
                         ; SCL = "H"
     JSR
         CHG scl H
MAKE ST1:
     BTST P7 1
                         ; Wait until SCL (P7 1) input goes to "H".
     JNC
         MAKE ST1
     BTST P7 0
                       ; SDA (P7_0) = "H" -> MAKE_ST2
; "L" output from SDA (P7_0).
         MAKE ST2
     JC
     JSR CHG sda_L
     MOV.B #00h, U2MR
                        ; Invalidate serial I/O = Port control.
     JSR CHG_scl_L
                         ; "L" output from SCL (P7 1).
     JSR WAIT_10microSEC
                         ; SDA = "H"
     JSR CHG sda H
     JSR WAIT 10microSEC
MAKE ST2:
         CHG sda L
     JSR
                         ; START condition output.
     JSR
          WAIT 5microSEC
     MOV.B #02h,U2MR
                         ; IIC mode settings.
     RTS
STOP Condition Generation
 *****************
;
MAKE STOP:
                        ; Disable transmit
         TE U2C1
     BCLR
     BCLR RE_U2C1
                        ; Disable receive
     BCLR PD7 0
                        ; Set SDA (P7 0) to input.
     MOV.B #00h,U2MR
                        ; Invalidate serial I/O = Port control
                        ; "L" output from SCL (P7 1).
     JSR CHG scl L
     JSR CHG_sda_L
                         ; "L" output from SDA (P7 \ 0).
        WAIT 5microSEC
     JSR
     JSR
         CHG\_scl\_H
                         ; SCL (P7 1) = "H"
MAKE_SP_1:
        P7 1
     BTST
     JNC
         MAKE SP 1
                         ; Wait until SCL (P7 1) goes to "H".
         WAIT 10microSEC
     JSR
         CHG sda H
     JSR
                        ; STOP condition output.
     RTS
```



```
Data Transmit
 *******************
OUTPUT DATA:
        TE U2C1
                             ; Enable transmit
     BSET
     BCLR IR_S2TIC
                       ; Clear NACK interrupt request bit.
     BCLR IR S2RIC
                        ; Clear ACK interrupt request bit.
                        ; Set SDA to "H" at ACK detection timing.
     OR.W #100h,R0
    MOV.W R0,U2TB
                              ; Set transmit data.
OUTPUT 1:
     BTST IR S2RIC
                        ; ACK interrupt request bit = 1?
                        ; Go to determination of NACK interrupt request
     JNC OUTPUT 2
bit.
          WAIT 10microSEC
     JSR
     FCLR
     RTS
                        ; Acknowledge is detected when C=0.
OUTPUT 2:
     BTST IR S2TIC
                        ; NACK interrupt request bit = 1?
         OUTPUT 1
                        ; Go to determination of ACK interrupt request
     JNC
bit.
     RTS
                         ; No Acknowledge is detected when C=1.
Stop Process (when NACK is detected)
ABORT:
     BCLR PD7 0
     BSET P7_0
                        ; SDA (P7 0) = "H"
     BCLR TE U2C1
                             ; Disable transmit
     MOV.B #00h,U2MR
                        ; Invalidate serial I/O = Port control
     JSR WAIT 5microSEC
     JSR MAKE STOP
                        ; STOP signal output.
     RTS
```



```
Port Switch Process
  *******************
                     ; SCL = "H"
CHG_scl_H:
    BCLR
       PD7_1
    RTS
CHG_scl_L:
                     ; "L" output from SCL.
    BCLR
       P7 1
    NOP
    BSET
       PD7 1
    RTS
                     ; SDA = "H"
CHG sda H:
    BCLR
        PD7_0
    RTS
CHG sda L:
                     ; "L" output from SDA.
    BCLR
       P7_0
    NOP
       PD7 0
    BSET
    RTS
Wait Time Process
WAIT_10microSEC:
    .MREPEAT
            40
    NOP
    .ENDR
WAIT_7_5_microSEC:
    .MREPEAT
            40
    NOP
    .ENDR
WAIT_5microSEC:
            40
    .MREPEAT
    NOP
    .ENDR
WAIT_2_5microSEC:
    .MREPEAT
            40
    NOP
    .ENDR
    RTS
```



### **Process Example in Read Mode**

CPU (master) reads 1 byte of data from the EEPROM (slave).



Figure 25. Timing Diagram of SCL and SDA lines in Read Mode

- 1. Select the simple I<sup>2</sup>C mode and set each clock-synchronous serial I/O function.
- 2. Master triggers START condition.
- 3. Master outputs slave address, checks for acknowledge.
- 4. Master outputs word address (read destination), checks for acknowledge.
- 5. Master triggers START condition.
- Master outputs slave address, checks for acknowledge.
- 7. Master inputs transferred data, finally outputs a NACK.
- 8. Master triggers STOP condition.

**Note:** When a NACK (No Acknowledge: SDA = "H") is detected during the acknowledge check, the rewrite process, etc., must be executed by software after the STOP condition is sent.



#### Sample Program

```
; Copyright 2003 Renesas Technology Corporation
; All rights reserved
;********************** Work RAM Area Reserve *********************
         .SECTION WORK, DATA .ORG 00400H
WORKRAM_TOP:
         .BLKB 1 ; Store receive data.
DATA:
WORKRAM END:
MAIN:
                       ; Function Initialization
    JSR INIT
    JSR MASTER OUT
                       ; Read Mode Process
Function Initialization
;
INIT:
    BCLR PD7 0
                       ; Set P7 0 to input.
    BSET P7 0
                       ; P7 0 = "H"
    BCLR PD7 1
                       ; Set P7_1 to input.
                       ; P7 1 = "H"
    BSET P7_1
;
                       ; Select IIC mode.
    MOV.B #01h, U2SMR
    MOV.B #82h, U2SMR2
                       ; Validate ACK and NACK interrupts.
                       ; Enable SCL synchronous function.
    MOV.B #40h,U2SMR3
                      ; Invalidate serial I/O = Port control
    MOV.B #00h,U2MR
    MOV.B #90h, U2C0
                       ; Disable CTS/RTS function, select MSB first.
    MOV.B #10h, U2C1
                       ; Disable transfer
    MOV.B \#(80-1), U2BRG ; Transfer speed = 100Kbps
INIT END:
    RTS
```



```
Read Mode Process
 *******************
MASTER IN:
                            ; START Condition Generation
          MAKE START
     JSR
     MOV.B #0A0h,R0L
                            ; Slave address + Data direction bit (W)
     JSR
           OUTPUT_DATA
                            ; Slave address and data direction bit (W) output.
      JNC
          MASTER IN 10
          ABORT
      JSR
     FSET C
                            ; C=1 -> Go to rewrite process, etc.
     RTS
MASTER IN 10:
     MOV.B #80h, R0L
                            ; Word address
     JSR
                            ; Word address output.
           OUTPUT DATA
     JNC
          MASTER_IN_11
     JSR
          ABORT
     FSET C
                             ; C=1 -> Go to rewrite process, etc.
     RTS
MASTER IN 11:
     BTST
      JNC
          MASTER_IN_11 ; Wait while SCL (P7_1) is "L".
     BCLR TE U2C1
                                  ; Disable transmit
     BCLR PD7 0
                            ; Set SDA (P7 0) to input.
     MOV.B #00h,U2MR
                            ; Invalidate serial I/O = Port control
                             ; SCL = "L"
     JSR
          CHG_scl_L
MASTER IN 12:
     BTST P7 0
      JNC MASTER IN 12
                            ; Wait while SDA (P7 0) is "L".
     JSR
          WAIT 10microSEC
     JSR
          MAKE START
                            ; START Condition Generation
     MOV.B #0A1h,R0L
                            ; Slave address + Data direction bit (R)
           OUTPUT_DATA
                            ; Slave address and data direction bit (R) output.
     JSR
      JNC
          MASTER_IN_13
           ABORT
     JSR
     FSET C
                            ; C=1 -> Go to rewrite process, etc.
     RTS
MASTER IN 13:
      BTST
          P7 1
      JNC
           MASTER IN 13
                          ; Wait while SCL (P7_1) is "L".
     BCLR
          TE U2C1
                               ; Disable transmit
      JSR
           INPUT DATA
                            ; Data Receive
     JSR
           MAKE STOP
                            ; STOP Condition Generation
     FCLR C
     RTS
```



```
START Condition Generation
MAKE START:
     JSR
          WAIT_5microSEC
                         ; SCL = "H"
     JSR
         CHG\_scl\_H
MAKE ST1:
     BTST
         P7 1
         MAKE ST1
                         ; Wait until SCL (P7 1) input goes to "H".
     JNC
     BTST P7 0
                         ; SDA (P7 0) = "H" -> MAKE ST2
     JC
         MAKE ST2
                         ; "L" output from SDA (P7\overline{0}).
     JSR CHG sda L
     MOV.B #00h,U2MR
                         ; Invalidate serial I/O = Port control.
     JSR CHG_scl_L
JSR WAIT_10microSEC
                          ; "L" output from SCL (P7 1).
                         ; SDA = "H"
     JSR CHG_sda_H
         WAIT_10microSEC
     JSR
MAKE ST2:
     JSR
         CHG sda L
                         ; START condition output.
          WAIT 5microSEC
     JSR
     MOV.B #02h, U2MR
                         ; IIC mode settings.
     RTS
STOP Condition Generation
MAKE_STOP:
     BCLR
         TE U2C1
                          ; Disable transmit
     BCLR RE_U2C1
                         ; Disable receive
     BCLR PD7 0
                         ; Set SDA (P7 0) to input.
     MOV.B #00h,U2MR
                         ; Invalidate serial I/O = Port control
     JSR CHG scl L
                         ; "L" output from SCL (P7 1).
                         ; "L" output from SDA (P7 0).
     JSR
         CHG sda L
        WAIT_5microSEC
     JSR
     JSR
          CHG scl H
                         ; Set SCL (P7_1) to input.
MAKE_SP_1:
     BTST
         P7_1
                         ; Wait until "H" is input to SCL (P7 1).
     JNC
          MAKE SP 1
     JSR
         WAIT 10microSEC
     JSR
          CHG sda H
                         ; STOP condition output.
     RTS
```



```
Data Transmit
 *******************
OUTPUT DATA:
         TE U2C1
                         ; Enable transmit
     BSET
     BCLR IR S2TIC
                          ; Clear NACK interrupt request bit.
                         ; Clear ACK interrupt request bit.
         IR S2RIC
     BCLR
                         ; Set SDA to "H" at ACK detection timing.
     OR.W #100h,R0
     MOV.W R0,U2TB
                          ; Set transmit data.
OUTPUT 1:
     BTST IR S2RIC
                         ; ACK interrupt request bit = 1?
     JNC OUTPUT 2
                          ; Go to determination of NACK interrupt request
bit.
          WAIT 10microSEC
     JSR
     FCLR
     RTS
                          ; Acknowledge is detected when C=0.
OUTPUT 2:
     BTST IR S2TIC
                          ; NACK interrupt request bit = 1?
         OUTPUT 1
                          ; Go to determination of ACK interrupt request
     JNC
bit.
     RTS
                          ; No Acknowledge is detected when C=1.
Data Receive
INPUT_DATA:
         TE U2C1
     BSET
                          ; Enable transmit
         RE U2C1
                         ; Enable receive
     BSET
                         ; Clear NACK interrupt request bit.
     BCLR IR S2TIC
     BCLR IR S2RIC
                         ; Clear ACK interrupt request bit.
     MOV.W #1FFh,U2TB
                         ; Generate no acknowledge (last data).
ID 10:
                          ; Wait until interrupt request bit is set to "1".
     BTST IR S2TIC
          ID 20
     JC
          IR_S2RIC
     BTST
     JNC ID_10
ID 20:
     MOV.B U2RB, DATA
                         ; Store received data.
     JSR WAIT 10microSEC
         TE U2C1
                         ; Disable transmit
     BCLR
          RE U2C1
                         ; Disable receive
     BCLR
     RTS
```



```
Stop Process (when NACK is detected)
*******************
ABORT:
    BCLR PD7 0
                   ; Set SDA (P7 0) to input.
    BSET P7_0
                    ; SDA (P7_0) = "H"
    BCLR TE U2C1
                    ; Disable transmit
    MOV.B #00h, U2MR
                    ; Invalidate serial I/O = Port control
    JSR WAIT_5microSEC
    JSR
      MAKE STOP
                    ; STOP signal output.
    RTS
Port Switch Process
*******************
                    ; SCL = "H"
CHG_scl_H:
    BCLR PD7_1
    RTS
CHG scl L:
                    ; "L" output from SCL.
    BCLR P7 1
    NOP
    BSET
       PD7 1
    RTS
                    ; SDA = "H"
CHG_sda_H:
    BCLR
       PD7 0
    RTS
CHG_sda L:
                    ; "L" output from SDA.
    BCLR
       P7 0
    NOP
    BSET
        PD7 0
    RTS
Wait Time Process
WAIT 10microSEC:
    .MREPEAT
           40
    NOP
    .ENDR
WAIT_7_5_microSEC:
    .MREPEAT
            40
    NOP
    .ENDR
WAIT 5microSEC:
    .MREPEAT
            40
    NOP
    .ENDR
```



### 4. Reference

Renesas Technology Corporation Semiconductor Home Page

http://www.renesas.com/

**E-mail Support** 

support\_apl@renesas.com



### **REVISION HISTORY**

| Rev. | Date         | Description |                      |  |
|------|--------------|-------------|----------------------|--|
|      |              | Page        | Summary              |  |
| 1.00 | Feb 25, 2004 | -           | First edition issued |  |
|      |              |             |                      |  |
|      |              |             |                      |  |



### Keep safety first in your circuit designs!

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

#### Notes regarding these materials

- These materials are intended as a reference to assist our customers in the selection of the Renesas
  Technology Corporation product best suited to the customer's application; they do not convey any
  license under any intellectual property rights, or any other rights, belonging to Renesas Technology
  Corporation or a third party.
- Renesas Technology Corporation assumes no responsibility for any damage, or infringement of any third-party's rights, originating in the use of any product data, diagrams, charts, programs, algorithms, or circuit application examples contained in these materials.
- All information contained in these materials, including product data, diagrams, charts, programs and
  algorithms represents information on products at the time of publication of these materials, and are
  subject to change by Renesas Technology Corporation without notice due to product improvements
  or other reasons. It is therefore recommended that customers contact Renesas Technology
  Corporation or an authorized Renesas Technology Corporation product distributor for the latest
  product information before purchasing a product listed herein.
  - The information described here may contain technical inaccuracies or typographical errors.
  - Renesas Technology Corporation assumes no responsibility for any damage, liability, or other loss rising from these inaccuracies or errors.
  - Please also pay attention to information published by Renesas Technology Corporation by various means, including the Renesas Technology Corporation Semiconductor home page (http://www.renesas.com).
- When using any or all of the information contained in these materials, including product data, diagrams, charts, programs, and algorithms, please be sure to evaluate all information as a total system before making a final decision on the applicability of the information and products. Renesas Technology Corporation assumes no responsibility for any damage, liability or other loss resulting from the information contained herein.
- Renesas Technology Corporation semiconductors are not designed or manufactured for use in a
  device or system that is used under circumstances in which human life is potentially at stake. Please
  contact Renesas Technology Corporation or an authorized Renesas Technology Corporation product
  distributor when considering the use of a product contained herein for any specific purposes, such as
  apparatus or systems for transportation, vehicular, medical, aerospace, nuclear, or undersea
  repeater use.
- The prior written approval of Renesas Technology Corporation is necessary to reprint or reproduce in whole or in part these materials.
- If these products or technologies are subject to the Japanese export control restrictions, they must be exported under a license from the Japanese government and cannot be imported into a country other than the approved destination.
  - Any diversion or reexport contrary to the export control laws and regulations of Japan and/or the country of destination is prohibited.
- Please contact Renesas Technology Corporation for further details on these materials or the products contained therein.