# 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.



# 3803 Group (Spec.H)

# Peripheral Function Application

# 1. Introduction

The following article introduces and shows an application example of peripheral function.

The explanation of this issue is applied to the following condition: Applicable MCU: 3803 Group (Spec.H)

# 2. Application

- 2.1 I/O port
- 2.2 Interrupt
- 2.3 Timer
- 2.4 Serial I/O
- 2.5 PWM
- 2.6 A-D converter
- 2.7 D-A converter
- 2.8 Watchdog timer
- 2.9 Reset
- 2.10 Clock generating circuit
- 2.11 Standby function
- 2.12 Flash memory mode



# 2.1 I/O port

This paragraph describes the setting method of I/O port relevant registers, notes etc.

## 2.1.1 Memory map



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



# 2.1.2 Relevant registers



Fig. 2.1.2 Structure of Port Pi (i = 0 to 6)



Fig. 2.1.3 Structure of Port Pi direction register (i = 0 to 6)





Fig. 2.1.4 Structure of Port Pi pull-up control register (i = 0, 1, 2, 4, 5, 6)



Fig. 2.1.5 Structure of Port P3 pull-up control register



# 2.1.3 Port Pi pull-up control register

Valid/Invalid of pull-up resistor can be set by the pull-up control register by a bit unit. Pull-up control is valid only when each direction register is set to the input mode.

Note: Ports P32 and P33 do not have pull-up control bit because they are N-channel open-drain output.

# 2.1.4 Terminate unused pins

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

| Pins             | Termination                                                                                        |
|------------------|----------------------------------------------------------------------------------------------------|
| P0, P1, P2, P3,  | $ullet$ Set to the input mode and connect each to Vcc or Vss through a resistor of 1 k $\Omega$ to |
| P4, P5, P6       | 10 kΩ.                                                                                             |
|                  | Set to the output mode and open at "L" or "H" output state.                                        |
| V <sub>REF</sub> | Connect to Vss (GND).                                                                              |
| AVss             | Connect to Vss (GND).                                                                              |
| Хоит             | Open (only when using external clock)                                                              |



#### 2.1.5 Notes on I/O port

## (1) Notes in standby state

In standby state\*1 for low-power dissipation, do not make input levels of an I/O port "undefined", especially for I/O ports of the N-channel open-drain.

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

When determining a resistance value, note the following points:

- External circuit
- Variation of output levels during the ordinary operation

When using built-in pull-up resistor, note on varied current values:

- When setting as an input port : Fix its input level
- When setting as an output port : Prevent current from flowing out to external

#### Reason

Even when setting as an output port with its direction register, when the content of the port latch is "1", the transistor becomes the OFF state, which causes the ports to be the high-impedance state. Note that the level becomes "undefined" depending on external circuits.

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

\*1 standby state: stop mode by executing **STP** instruction wait mode by executing **WIT** instruction

#### (2) Modifying output data with bit managing instruction

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

#### Reason

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

•As for bit which is set for input port:

The pin state is read in the CPU, and is written to this bit after bit managing.

•As for bit which is set for output port:

The bit value is read in the CPU, and is written to this bit after bit managing.

Note the following:

- •Even when a port which is set as an output port is changed for an input port, its port latch holds the output data.
- •As for a bit of which is set for an input port, its value may be changed even when not specified with a bit managing instruction in case where the pin state differs from its port latch contents.

\*2 Bit managing instructions: SEB and CLB instructions



#### 2.1.6 Termination of unused pins

# (1) Terminate unused pins

#### ① I/O ports:

• Set the I/O ports for the input mode and connect them to Vcc or Vss through each resistor of 1 k $\Omega$  to 10 k $\Omega$ .

Ports that permit the selecting of a built-in pull-up resistor can also use this resistor. Set the I/O ports for the output mode and open them at "L" or "H".

- When opening them in the output mode, the input mode of the initial status remains until the
  mode of the ports is switched over to the output mode by the program after reset. Thus, the
  potential at these pins is undefined and the power source current may increase in the input
  mode. With regard to an effects on the system, thoroughly perform system evaluation on the user
  side.
- Since the direction register setup may be changed because of a program runaway or noise, set direction registers by program periodically to increase the reliability of program.
- 2 The AVss pin when not using the A-D converter :
  - When not using the A-D converter, handle a power source pin for the A-D converter, AVss pin as follows:

AVss: Connect to the Vss pin.

#### (2) Termination remarks

#### ① I/O ports:

Do not open in the input mode.

#### Reason

- The power source current may increase depending on the first-stage circuit.
- An effect due to noise may be easily produced as compared with proper termination ② and shown on the above.

#### 2 I/O ports:

When setting for the input mode, do not connect to VCC or Vss directly.

#### Reason

If the direction register setup changes for the output mode because of a program runaway or noise, a short circuit may occur between a port and Vcc (or Vss).

# 3 I/O ports:

When setting for the input mode, do not connect multiple ports in a lump to VCC or Vss through a resistor.

# Reason

If the direction register setup changes for the output mode because of a program runaway or noise, a short circuit may occur between ports.

• At the termination of unused pins, perform wiring at the shortest possible distance (20 mm or less) from microcomputer pins.



# 2.2 Interrupt

This paragraph explains the registers setting method and the notes relevant to the interrupt.

#### 2.2.1 Memory map



Fig. 2.2.1 Memory map of registers relevant to interrupt

#### 2.2.2 Relevant registers



Fig. 2.2.2 Structure of Interrupt source selection register



| b7 b6 b5 b |   |                                            | rrupt edge selection reg<br>FEDGE: address 003A16            |                                                        |                                                          |                                                        |   |   |   |
|------------|---|--------------------------------------------|--------------------------------------------------------------|--------------------------------------------------------|----------------------------------------------------------|--------------------------------------------------------|---|---|---|
|            |   | b                                          | Name                                                         | Functions                                              | At reset                                                 | R                                                      | W |   |   |
|            |   | 0                                          | INTo active edge selection bit                               | 0: Falling edge active 1: Rising edge active           | 0                                                        | 0                                                      | 0 |   |   |
|            |   | 1                                          | INT <sub>1</sub> active edge selection bit                   | 0: Falling edge active 1: Rising edge active           | 0                                                        | 0                                                      | 0 |   |   |
|            |   | 2                                          | Nothing is arranged disabled bit. When the contents are "0". | 0                                                      | 0                                                        | ×                                                      |   |   |   |
|            |   | 3                                          | INT <sub>2</sub> active edge selection bit                   | 0: Falling edge active 1: Rising edge active           | 0                                                        | 0                                                      | 0 |   |   |
|            | 4 | INT <sub>3</sub> active edge selection bit | 0: Falling edge active 1: Rising edge active                 | 0                                                      | 0                                                        | 0                                                      |   |   |   |
|            |   | 5                                          | INT <sub>4</sub> active edge selection bit                   | 0: Falling edge active<br>1: Rising edge active        | 0                                                        | 0                                                      | 0 |   |   |
|            |   |                                            |                                                              |                                                        | INT <sub>0</sub> , INT <sub>4</sub> interrupt switch bit | 0: INT00, INT40 interrupt<br>1: INT01, INT41 interrupt | 0 | 0 | 0 |
|            |   | 7                                          | Nothing is arranged disabled bit. When the contents are "0". | for this bit. This is a write his bit is read out, the | 0                                                        | 0                                                      | × |   |   |

Fig. 2.2.3 Structure of Interrupt edge selection register



Fig. 2.2.4 Structure of Interrupt request register 1





Fig. 2.2.5 Structure of Interrupt request register 2



Fig. 2.2.6 Structure of Interrupt control register 1



| b7 b6 b5 b4 b3 b2 b1 b0 |   | rrupt control register 2<br>DN2 : address 003F16)                  |                                                              |          |   |   |
|-------------------------|---|--------------------------------------------------------------------|--------------------------------------------------------------|----------|---|---|
|                         | b | Name                                                               | Functions                                                    | At reset | R | W |
|                         | 0 | CNTR <sub>0</sub> interrupt enable bit                             | 0 : Interrupt disabled<br>1 : Interrupt enabled              | 0        | 0 | 0 |
|                         | 1 | CNTR <sub>1</sub> / Serial I/O3<br>receive interrupt<br>enable bit | 0 : Interrupt disabled<br>1 : Interrupt enabled              | 0        | 0 | 0 |
|                         | 2 | Serial I/O2/ Timer Z interrupt enable bit                          | 0 : Interrupt disabled<br>1 : Interrupt enabled              | 0        | 0 | 0 |
|                         | 3 | INT2 interrupt enable bit                                          | 0 : Interrupt disabled<br>1 : Interrupt enabled              | 0        | 0 | 0 |
|                         | 4 | INT₃ interrupt<br>enable bit                                       | 0 : Interrupt disabled                                       | 0        | 0 | 0 |
|                         | 5 | INT4/CNTR2 interrupt enable bit                                    | 0 : Interrupt disabled<br>1 : Interrupt enabled              | 0        | 0 | 0 |
|                         | 6 | AD converter/Serial I/O3 transmit interrupt enable bit             | 0 : Interrupt disabled 1 : Interrupt enabled                 | 0        | 0 | 0 |
| <u> </u>                | 7 |                                                                    | for this bit. Do not write "1" bit is read out, the contents | 0        | 0 | 0 |

Fig. 2.2.7 Structure of Interrupt control register 2



#### 2.2.3 Interrupt source

The 3803 group (Spec. H) 's interrupts are a type of vector and occur by 16 sources among 21 sources: eight external, twelve internal, and one software. These are vector interrupts with a fixed priority system. Accordingly, when two or more interrupt requests occur during the same sampling, the higher-priority interrupt is accepted first. This priority is determined by hardware, but a variety of priority processing can be performed by software, using an interrupt enable bit and an interrupt disable flag.

For interrupt sources, vector addresses and interrupt priority, refer to Tables 2.2.1.

Table 2.2.1 Interrupt sources, vector addresses and priority

| Interrupt Source            | Priority | Vector Addre | sses (Note 1)      | Interrupt Request                                                                    | Remarks                                     |
|-----------------------------|----------|--------------|--------------------|--------------------------------------------------------------------------------------|---------------------------------------------|
| interrupt Source            | Filolity | High         | Low                | Generating Conditions                                                                | Nemarks                                     |
| Reset (Note 2)              | 1        | FFFD16       | FFFC16             | At reset                                                                             | Non-maskable                                |
| INT <sub>0</sub>            | 2        | FFFB16       | FFFA16             | At detection of either rising or falling edge of INTo input                          | External interrupt (active edge selectable) |
| Timer Z                     |          |              |                    | At timer Z underflow                                                                 |                                             |
| INT1                        | 3        | FFF916       | FFF816             | At detection of either rising or falling edge of INT1 input                          | External interrupt (active edge selectable) |
| Serial I/O1 reception       | 4        | FFF716       | FFF616             | At completion of serial I/O1 data reception                                          | Valid when serial I/O1 is selected          |
| Serial I/O1<br>transmission | 5        | FFF516       | FFF416             | At completion of serial I/O1 transmission shift or when transmission buffer is empty | Valid when serial I/O1 is selected          |
| Timer X                     | 6        | FFF316       | FFF216             | At timer X underflow                                                                 |                                             |
| Timer Y                     | 7        | FFF116       | FFF016             | At timer Y underflow                                                                 |                                             |
| Timer 1                     | 8        | FFEF16       | FFEE16             | At timer 1 underflow                                                                 | STP release timer underflow                 |
| Timer 2                     | 9        | FFED16       | FFEC16             | At timer 2 underflow                                                                 |                                             |
| CNTR <sub>0</sub>           | 10       | FFEB16       | FFEA <sub>16</sub> | At detection of either rising or falling edge of CNTRo input                         | External interrupt (active edge selectable) |
| CNTR <sub>1</sub>           | 11       | FFE916       | FFE816             | At detection of either rising or falling edge of CNTR1 input                         | External interrupt (active edge selectable) |
| Serial I/O3 reception       |          |              |                    | At completion of serial I/O3 data reception                                          | Valid when serial I/O3 is selected          |
| Serial I/O2                 | 12       | FFE716       | FFE616             | At completion of serial I/O2 data transmission or reception                          | Valid when serial I/O2 is selected          |
| Timer Z                     |          |              |                    | At timer Z underflow                                                                 |                                             |
| INT2                        | 13       | FFE516       | FFE416             | At detection of either rising or falling edge of INT2 input                          | External interrupt (active edge selectable) |
| INT3                        | 14       | FFE316       | FFE216             | At detection of either rising or falling edge of INT3 input                          | External interrupt (active edge selectable) |
| INT4                        | 15       | FFE116       | FFE016             | At detection of either rising or falling edge of INT4 input                          | External interrupt (active edge selectable) |
| CNTR2                       |          |              |                    | At detection of either rising or falling edge of CNTR2 input                         | External interrupt (active edge selectable) |
| A-D converter               | 16       | FFDF16       | FFDE16             | At completion of A-D conversion                                                      |                                             |
| Serial I/O3<br>transmission |          |              |                    | At completion of serial I/O3 transmission shift or when transmission buffer is empty | Valid when serial I/O3 is selected          |
| BRK instruction             | 17       | FFDD16       | FFDC16             | At BRK instruction execution                                                         | Non-maskable software interrupt             |

Notes 1: Vector addresses contain interrupt jump destination addresses.

<sup>2:</sup> Reset function in the same way as an interrupt with the highest priority.



#### 2.2.4 Interrupt operation

When an interrupt request is accepted, the contents of the following registers just before acceptance of the interrupt requests are automatically pushed onto the stack area in the order of ①, ② and ③.

- ①High-order contents of program counter (PCH)
- ②Low-order contents of program counter (PC<sub>L</sub>)
- 3 Contents of processor status register (PS)

After the contents of the above registers are pushed onto the stack area, the accepted interrupt vector address enters the program counter and consequently the interrupt processing routine is executed. When the RTI instruction is executed at the end of the interrupt processing routine, the contents of the above registers pushed onto the stack area are restored to the respective registers in the order of ③, ② and ①; and the microcomputer resumes the processing executed just before acceptance of the interrupts. Figure 2.2.8 shows an interrupt operation diagram.



Fig. 2.2.8 Interrupt operation diagram



#### (1) Processing upon acceptance of interrupt request

Upon acceptance of an interrupt request, the following operations are automatically performed.

- 1) The processing being executed is stopped.
- The contents of the program counter and the processor status register are pushed onto the stack area. Figure 2.2.9 shows the changes of the stack pointer and the program counter upon acceptance of an interrupt request.
- ③Concurrently with the push operation, the jump destination address (the beginning address of the interrupt processing routine) of the occurring interrupt stored in the vector address is set in the program counter, then the interrupt processing routine is executed.

Accordingly, for executing the interrupt processing routine, it is necessary to set the jump destination address in the vector area corresponding to each interrupt.



Fig. 2.2.9 Changes of stack pointer and program counter upon acceptance of interrupt request



# (2) Timing after acceptance of interrupt request

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

Figure 2.2.10 shows the time up to execution of interrupt processing routine and Figure 2.2.11 shows the timing chart after acceptance of interrupt request.



Fig. 2.2.10 Time up to execution of interrupt processing routine



Fig. 2.2.11 Timing chart after acceptance of interrupt request



#### 2.2.5 Interrupt control

The acceptance of all interrupts, excluding the BRK instruction interrupt, can be controlled by the interrupt request bit, interrupt enable bit, and an interrupt disable flag, as described in detail below. Figure 2.2.12 shows an interrupt control diagram.



Fig. 2.2.12 Interrupt control diagram

The interrupt request bit, interrupt enable bit and interrupt disable flag function independently and do not affect each other. An interrupt is accepted when all the following conditions are satisfied.

- ●Interrupt request bit ........... "1"
- ●Interrupt enable bit ........... "1"
- ●Interrupt disable flag ...... "0"

Though the interrupt priority is determined by hardware, a variety of priority processing can be performed by software using the above bits and flag. Tables 2.2.2 shows list of interrupt control bits according to the interrupt source.

# (1) Interrupt request bits

The interrupt request bits are allocated to the interrupt request register 1 (address  $003C_{16}$ ) and interrupt request register 2 (address  $003D_{16}$ ).

The occurrence of an interrupt request causes the corresponding interrupt request bit to be set to "1". The interrupt request bit is held in the "1" state until the interrupt is accepted. When the interrupt is accepted, this bit is automatically cleared to "0".

Each interrupt request bit can be set to "0", but cannot be set to "1", by software.

#### (2) Interrupt enable bits

The interrupt enable bits are allocated to the interrupt control register 1 (address 003E<sub>16</sub>) and the interrupt control register 2 (address 003F<sub>16</sub>).

The interrupt enable bits control the acceptance of the corresponding interrupt request.

When an interrupt enable bit is "0", the corresponding interrupt request is disabled. If an interrupt request occurs when this bit is "0", the corresponding interrupt request bit is set to "1" but the interrupt is not accepted. In this case, unless the interrupt request bit is set to "0" by software, the interrupt request bit remains in the "1" state.

When an interrupt enable bit is "1", the corresponding interrupt is enabled. If an interrupt request occurs when this bit is "1", the interrupt is accepted (when interrupt disable flag = "0").

Each interrupt enable bit can be set to "0" or "1" by software.



#### (3) Interrupt disable flag

The interrupt disable flag is allocated to bit 2 of the processor status register. The interrupt disable flag controls the acceptance of interrupt request except BRK instruction.

When this flag is "1", the acceptance of interrupt requests is disabled. When the flag is "0", the acceptance of interrupt requests is enabled. This flag is set to "1" with the SEI instruction and is set to "0" with the CLI instruction.

When a main routine branches to an interrupt processing routine, this flag is automatically set to "1", so that multiple interrupts are disabled. To use multiple interrupts, set this flag to "0" with the CLI instruction within the interrupt processing routine. Figure 2.2.13 shows an example of multiple interrupts.

Table 2.2.2 List of interrupt bits according to interrupt source

| Interrupt course                         | Interrupt          | enable bit | Interrupt request bit |     |  |
|------------------------------------------|--------------------|------------|-----------------------|-----|--|
| Interrupt source                         | Address            | Bit        | Address               | Bit |  |
| INT <sub>0</sub> /Timer Z                | 003E <sub>16</sub> | b0         | 003C <sub>16</sub>    | b0  |  |
| INT <sub>1</sub>                         | 003E <sub>16</sub> | b1         | 003C <sub>16</sub>    | b1  |  |
| Serial I/O1 reception                    | 003E <sub>16</sub> | b2         | 003C <sub>16</sub>    | b2  |  |
| Serial I/O1 transmission                 | 003E <sub>16</sub> | b3         | 003C <sub>16</sub>    | b3  |  |
| Timer X                                  | 003E <sub>16</sub> | b4         | 003C <sub>16</sub>    | b4  |  |
| Timer Y                                  | 003E <sub>16</sub> | b5         | 003C <sub>16</sub>    | b5  |  |
| Timer 1                                  | 003E <sub>16</sub> | b6         | 003C <sub>16</sub>    | b6  |  |
| Timer 2                                  | 003E <sub>16</sub> | b7         | 003C <sub>16</sub>    | b7  |  |
| CNTR <sub>0</sub>                        | 003F <sub>16</sub> | b0         | 003D <sub>16</sub>    | b0  |  |
| CNTR <sub>1</sub> /Serial I/O3 reception | 003F <sub>16</sub> | b1         | 003D <sub>16</sub>    | b1  |  |
| Serial I/O2/Timer Z                      | 003F <sub>16</sub> | b2         | 003D <sub>16</sub>    | b2  |  |
| INT <sub>2</sub>                         | 003F <sub>16</sub> | b3         | 003D <sub>16</sub>    | b3  |  |
| INT <sub>3</sub>                         | 003F <sub>16</sub> | b4         | 003D <sub>16</sub>    | b4  |  |
| INT4/CNTR2                               | 003F <sub>16</sub> | b5         | 003D <sub>16</sub>    | b5  |  |
| A-D converter/Serial I/O3 transmission   | 003F <sub>16</sub> | b6         | 003D <sub>16</sub>    | b6  |  |





Fig. 2.2.13 Example of multiple interrupts



#### 2.2.6 INT interrupt

The INT interrupt requests is generated when the microcomputer detects a level change of each INT pin (INT<sub>0</sub>-INT<sub>4</sub>).

#### (1) Active edge selection

INT<sub>0</sub>-INT<sub>4</sub> can be selected from either a falling edge or rising edge detection as an active edge by the interrupt edge selection register. In the "0" state, the falling edge of the corresponding pin is detected. In the "1" state, the rising edge of the corresponding pin is detected.

# (2) INT<sub>0</sub>, INT<sub>4</sub> interrupt source selection

When using the following interrupt source, select which of the interrupt source by the interrupt source selection register (address 39<sub>16</sub>). (Set these bits to "0" when using INT.)

- •INTo or timer Z (bit 0)
- •INT4 or CNTR2 (bit 4)



## 2.2.7 Notes on interrupts

## (1) Change of relevant register settings

When the setting of the following registers or bits is changed, the interrupt request bit may be set to "1". When not requiring the interrupt occurrence synchronized with these setting, take the following sequence.

- •Interrupt edge selection register (address 003A<sub>16</sub>)
- •Timer XY mode register (address 0023<sub>16</sub>)
- •Timer Z mode register (address 002A<sub>16</sub>)

Set the above listed registers or bits as the following sequence.



Fig. 2.2.14 Sequence of changing relevant register

#### ■ Reason

When setting the followings, the interrupt request bit may be set to "1".

•When setting external interrupt active edge

Concerned register: Interrupt edge selection register (address 003A<sub>16</sub>)

Timer XY mode register (address 0023<sub>16</sub>)

Timer Z mode register (address 002A<sub>16</sub>)

•When switching interrupt sources of an interrupt vector address where two or more interrupt sources are allocated.

Concerned register: Interrupt source selection register (address 0039<sub>16</sub>)



# (2) Check of interrupt request bit

• When executing the BBC or BBS instruction to an interrupt request bit of an interrupt request register immediately after this bit is set to "0", execute one or more instructions before executing the BBC or BBS instruction.



Fig. 2.2.15 Sequence of check of interrupt request bit

#### ■ Reason

If the BBC or BBS instruction is executed immediately after an interrupt request bit of an interrupt request register is cleared to "0", the value of the interrupt request bit before being cleared to "0" is read.



# 2.3 Timer

This paragraph explains the registers setting method and the notes relevant to the timers.

#### 2.3.1 Memory map



Fig. 2.3.1 Memory map of registers relevant to timers



#### 2.3.2 Relevant registers



Fig. 2.3.2 Structure of Prescaler 12, Prescaler X, Prescaler Y



Fig. 2.3.3 Structure of Timer 1





Fig. 2.3.4 Structure of Timer 2, Timer X, Timer Y



Fig. 2.3.5 Structure of Timer Z (low-order, high-order)





Fig. 2.3.6 Structure of Timer XY mode register

Table 2.3.1 CNTR<sub>0</sub> /CNTR<sub>1</sub> active edge switch bit function

| Timer X /Timer Y operation   | CNTR₀ / CNTR₁ active edge switch bit                                                 |
|------------------------------|--------------------------------------------------------------------------------------|
| modes                        | (bits 2, 6 of address 0023 <sub>16</sub> ) contents                                  |
| Timer mode                   | "0" CNTR <sub>0</sub> / CNTR <sub>1</sub> interrupt request occurrence: Falling edge |
|                              | ; No influence to timer count                                                        |
|                              | "1" CNTR <sub>0</sub> / CNTR <sub>1</sub> interrupt request occurrence: Rising edge  |
|                              | ; No influence to timer count                                                        |
| Pulse output mode            | "0" Pulse output start: Beginning at "H" level                                       |
|                              | CNTR₀ / CNTR₁ interrupt request occurrence: Falling edge                             |
|                              | "1" Pulse output start: Beginning at "L" level                                       |
|                              | CNTR₀ / CNTR₁ interrupt request occurrence: Rising edge                              |
| Event counter mode           | "0" Timer X / Timer Y: Rising edge count                                             |
|                              | CNTR₀ / CNTR₁ interrupt request occurrence: Falling edge                             |
|                              | "1" Timer X / Timer Y: Falling edge count                                            |
|                              | CNTR₀ / CNTR₁ interrupt request occurrence: Rising edge                              |
| Pulse width measurement mode | "0" Timer X / Timer Y: "H" level width measurement                                   |
|                              | CNTR₀ / CNTR₁ interrupt request occurrence: Falling edge                             |
|                              | "1" Timer X / Timer Y: "L" level width measurement                                   |
|                              | CNTR₀ / CNTR₁ interrupt request occurrence: Rising edge                              |





Fig. 2.3.7 Structure of Timer Z mode register



Table 2.3.2 CNTR2 active edge switch bit function

| Timer Z                          |          | CNTR <sub>2</sub> active edge switch bit                             |
|----------------------------------|----------|----------------------------------------------------------------------|
| operation modes                  |          | (bit 5 of address 002A <sub>16</sub> ) contents                      |
| Timer mode                       | "0" C    | NTR <sub>2</sub> interrupt request occurrence: Falling edge          |
|                                  |          | ; No influence to timer count                                        |
|                                  | "1" C    | NTR <sub>2</sub> interrupt request occurrence: Rising edge           |
|                                  |          | ; No influence to timer count                                        |
| Event counter mode               | "0" Ti   | imer Z: Rising edge count                                            |
|                                  | С        | NTR2 interrupt request occurrence: Falling edge                      |
|                                  | "1" Ti   | imer Z: Falling edge count                                           |
|                                  | С        | NTR2 interrupt request occurrence: Rising edge                       |
| Pulse output mode                | "0" Pi   | ulse output start: Beginning at "H" level                            |
|                                  | C        | NTR2 interrupt request occurrence: Falling edge                      |
|                                  | "1" Pı   | ulse output start: Beginning at "L" level                            |
|                                  | С        | NTR2 interrupt request occurrence: Rising edge                       |
| Pulse period measurement mode    | "0"   Ti | imer Z : Term from one falling edge to next falling edge measurement |
|                                  | С        | NTR2 interrupt request occurrence: Falling edge                      |
|                                  | "1" Ti   | imer Z: Term from one rising edge to next rising edge measurement    |
|                                  | С        | NTR2 interrupt request occurrence: Rising edge                       |
| Pulse width measurement mode     | "0"   Ti | imer Z: "H" level width measurement                                  |
|                                  | С        | NTR2 interrupt request occurrence: Falling edge                      |
|                                  | "1" Ti   | imer Z: "L" level width measurement                                  |
|                                  | С        | NTR2 interrupt request occurrence: Rising edge                       |
| Programmable one-shot generating | "0"   Ti | imer Z: Pulse output start from "L" level, and "H" level one-shot    |
| mode                             |          | pulse is output.                                                     |
|                                  |          | NTR2 interrupt request occurrence: Falling edge                      |
|                                  | "1" Ti   | imer Z: Pulse output start from "H" level, and "L" level one-shot    |
|                                  |          | pulse is output.                                                     |
|                                  | C        | NTR2 interrupt request occurrence: Rising edge                       |





Fig. 2.3.8 Structure of Timer 12, X count source selection register



Fig. 2.3.9 Structure of Timer Y, Z count source selection register



| b7 b6 b5 b4 b3 b2 b1 b0 |     | rrupt source selection reg<br>SEL: address 003916)                   | ister                                                        |          |   |   |
|-------------------------|-----|----------------------------------------------------------------------|--------------------------------------------------------------|----------|---|---|
|                         | b   | Name                                                                 | Functions                                                    | At reset | R | W |
|                         | 0   |                                                                      | 0: INT₀ interrupt<br>1: Timer Z interrupt                    | 0        | 0 | 0 |
|                         | - 1 |                                                                      | D: Serial I/O2 interrupt<br>I: Timer Z interrupt             | 0        | 0 | 0 |
|                         | - 2 | Nothing is arranged fo                                               | or these bits. Do not write n these bits are read out,       | 0        | 0 | 0 |
|                         | _ 3 | the contents are "0".                                                | ir these bits are read out,                                  | 0        | 0 | 0 |
|                         | 4   |                                                                      | D: INT4 interrupt<br>I: CNTR2 interrupt                      | 0        | 0 | 0 |
|                         | - 5 |                                                                      | or this bit. Do not write "1" oit is read out, the contents  | 0        | 0 | 0 |
| \                       | _ 6 |                                                                      | D: CNTR1 interrupt<br>1: Serial I/O3 receive<br>interrupt    | 0        | 0 | 0 |
|                         | 7   | AD converter/Serial (// I/O3 transmit interrupt source selection bit | D: A-D converter interrupt 1: Serial I/O3 transmit interrupt | 0        | 0 | 0 |

Fig. 2.3.10 Structure of Interrupt source selection register





Fig. 2.3.11 Structure of Interrupt request register 1



Fig. 2.3.12 Structure of Interrupt request register 2



| Interrupt control reg   | iste | er 1_                                                          |                                                 |          |   |   |
|-------------------------|------|----------------------------------------------------------------|-------------------------------------------------|----------|---|---|
| b7 b6 b5 b4 b3 b2 b1 b0 |      | rrupt control register 1<br>DN1 : address 003E <sub>16</sub> ) |                                                 |          |   |   |
|                         | b    | Name                                                           | Functions                                       | At reset | R | W |
|                         | 0    | INT <sub>0</sub> /Timer Z interrupt enable bit                 | 0 : Interrupt disabled<br>1 : Interrupt enabled | 0        | 0 | 0 |
|                         | 1    | INT₁ interrupt<br>enable bit                                   | 0 : Interrupt disabled<br>1 : Interrupt enabled | 0        | 0 | 0 |
|                         | 2    | Serial I/O1 receive interrupt enable bit                       | 0 : Interrupt disabled<br>1 : Interrupt enabled | 0        | 0 | 0 |
|                         | . 3  | Serial I/O1 transmit interrupt enable bit                      | 0 : Interrupt disabled<br>1 : Interrupt enabled | 0        | 0 | 0 |
|                         | 4    | Timer X interrupt enable bit                                   | 0 : Interrupt disabled 1 : Interrupt enabled    | 0        | 0 | 0 |
|                         | 5    | Timer Y interrupt enable bit                                   | 0 : Interrupt disabled<br>1 : Interrupt enabled | 0        | 0 | 0 |
|                         | 6    | Timer 1 interrupt enable bit                                   | 0 : Interrupt disabled<br>1 : Interrupt enabled | 0        | 0 | 0 |
| <u> </u>                | 7    | Timer 2 interrupt enable bit                                   | 0 : Interrupt disabled<br>1 : Interrupt enabled | 0        | 0 | 0 |

Fig. 2.3.13 Structure of Interrupt control register 1



Fig. 2.3.14 Structure of Interrupt control register 2



#### 2.3.3 Timer application examples

#### (1) Basic functions and uses

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

When a certain time, by setting a count value to each timer, has passed, the timer interrupt request occurs.

<Use>

- Generation of an output signal timing
- •Generation of a wait time

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

The value of the timer latch is automatically written to the corresponding timer each time the timer underflows, and each timer interrupt request occurs in cycles.

<Use>

- Generation of cyclic interrupts
- •Clock function (measurement of 250 ms); see Application example 1
- •Control of a main routine cycle

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

The output level of the CNTR pin is inverted each time the timer underflows (in the pulse output mode).

<Use>

- •Piezoelectric buzzer output; see Application example 2
- •Generation of the remote control carrier waveforms

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

External pulses input to the CNTR pin are counted as the timer count source (in the event counter mode).

<Use>

- •Frequency measurement; see Application example 3
- Division of external pulses
- •Generation of interrupts due to a cycle using external pulses as the count source; count of a reel pulse

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

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

<Use>

- •Measurement of external pulse frequency (measurement of pulse width of FG pulse\* for a motor); see Application example 4
- •Measurement of external pulse duty (when the frequency is fixed)

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

# [Function 6] Output of Arbitrary waveform (Timer Z)

The value which is set to the output level latch is output from the CNTR pin each time the timer underflows. (programmable waveform generating mode)

#### [Function 7] One-shot pulse output by external trigger (Timer Z)

The value of timer latch is set to timer by trigger signal which is input from the INT pin, and timer is counted down. When trigger signal is input, "H" or "L" is output from the CNTR pin at the same time, and "L" or "H" is output by underflow of timer. (programmable one-shot generating mode)



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

**Outline**: The input clock is divided by the timer so that the clock can count up at 250 ms intervals. **Specifications**: •The clock  $f(X_{IN}) = 4.19$  MHz ( $2^{22}$  Hz) is divided by the timer.

•The clock is counted up in the process routine of the timer X interrupt which occurs at 250 ms intervals.

Figure 2.3.15 shows the timers connection and setting of division ratios; Figure 2.3.16 shows the relevant registers setting; Figure 2.3.17 shows the control procedure.



Fig. 2.3.15 Timers connection and setting of division ratios



Fig. 2.3.16 Relevant registers setting





Fig. 2.3.17 Control procedure



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

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

**Specifications**: •The rectangular waveform, dividing the clock  $f(X_{IN}) = 8$  MHz into about 2 kHz (2049 Hz), is output from the P4<sub>7</sub>/CNTR<sub>2</sub> pin.

•The level of the P47/CNTR2 pin is fixed to "H" while a piezoelectric buzzer output stops.

Figure 2.3.18 shows a peripheral circuit example, and Figure 2.3.19 shows the timers connection and setting of division ratios. Figure 2.3.20 shows the relevant registers setting, and Figure 2.3.21 shows the control procedure.



Fig. 2.3.18 Peripheral circuit example



Fig. 2.3.19 Timers connection and setting of division ratios





Fig. 2.3.20 Relevant registers setting





Fig. 2.3.21 Control procedure



## (4) Timer application example 3: Frequency measurement

**Outline**: The following two values are compared to judge whether the frequency is within a valid range.

- •A value by counting pulses input to P55/CNTR1 pin with the timer.
- •A reference value

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

- •The clock f(XIN) = 8 MHz is dividing by the timer 1, and the interrupt request occurs at about 2 ms intervals.
- •A count value is read out at about 2 ms intervals, the timer 1 interrupt interval. When the count value is 28 to 40, it is judged that the input pulse is valid.
- •Because the timer is a down-counter, the count value is compared with 227 to 215 (Note).

**Note**: 227 to 215 =  $\{255 \text{ (initial value of counter)} - 28\}$  to  $\{255 - 40\}$ ; 28 to 40 means the number of valid count value.

Figure 2.3.22 shows the judgment method of valid/invalid of input pulses; Figure 2.3.23 shows the relevant registers setting; Figure 2.3.24 shows the control procedure.



Fig. 2.3.22 Judgment method of valid/invalid of input pulses





Fig. 2.3.23 Relevant registers setting





Fig. 2.3.24 Control procedure



## (5) Timer application example 4: Measurement of FG pulse width for motor

**Outline**: The timer Z counts the "H" level width of the pulses input to the P4<sub>7</sub>/CNTR<sub>2</sub> pin. An underflow is detected by the timer Z interrupt and an end of the input pulse "H" level is detected by the P4<sub>7</sub>/CNTR<sub>2</sub> interrupt.

Specifications: •The timer Z counts the "H" level width of the FG pulse input to the P47/CNTR2 pin.

## <Example>

When the clock frequency is 8 MHz, the count source is 2  $\mu$ s, which is obtained by dividing the clock frequency by 16. Measurement can be made up to 131.072 ms in the range of FFFF<sub>16</sub> to  $0000_{16}$ .

Figure 2.3.25 shows the timers connection and setting of division ratio; Figure 2.3.26 shows the relevant registers setting; Figure 2.3.27 and Figure 2.3.28 show the control procedure.



Fig. 2.3.25 Timers connection and setting of division ratios





Fig. 2.3.26 Relevant registers setting





Fig. 2.3.27 Control procedure (1)





Fig. 2.3.28 Control procedure (2)



## 2.3.4 Notes on timer

- If a value n (between 0 and 255) is written to a timer latch, the frequency division ratio is 1/(n+1).
- When switching the count source by the timer 12, X and Y count source selection bits, the value of timer count is altered in unconsiderable amount owing to generating of thin pulses in the count input signals.

Therefore, select the timer count source before set the value to the prescaler and the timer.



## 2.4 Serial I/O

This paragraph explains the registers setting method and the notes relevant to Serial I/O.

# 2.4.1 Memory map



Fig. 2.4.1 Memory map of registers relevant to Serial I/O



## 2.4.2 Relevant registers



Fig. 2.4.2 Structure of Transmit/Receive buffer register 1 and Transmit/Receive buffer register 3



Fig. 2.4.3 Structure of Serial I/O1 status register and Serial I/O3 status register



|                         |     | ster                                                    |                                                                                                                                                                                           |          |   |   |
|-------------------------|-----|---------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|---|---|
| b7 b6 b5 b4 b3 b2 b1 b0 | Se  | rial I/O1 control register                              |                                                                                                                                                                                           |          |   |   |
| ┖ <del>╷╏┍</del> ╏      |     | IO1CON: address 001A1                                   | 6)                                                                                                                                                                                        |          |   |   |
|                         | b   | Name                                                    | Functions                                                                                                                                                                                 | At reset | R | W |
|                         | _ 0 | BRG count source selection bit (CSS)                    | 0: f(XIN)<br>1: f(XIN)/4                                                                                                                                                                  | 0        | 0 | 0 |
|                         | 1   | Serial I/O1<br>synchronous clock<br>selection bit (SCS) | When clock synchronous serial I/O is selected, 0: BRG output divided by 4 1: External clock input When UART is selected, 0: BRG output divided by 16 1: External clock input divided by16 | 0        |   | 0 |
|                         | 2   | SRDY1 output enable bit (SRDY)                          | 0: I/O port (P47)<br>1: SRDY1 output pin                                                                                                                                                  | 0        | 0 | 0 |
|                         | 3   | Transmit interrupt source selection bit (TIC)           | Transmit buffer empty     Transmit shift operation completion                                                                                                                             | 0        | 0 | 0 |
|                         | - 4 | Transmit enable bit (TE)                                | 0: Transmit disabled<br>1: Transmit enabled                                                                                                                                               | 0        | 0 | 0 |
|                         | . 5 | Receive enable bit (RE)                                 | 0: Receive disabled<br>1: Receive enabled                                                                                                                                                 | 0        | 0 | 0 |
|                         | 6   | Serial I/O1 mode selection bit (SIOM)                   | 0: UART<br>1: Clock synchronous<br>serial I/O                                                                                                                                             | 0        | 0 | 0 |
|                         | 7   | Serial I/O1 enable bit (SIOE)                           | 0: Serial I/O1 disabled<br>(P44 to P47: normal I/O pins)<br>1: Serial I/O1 enabled<br>(P44 to P47: Serial I/O pins)                                                                       | 0        | 0 | 0 |

Fig. 2.4.4 Structure of Serial I/O1 control register





Fig. 2.4.5 Structure of Serial I/O3 control register





Fig. 2.4.6 Structure of UART1 control register



Fig. 2.4.7 Structure of UART3 control register





Fig. 2.4.8 Structure of Baud rate generator 1 and Baud rate generator 3





Fig. 2.4.9 Structure of Serial I/O2 control register



Fig. 2.4.10 Structure of Serial I/O2 register



#### Interrupt source selection register b7 b6 <u>b5 b4 b3 b2 b1 b0</u> Interrupt source selection register (INTSEL: address 003916) b Name **Functions** At reset RW 0 INT<sub>0</sub>/Timer Z 0: INTo interrupt 0 0:0 interrupt source 1: Timer Z interrupt selection bit (\*1) Serial I/O2/Timer Z 0:0 0: Serial I/O2 interrupt 0 interrupt source 1: Timer Z interrupt selection bit (\*1) 2 Nothing is arranged for these bits. Do not write 0 0:0 "1" to these bits. When these bits are read out, 3 0 010 the contents are "0" INT4/CNTR2 0: INT4 interrupt 0 010 4 1: CNTR2 interrupt interrupt source selection bit 0 0:0 Nothing is arranged for this bit. Do not write "1" to this bit. When this bit is read out, the contents are "0". CNTR<sub>1</sub>/Serial I/O3 0: CNTR1 interrupt 0 0:0 6 receive interrupt 1: Serial I/O3 receive source selection bit interrupt 0: A-D converter interrupt 0 oioAD converter/Serial 1: Serial I/O3 transmit I/O3 transmit interrupt interrupt source selection bit \*1: Do not write "1" to these bits simultaneously.

Fig. 2.4.11 Structure of Interrupt source selection register



|          |                  |   | <del></del>                                                    |                                                                 |          |   |   |
|----------|------------------|---|----------------------------------------------------------------|-----------------------------------------------------------------|----------|---|---|
| b7 b6 b5 | 5 b4 b3 b2 b1 b0 |   | rrupt request register 1<br>EQ1 : address 003C <sub>16</sub> ) |                                                                 |          |   |   |
|          |                  | b | Name                                                           | Functions                                                       | At reset | R | W |
|          |                  | 0 | INT <sub>0</sub> /Timer Z interrupt request bit                | 0 : No interrupt request issued 1 : Interrupt request issued    | 0        | 0 | * |
|          |                  | 1 | INT1 interrupt request bit                                     | 0 : No interrupt request issued<br>1 : Interrupt request issued | 0        | 0 | * |
|          |                  | 2 | Serial I/O1 receive interrupt request bit                      | 0 : No interrupt request issued 1 : Interrupt request issued    | 0        | 0 | * |
|          |                  | 3 | Serial I/O1 transmit interrupt request bit                     | 0 : No interrupt request issued 1 : Interrupt request issued    | 0        | 0 | * |
|          | į                | 4 | Timer X interrupt request bit                                  | 0 : No interrupt request issued 1 : Interrupt request issued    | 0        | 0 | * |
|          |                  | 5 | Timer Y interrupt request bit                                  | 0 : No interrupt request issued 1 : Interrupt request issued    | 0        | 0 | * |
|          |                  | 6 | Timer 1 interrupt request bit                                  | 0 : No interrupt request issued<br>1 : Interrupt request issued | 0        | 0 | * |
| <u> </u> |                  | 7 | Timer 2 interrupt request bit                                  | 0 : No interrupt request issued 1 : Interrupt request issued    | 0        | 0 | * |

Fig. 2.4.12 Structure of Interrupt request register 1



Fig. 2.4.13 Structure of Interrupt request register 2





Fig. 2.4.14 Structure of Interrupt control register 1



Fig. 2.4.15 Structure of Interrupt control register 2



# 2.4.3 Serial I/O connection examples

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

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



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



# (2) Connection with microcomputer

Figure 2.4.17 shows connection examples with another microcomputer.



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



# 2.4.4 Setting of serial I/O transfer data format

A clock synchronous or clock asynchronous (UART) can be selected as a data format of serial I/O1 and serial I/O3.

Serial I/O2 operates in a clock synchronous.

Figure 2.4.18 shows the serial I/O transfer data format.



Fig. 2.4.18 Serial I/O transfer data format



#### 2.4.5 Serial I/O1, serial I/O3 operation: stop and initialize

Serial I/O1 and serial I/O3 perform the same operation. In the following explanations when names of serial I/O1 and serial I/O3 are different, serial I/O1s' are showed first and then serial I/O3s' in the marked ( ).

### (1) Clock synchronous serial I/O mode

## ■Stop/initialize transmit operation when only transmitting

When using an internal clock, set the transmit enable bit and serial I/O1 enable bit (serial I/O3 enable bit) to "0".

When using an external clock, set the transmit enable bit to "0".

By setting the transmit enable bit to "0", the transmit operations listed below will be stopped or initialized. However, when using an internal clock, the clock is output in 8 pulses, even if the transmit enable bit is set to "0" during transmit operations.

- •Stop supply of shift clock to transmit shift register
- •Initialize clock control circuit for transmit
- •Transmit buffer empty flag = "0"
- •Transmit shift register shift complete flag = "0"
- •P45/TxD1 pin: input/output port P45 (P35/TxD3 pin: input/output port P35)

By setting the serial I/O1 enable bit (serial I/O3 enable bit) to "0", pins P4<sub>4</sub>/RxD<sub>1</sub>, P4<sub>5</sub>/TxD<sub>1</sub>, P4<sub>6</sub>/S<sub>CLK1</sub>, and P4<sub>7</sub>/ $\overline{S}_{RDY1}$  (P3<sub>4</sub>/RxD<sub>3</sub>, P3<sub>5</sub>/TxD<sub>3</sub>, P3<sub>6</sub>/S<sub>CLK3</sub>, P3<sub>7</sub>/ $\overline{S}_{RDY3}$  pins) all become I/O ports. As a result, the internal clock cannot be output externally.

## ■Stop/initialize receive operation when only receiving

When using an internal clock, set the receive enable bit and serial I/O1 enable bit (serial I/O3 enable bit) to "0".

When using an external clock, set the receive enable bit or serial I/O1 enable bit (serial I/O3 enable bit) to "0".

By setting the receive enable bit to "0", the receive operations listed below will be stopped or initialized. However, when using an internal clock, the clock is output in 8 pulses, even if the receive enable bit is set to "0" during receive operations.

- •Stop supply of shift clock to receive shift register
- •Initialize clock control circuit for receive
- •Error flags (over-run, parity, framing, and summing error flags) = "0"
- •Receive buffer full flag = "0"
- •P44/RxD1 pin: input/output port P44 (P34/RxD3 pin: input/output port P34)

By setting the serial I/O1 enable bit (serial I/O3 enable bit) to "0", the receive operations listed below will be stopped or initialized. As a result, the internal clock cannot be output externally.

- •Stop supply of shift clock to receive shift register
- •Initialize clock control circuit for receive
- •Error flags (over-run, parity, framing, and summing error flags) = "0"
- •Receive buffer full flag = "0"
- •P4<sub>4</sub>/RxD<sub>1</sub>, P4<sub>5</sub>/TxD<sub>1</sub>, P4<sub>6</sub>/S<sub>CLK1</sub>, P4<sub>7</sub>/S<sub>RDY1</sub> pins: I/O ports P4<sub>4</sub>, P4<sub>5</sub>, P4<sub>6</sub>, P4<sub>7</sub> (P3<sub>4</sub>/RxD<sub>3</sub>, P3<sub>5</sub>/TxD<sub>3</sub>, P3<sub>6</sub>/S<sub>CLK3</sub>, P3<sub>7</sub>/S<sub>RDY3</sub> pins: I/O ports P3<sub>4</sub>, P3<sub>5</sub>, P3<sub>6</sub>, P3<sub>7</sub>)

## ■Stop/initialize receive/transmit operation when both receiving and transmitting

Set the transmit enable bit and receive enable bit to "0" simultaneously.

When using an internal clock, also set the serial I/O1 enable bit (serial I/O3 enable bit) to "0".

#### (2) UART Mode

#### ■Stop/initialize transmit operation

Set the transmit enable bit to "0".

#### ■Stop/initialize receive operation

Set the receive enable bit to "0".



# 2.4.6 Serial I/O pin function and selection method

## (1) Serial I/O1, serial I/O3

Table 2.4.1 shows the pin function in the clock synchronous serial I/O mode, Table 2.4.2 shows the pin function in the UART mode.

Table 2.4.1 Pin function in clock synchronous serial I/O mode

|                       | Pin name<br>(Serial I/O3) |                               | Serial I/O1 control register (address 1A <sub>16</sub> )<br>Serial I/O3 control register (address 32 <sub>16</sub> ) |      |    |    |     |      |     |     |                    |  |
|-----------------------|---------------------------|-------------------------------|----------------------------------------------------------------------------------------------------------------------|------|----|----|-----|------|-----|-----|--------------------|--|
|                       |                           | Function                      | b7<br>(Note 1)                                                                                                       | b6   | b5 | b4 | b3  | b2   | b1  | b0  | sponding direction |  |
|                       |                           |                               | SIOE                                                                                                                 | SIOM | RE | TE | TIC | SRDY | SCS | CSS | register           |  |
| P44/RxD1              | P34/RxD3                  | RxD1, RxD3                    | 1                                                                                                                    | 1    | 1  | 1  | X   | X    | X   | X   | ×                  |  |
| P44/RXD1              | P34/RXD3                  | P44, P34                      | 1                                                                                                                    | 1    | 0  | X  | X   | X    | X   | X   | 0/1                |  |
| P45/TxD1              | P35/TxD3                  | TxD1, TxD3                    | 1                                                                                                                    | 1    | X  | 1  | X   | X    | X   | X   | ×                  |  |
| F45/TXD1              |                           | P45, P35                      | 1                                                                                                                    | 1    | X  | 0  | ×   | X    | X   | X   | 0/1                |  |
| P46/Sclk1             | P36/Sclk3                 | SCLK1 (External clock input)  | 1                                                                                                                    | 1    | X  | 1  | ×   | X    | 1   | X   | ×                  |  |
| F40/SCLKI             |                           | Sclk1 (Internal clock output) | 1                                                                                                                    | 1    | X  | 1  | X   | Х    | 0   | X   | ×                  |  |
| (Note 2)<br>P47/SRDY1 |                           | SRDY1, SRDY3                  | 1                                                                                                                    | 1    | 1  | 1  | X   | 1    | X   | X   | ×                  |  |
| /CNTR2                | P37/SRDY3                 | P47, P37                      | 1                                                                                                                    | 1    | X  | X  | X   | 0    | X   | ×   | 0/1                |  |

Note 1: When SIOE is set to "0", all pins become I/O ports regardless of set value of b6-b0.

Note 2: In the pulse output mode, the programmable waveform generating mode, or the programmable one-shot generating mode of the timer Z, this pin functions as the timer Z function output pin regardless of b7-b0 setting.

Table 2.4.2 Pin function in UART mode

| Pin name<br>(Serial I/O1)       |                           | Function                     | Serial I/O1 control register (address 1A <sub>16</sub> ) |      |    |    |     |      |     |     |                    |
|---------------------------------|---------------------------|------------------------------|----------------------------------------------------------|------|----|----|-----|------|-----|-----|--------------------|
|                                 | Pin name<br>(Serial I/O3) |                              | b7<br>(Note 1)                                           | b6   | b5 | b4 | b3  | b2   | b1  | b0  | sponding direction |
|                                 |                           |                              | SIOE                                                     | SIOM | RE | TE | TIC | SRDY | SCS | CSS | register           |
| P44/RxD1                        |                           | RxD                          | 1                                                        | 0    | 1  | X  | X   | Х    | X   | X   | ×                  |
|                                 | P34/RxD3                  | P44                          | 1                                                        | 0    | 0  | X  | X   | X    | X   | X   | 0/1                |
|                                 | P35/TxD3                  | TxD                          | 1                                                        | 0    | X  | 1  | X   | X    | X   | X   | X                  |
| P45/TxD1                        |                           | P45                          | 1                                                        | 0    | X  | 0  | X   | X    | X   | X   | 0/1                |
| B4./0                           | P36/SCLK3                 | SCLK1 (External clock input) | 1                                                        | 0    | X  | X  | ×   | X    | 1   | X   | ×                  |
| P46/Sclk1                       |                           | P46                          | 1                                                        | 0    | X  | X  | X   | Х    | 0   | X   | 0/1                |
| (Note 2)<br>P47/SRDY1<br>/CNTR2 | P37/SRDY3                 | P47                          | 1                                                        | 0    | X  | X  | X   | ×    | X   | X   | 0/1                |

Note 1: When SIOE is set to "0", all pins become I/O ports regardless of set value of b6-b0.

Note 2: In the pulse output mode, the programmable waveform generating mode, or the programmable one-shot generating mode of the timer Z, this pin functions as the timer Z function output pin regardless of b7-b0 setting.

#### (2) Serial I/O2

Table 2.4.3 shows the pin function in the clock synchronous serial I/O mode.

Table 2.4.3 Pin function in clock synchronous serial I/O mode

| Pin name  | Function      |                                |          | Correspond-<br>ing direction |    |    |    |    |    |     |          |
|-----------|---------------|--------------------------------|----------|------------------------------|----|----|----|----|----|-----|----------|
|           |               |                                | b7       | b6                           | b5 | b4 | b3 | b2 | b1 | b0  | register |
| P50/SIN2  | SIN2 (Note 1) |                                | X        | X                            | X  | X  | 1  | X  | X  | X   | 0        |
| F30/3IN2  | P50           | X                              | X        | X                            | X  | X  | X  | X  | X  | 0/1 |          |
| P51/SOUT2 | SOUT2         | CMOS output                    | 0        | X                            | X  | X  | 1  | X  | X  | X   | ×        |
|           | 30012         | N-channel open-drain output    | 1        | X                            | X  | X  | 1  | X  | X  | ×   | ×        |
|           | P51           |                                | (Note 3) | X                            | X  | X  | 0  | X  | X  | X   | 0/1      |
|           | SCLK2 (E      | External clock input) (Note 2) | X        | 0                            | X  | X  | 1  | X  | X  | ×   | ×        |
| P52/SCLK2 | SCLK2 (       | X                              | 1        | X                            | X  | 1  | X  | X  | ×  | ×   |          |
|           | P52           | X                              | X        | X                            | X  | 0  | X  | X  | X  | 0/1 |          |
| P53/SRDY2 | SRDY2         |                                | Х        | X                            | X  | 1  | X  | X  | X  | X   | ×        |
|           | P53           | X                              | X        | X                            | 0  | X  | X  | X  | X  | 0/1 |          |

Notes 1: Although this pin functions as S<sub>IN2</sub> when b3 is set to "0", set "1" to b3.

Notes 2: Although this pin functions as SCLK2 when b3 and the corresponding direction register are set to "0", set "1" to b3.

Notes 3: When the corresponding direction register bit is "1", the b7 setting is valid.

X: This is not used for the pin's function setting.

X: This is not used for the pin's function setting.

X: This is not used for the pin's function setting.



# 2.4.7 Serial I/O application examples

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

**Outline :** 2-byte data is transmitted and received, using the clock synchronous serial I/O. The  $\overline{S_{RDY1}}$  signal is used for communication control.

Figure 2.4.19 shows a connection diagram, and Figure 2.4.20 shows a timing chart.

Figure 2.4.21 shows a registers setting relevant to the transmitting side, and Figure 2.4.22 shows registers setting relevant to the receiving side.



Fig. 2.4.19 Connection diagram

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

- Synchronous clock frequency : 125 kHz ( $f(X_{IN}) = 4$  MHz is divided by 32)
- SRDY1 (receivable signal) is used.
- The receiving side outputs  $\overline{S_{RDY1}}$  signal at intervals of 2 ms (generated by timer), and 2-byte data is transferred from the transmitting side to the receiving side.



Fig. 2.4.20 Timing chart (using clock synchronous serial I/O)





Fig. 2.4.21 Registers setting relevant to transmitting side





Fig. 2.4.22 Registers setting relevant to receiving side



Figure 2.4.23 shows a control procedure of the transmitting side, and Figure 2.4.24 shows a control procedure of the receiving side.



Fig. 2.4.23 Control procedure of transmitting side





Fig. 2.4.24 Control procedure of receiving side



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

Outline: 4-byte data is transmitted and received, using the clock synchronous serial I/O. The CS signal is output to a peripheral IC through port P6<sub>3</sub>.

Figure 2.4.25 shows connection diagrams of example for using serial I/O1 and example for using serial I/O2 with the same specification, and Figure 2.4.26 shows a timing chart.



Fig. 2.4.25 Connection diagrams

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

- Synchronous clock frequency: 125 kHz ( $f(X_{IN}) = 4$  MHz is divided by 32)
- Transfer direction: LSB first
- The Serial I/O interrupt is not used.
- Port P6<sub>3</sub> is connected to the  $\overline{\text{CS}}$  pin ("L" active) of the peripheral IC for transmission control; the output level of port P6<sub>3</sub> is controlled by software.



Fig. 2.4.26 Timing chart (serial I/O1)



Figure 2.4.27 shows registers setting relevant to serial I/O1, and Figure 2.4.28 shows a setting of serial I/O1 transmission data.



Fig. 2.4.27 Registers setting relevant to serial I/O1



Fig. 2.4.28 Setting of serial I/O1 transmission data



When the registers are set as shown in Fig. 2.4.27, serial I/O1 can transmit 1-byte data by writing data to the transmit buffer register.

Thus, after setting the  $\overline{CS}$  signal to "L", write the transmission data to the transmit buffer register by each 1 byte, and return the  $\overline{CS}$  signal to "H" when the target number of bytes has been transmitted. Figure 2.4.29 shows a control procedure of serial I/O1.



Fig. 2.4.29 Control procedure of serial I/O1



Figure 2.4.30 shows registers setting relevant to serial I/O2, and Figure 2.4.31 shows a setting of serial I/O2 transmission data.



Fig. 2.4.30 Registers setting relevant to serial I/O2



Fig. 2.4.31 Setting of serial I/O2 transmission data



When the registers are set as shown in Fig. 2.4.30, serial I/O2 can transmit 1-byte data by writing data to the serial I/O2 register.

Thus, after setting the CS signal to "L", write the transmission data to the serial I/O2 register by each 1 byte, and return ... a CS signal to "H" when the target number of bytes has been transmitted. Figure 2.4.32 shows a control procedure of serial I/O2.



Fig. 2.4.32 Control procedure of serial I/O2



# (3) Cyclic transmission or reception of block data (data of specified number of bytes) between two microcomputers

**Outline:** When the clock synchronous serial I/O is used for communication, synchronization of the clock and the data between the transmitting and receiving sides may be lost because of noise included in the synchronous clock. It is necessary to correct that constantly, using "heading adjustment".

This "heading adjustment" is carried out by using the interval between blocks in this example. This example is described for serial I/O1, but this example also can apply serial I/O3.

Figure 2.4.33 shows connection diagram.



Fig. 2.4.33 Connection diagram

#### Specifications:

- The serial I/O1 is used (clock synchronous serial I/O is selected).
- Synchronous clock frequency: 125 kHz ( $f(X_{IN}) = 4$  MHz is divided by 32)
- Byte cycle: 500 μs
- Number of bytes for transmission or reception: 8 byte/block
- Block transfer cycle : 16 ms
- Block transfer term : 4 ms
- Interval between blocks: 12 ms
  Heading adjustment time: 8 ms

Master side control

 Data is transmitted and received by interrupt routine executed every byte cycle (500 μs)

Slave side control

- Data is transmitted and received by serial I/O1 receive interrupt routine.
- The heading adjustment is carried out by interrupt routine executed every 1 ms.

## Limitations of specifications:

- Reading of the reception data and writing of the next transmission data must be completed within the time obtained from "byte cycle time for transferring 1-byte data" (in this example, the time taken from generating of the serial I/O1 receive interrupt request to input of the next synchronous clock is 436 µs).
- "Heading adjustment time < interval between blocks" must be satisfied.



The communication is performed according to the timing shown in Figure 2.4.34. In the slave unit, when a synchronous clock is not input within a certain time (heading adjustment time), the next clock input is processed as the beginning (heading) of a block.

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

Figure 2.4.35 shows relevant registers setting.



Fig. 2.4.34 Timing chart



Fig. 2.4.35 Relevant registers setting



#### Control procedure:

Control in the master unit

The master unit starts transmission or reception by writing transmission data to the transmit buffer register in the interrupt routine executed every 500  $\mu s$ . In this interrupt routine, read the reception data before the next transmission data is written to the transmit buffer register. Additionally, transmission and reception of one block (8 bytes) is controlled and the block interval is generated. Figure 2.4.36 shows the control procedure of the master unit.



Fig. 2.4.36 Control procedure of master unit



#### Control in the slave unit

After setting the relevant registers as shown in Figure 2.4.35, the slave unit becomes the state where a synchronous clock can be received at any time, and the serial I/O1 receive interrupt occurs each time an 8-bit synchronous clock is received.

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

However, if no serial I/O1 receive interrupt occurs for a certain time (heading adjustment time or more), the following processing will be performed in the interrupt routine executed every 1 ms.

- 1. Serial I/O1 is initialized.
- 2. The first 1-byte data of the transmission data in the block is written into the transmit buffer register.
- 3. Since the data to be received next is processed as the first 1 byte of the received data in the block, the receive byte counter is initialized.

Figure 2.4.37 shows a control procedure of the slave unit.



Fig. 2.4.37 Control procedure of slave unit



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

**Outline :** 2-byte data is transmitted and received, using the asynchronous serial I/O. Port P4<sub>0</sub> is used for communication control.

Figure 2.4.38 shows a connection diagram, and Figure 2.4.39 shows a timing chart.



Fig. 2.4.38 Connection diagram (Communication using UART)

**Specifications:** • Serial I/O1 is used (UART is selected).

- Transfer bit rate : 9600 bps  $(f(X_{IN}) = 4.9152 \text{ MHz} \text{ is divided by 512})$
- Communication control using port P4<sub>0</sub>
   (The output level of port P4<sub>0</sub> is controlled by software.)
- 2-byte data is transferred from the transmitting side to the receiving side at intervals of 10 ms generated by the timer.



Fig. 2.4.39 Timing chart (using UART)



Table 2.4.4 shows setting examples of the baud rate generator (BRG) values and transfer bit rate values; Figure 2.4.40 shows registers setting relevant to the transmitting side; Figure 2.4.41 shows registers setting relevant to the receiving side.

Table 2.4.4 Setting examples of Baud rate generator (BRG) values and transfer bit rate values

| BRG count source (Note 1) | BRG setting value     | Transfer bit rate (bps) (Note 2) |                    |
|---------------------------|-----------------------|----------------------------------|--------------------|
|                           |                       | at f(XIN) = 4.9152 MHz           | at f(XIN) = 16 MHz |
| f(XIN)/4                  | 255(FF16)             | 300                              | 976.5625           |
| f(XIN)/4                  | 127(7F16)             | 600                              | 1953.125           |
| f(XIN)/4                  | 63(3F16)              | 1200                             | 3906.25            |
| f(XIN)/4                  | 31(1F <sub>16</sub> ) | 2400                             | 7812.5             |
| f(XIN)/4                  | 15(0F16)              | 4800                             | 15625              |
| f(XIN)/4                  | 7(0716)               | 9600                             | 31250              |
| f(XIN)/4                  | 3(0316)               | 19200                            | 62500              |
| f(XIN)/4                  | 1(0116)               | 38400                            | 125000             |
| f(XIN)                    | 3(0316)               | 76800                            | 250000             |
| f(XIN)                    | 1(0116)               | 153600                           | 500000             |
| f(XIN)                    | 0(0016)               | 307200                           | 1000000            |

Notes 1: Select the BRG count source with bit 0 of the serial I/O1 control register (Address: 1A16).

2: Equation of transfer bit rate:

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

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

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





Fig. 2.4.40 Registers setting relevant to transmitting side





Fig. 2.4.41 Registers setting relevant to receiving side



Figure 2.4.42 shows a control procedure of the transmitting side, and Figure 2.4.43 shows a control procedure of the receiving side.



Fig. 2.4.42 Control procedure of transmitting side





Fig. 2.4.43 Control procedure of receiving side



#### 2.4.8 Notes on serial I/O

#### (1) Notes when selecting clock synchronous serial I/O

#### ① Stop of transmission operation

As for serial I/Oi (i = 1, 3) that can be used as either a clock synchronous or an asynchronous (UART) serial I/O, clear the serial I/Oi enable bit and the transmit enable bit to "0" (serial I/Oi and transmit disabled).

#### Reason

Since transmission is not stopped and the transmission circuit is not initialized even if only the serial I/Oi enable bit is cleared to "0" (serial I/Oi disabled), the internal transmission is running (in this case, since pins TxDi, RxDi, Sclki, and SRDYi function as I/O ports, the transmission data is not output). When data is written to the transmit buffer register in this state, data starts to be shifted to the transmit shift register. When the serial I/Oi enable bit is set to "1" at this time, the data during internally shifting is output to the TxDi pin and an operation failure occurs.

#### 2 Stop of receive operation

As for serial I/Oi (i = 1, 3) that can be used as either a clock synchronous or an asynchronous (UART) serial I/O, clear the receive enable bit to "0" (receive disabled), or clear the serial I/Oi enable bit to "0" (serial I/Oi disabled).

#### 3 Stop of transmit/receive operation

As for serial I/Oi (i = 1, 3) that can be used as either a clock synchronous or an asynchronous (UART) serial I/O, clear both the transmit enable bit and receive enable bit to "0" simultaneously (transmit and receive disabled) in the clock synchronous serial I/O mode.

(When data is transmitted and received in the clock synchronous serial I/O mode, any one of data transmission and reception cannot be stopped.)

#### Reason

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

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

#### (2) Notes when selecting clock asynchronous serial I/O

#### 1) Stop of transmission operation

Clear the transmit enable bit to "0" (transmit disabled). Transmission operation does not stop by setting the serial I/Oi enable bit (i = 1, 3) to "0".

#### Reason

This is the same as ① in (1).

#### 2 Stop of receive operation

Clear the receive enable bit to "0" (receive disabled).



## 3 Stop of transmit/receive operation

## Only transmission operation is stopped.

Clear the transmit enable bit to "0" (transmit disabled). Transmission operation does not stop by setting the serial I/Oi enable bit (i = 1, 3) to "0".

#### Reason

This is the same as ① in (1).

#### Only receive operation is stopped.

Clear the receive enable bit to "0" (receive disabled).

#### (3) SRDY output of reception side

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

## (4) Setting serial I/Oi (i = 1, 3) control register again

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



Fig. 2.4.44 Sequence of setting serial I/Oi (i = 1, 3) control register again

#### (5) Data transmission control with referring to transmit shift register completion flag

After the transmit data is written to the transmit buffer register, the transmit shift register completion flag changes from "1" to "0" with a delay of 0.5 to 1.5 shift clocks. When data transmission is controlled with referring to the flag after writing the data to the transmit buffer register, note the delay.

## (6) Transmission control when external clock is selected

When an external clock is used as the synchronous clock for data transmission, set the transmit enable bit to "1" at "H" of the SCLKi (i = 1, 3) input level. Also, write the transmit data to the transmit buffer register at "H" of the SCLKi input level.



#### (7) Transmit interrupt request when transmit enable bit is set

When the transmit interrupt is used, take the following sequence.

- ① Set the serial I/O transmit interrupt enable bit to "0" (disabled).
- 2 Set the tranasmit enable bit to "1".
- 3 Set the serial I/O transmit interrupt request bit to "0" after 1 or more instruction has executed.
- 4 Set the serial I/O transmit interrupt enable bit to "1" (enabled).

#### Reason

When the transmission enable bit is set to "1", the transmit buffer empty flag and transmit shift register completion flag are set to "1".

The transmission interrupt request bit is set and the interrupt request occurs even when selecting timing that either of the following flags is set to "1" as timing where the transmission interrupt occurs.

- Transmit buffer empty flag is set to "1"
- Transmit shift register completion flag is set to "1"

#### (8) Writing to baud rate generator

Write data to the baud rate generator i (BRGi) (i = 1, 3) while the transmission/reception operation is stopped.



#### 2.5 **PWM**

This paragraph explains the registers setting method and the notes relevant to the PWM.

#### 2.5.1 Memory map



Fig. 2.5.1 Memory map of registers relevant to PWM

## 2.5.2 Relevant registers



Fig. 2.5.2 Structure of PWM control register





Fig. 2.5.3 Structure of PWM prescaler



Fig. 2.5.4 Structure of PWM register



## 2.5.3 PWM output circuit application example

#### <Motor control>

Outline: The rotation speed of the motor is controlled by using PWM (pulse width modulation) output.

Figure 2.5.5 shows a connection diagram; Figures 2.5.6 shows PWM output timing, and Figure 2.5.7 shows a setting of the related registers.



Fig. 2.5.5 Connection diagram

**Specifications:** • Motor is controlled by using the PWM output function of 8-bit resolution.

• Clock f(XIN) = 5 MHz

• "T", PWM cycle : 102 μs

• "t", "H" level width of output pulse : 40  $\mu$ s (Fixed speed)

\* A motor speed can be changed by modifying the "H" level width of output pulse.



Fig. 2.5.6 PWM output timing





Fig. 2.5.7 Setting of relevant registers

#### <About PWM output>

- 1. Set the PWM function enable bit to "1": The P56/PWM pin is used as the PWM pin.
  - The pulse beginning with "H" level pulse is output.
- 2. Set the PWM function enable bit to "0": The P56/PWM pin is used as the port P56.

Thus, when fixing the output level, take the following procedure:

- (1) Write an output value to bit 6 of the port P5 register.
- (2) Write "010000002" to the port P5 direction register.
- 3. After data is set to the PWM prescaler and the PWM register, the PWM waveforms corresponding to updated data will be output from the next repetitive cycle.



Fig. 2.5.8 PWM output



By setting the related registers as shown by Figure 2.5.7, PWM waveforms are output to the externals. This PWM output is integrated through the low pass filter, and that converted into DC signals is used for control of the motor. Figure 2.5.9 shows control procedure.



Fig. 2.5.9 Control procedure

#### 2.5.4 Notes on PWM

The PWM starts after the PWM enable bit is set to enable and "L" level is output from the PWM pin. The length of this "L" level output is as follows:

$$\frac{n+1}{2 \cdot f(X_{|N})}$$
 (s) (Count source selection bit = 0, where n is the value set in the prescaler)

$$\frac{n+1}{f(X_{|N})}$$
 (s) (Count source selection bit = 1, where n is the value set in the prescaler)



#### 2.6 A-D converter

This paragraph explains the registers setting method and the notes relevant to the A-D converter.

## 2.6.1 Memory map



Fig. 2.6.1 Memory map of registers relevant to A-D converter

#### 2.6.2 Relevant registers



Fig. 2.6.2 Structure of AD/DA control register





Fig. 2.6.3 Structure of A-D conversion register 1



Fig. 2.6.4 Structure of A-D conversion register 2





Fig. 2.6.5 Structure of Interrupt source selection register





Fig. 2.6.6 Structure of Interrupt request register 2



Fig. 2.6.7 Structure of Interrupt control register 2



#### 2.6.3 A-D converter application examples

## (1) Conversion of analog input voltage 1

Outline: The analog input voltage input from a sensor is converted to digital values.

Figure 2.6.8 shows a connection diagram, and Figure 2.6.9 shows the relevant registers setting.



Fig. 2.6.8 Connection diagram

**Specifications**: •The analog input voltage input from a sensor is converted to digital values.

•P6<sub>0</sub>/AN<sub>0</sub> pin is used as an analog input pin.

•10-bit A-D mode



Fig. 2.6.9 Relevant registers setting



An analog input signal from a sensor is converted to the digital value according to the relevant registers setting shown by Figure 2.6.9. Figure 2.6.10 shows the control procedure for 10-bit A-D mode.



Fig. 2.6.10 Control procedure (10-bit A-D mode)



## (2) Conversion of analog input voltage 2

Outline: The analog input voltage input from a sensor is converted to digital values.

Figure 2.6.11 shows a connection diagram, and Figure 2.6.12 shows the relevant registers setting.



Fig. 2.6.11 Connection diagram

**Specifications**: •The analog input voltage input from a sensor is converted to digital values.

•P6₀/AN₀ pin is used as an analog input pin.

•8-bit A-D mode



Fig. 2.6.12 Relevant registers setting



An analog input signal from a sensor is converted to the digital value according to the relevant registers setting shown by Figure 2.6.12. Figure 2.6.13 shows the control procedure for 8-bit A-D mode.



Fig. 2.6.13 Control procedure (8-bit A-D mode)



#### 2.6.4 Notes on A-D converter

## (1) Analog input pin

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

#### Reason

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

#### (2) A-D converter power source pin

The AVss pin is A-D converter power source pins. Regardless of using the A-D conversion function or not, connect it as following:

• AVss : Connect to the Vss line

#### Reason

If the AVSS pin is opened, the microcomputer may have a failure because of noise or others.

## (3) Clock frequency during A-D conversion

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

- f(XIN) is 500 kHz or more
- Do not execute the **STP** instruction

#### (4) Difference between at 8-bit reading in 10-bit A-D mode and at 8-bit A-D mode

At 8-bit reading in the 10-bit A-D mode, "-1/2 LSB" correction is not performed to the A-D conversion result.

In the 8-bit A-D mode, the A-D conversion characteristics is the same as 3802 group's characteristics because "-1/2 LSB" correction is performed.



## 2.7 D-A Converter

This paragraph explains the registers setting method and the notes relevant to the D-A converter.

## 2.7.1 Memory map



Fig. 2.7.1 Memory map of registers relevant to D-A converter



## 2.7.2 Relevant registers



Fig. 2.7.2 Structure of Port P5 direction register



Fig. 2.7.3 Structure of AD/DA control register





Fig. 2.7.4 Structure of D-Ai converter register



#### 2.7.3 D-A converter application example

## (1) Speaker output volume modulation

Outline: The volume of a speaker output is modulated by using D-A converter.

**Specifications:** •Timer X modulates the period of sound for the pitch interval, so that a fixed pitch ("la": approx. 440 Hz) can be output. Modulating the amplitude with the D-A output value controls the volume.

- •Use  $f(X_{IN}) = 6$  MHz.
- •Use DA1 (P3<sub>0</sub>/DA<sub>1</sub> pin) as D-A converter.

Figure 2.7.5 shows a peripheral circuit example and Figure 2.7.6 shows a speaker output example. Figure 2.7.7 shows the relevant registers setting.



Fig. 2.7.5 Peripheral circuit example



Fig. 2.7.6 Speaker output example





Fig. 2.7.7 Relevant registers setting



When the registers are set as shown in Figure 2.7.7, the speaker output volume is modulated by the D-A output value. Figure 2.7.8 shows the control procedure.



Fig. 2.7.8 Control procedure



## 2.7.4 Notes on D-A converter

## (1) Vcc when using D-A converter

The D-A converter accuracy when Vcc is 4.0 V or less differs from that of when Vcc is 4.0 V or more. When using the D-A converter, we recommend using a Vcc of 4.0 V or more.

## (2) D-Ai conversion register when not using D-A converter

When a D-A converter is not used, set all values of the D-Ai conversion registers (i = 1, 2) to " $00_{16}$ ". The initial value after reset is " $00_{16}$ ".



## 2.8 Watchdog timer

This paragraph explains the registers setting method and the notes relevant to the watchdog timer.

#### 2.8.1 Memory map



Fig. 2.8.1 Memory map of registers relevant to watchdog timer

## 2.8.2 Relevant registers



Fig. 2.8.2 Structure of Watchdog timer control register





Fig. 2.8.3 Structure of CPU mode register



### 2.8.3 Watchdog timer application examples

## (1) Detection of program runaway

**Outline**: If program runaway occurs, let the microcomputer reset, using the internal timer for detection of program runaway.

Specifications: •High-speed mode is used as a main clock division ratio.

- •An underflow signal of the watchdog timer L is supplied as the count source of watchdog timer H.
- •1 cycle of main routine is 65.536 ms or less.
- •Before the watchdog timer H underflows, "0" is set into bit 7 of the watchdog timer control register at every cycle in a main routine.
- •An underflow of watchdog timer H is judged to be program runaway, and the microcomputer is returned to the reset status.

Figure 2.8.4 shows a watchdog timer connection and division ratio setting; Figure 2.8.5 shows the relevant registers setting; Figure 2.8.6 shows the control procedure.



Fig. 2.8.4 Watchdog timer connection and division ratio setting





Fig. 2.8.5 Relevant registers setting



Fig. 2.8.6 Control procedure

### 2.8.4 Notes on watchdog timer

- ■Make sure that the watchdog timer H does not underflow while waiting Stop release, because the
  watchdog timer keeps counting during that term.
- ●When the STP instruction disable bit has been set to "1", it is impossible to switch it to "0" by a program.



# 2.9 Reset

# 2.9.1 Connection example of reset IC



Fig. 2.9.1 Example of poweron reset circuit

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



Fig. 2.9.2 RAM backup system



# 2.9.2 Notes on RESET pin

### Connecting capacitor

In case where the RESET signal rise time is long, connect a ceramic capacitor or others across the RESET pin and the Vss pin. Use a 1000 pF or more capacitor for high frequency use. When connecting the capacitor, note the following :

- Make the length of the wiring which is connected to a capacitor as short as possible.
- Be sure to verify the operation of application products on the user side.

#### Reason

If the several nanosecond or several ten nanosecond impulse noise enters the  $\overline{\text{RESET}}$  pin, it may cause a microcomputer failure.



# 2.10 Clock generating circuit

This paragraph explains how to set the registers relevant to the clock generating circuit and describes an application example.

### 2.10.1 Relevant registers



Fig. 2.10.1 Structure of CPU mode register



### 2.10.2 Clock generating circuit application example

# (1) Status transition during power failure

Outline: The clock counts up every second by using the timer interrupt during a power failure.



Fig. 2.10.2 Connection diagram

Specifications: •Reducing power dissipation as low as possible while maintaining clock function

•Clock:  $f(X_{IN}) = 8 \text{ MHz}, f(X_{CIN}) = 32.768 \text{ kHz}$ 

Port processing

Input port: Fixed to "H" or "L" level externally.

Output port: Fixed to output level that does not cause current flow to the external.

(Example) Fix to "H" for an LED circuit that turns on at "L" output level.

I/O port: Input port  $\rightarrow$  Fixed to "H" or "L" level externally.

Output port  $\rightarrow$  Output of data that does not consume current

VREF pin: Terminate A-D conversion operation

Stop  $V_{\text{REF}}$  current dissipation by setting value of D-Ai conversion register to "0016".

Figure 2.10.3 shows the status transition diagram during power failure and Figure 2.10.4 shows the setting of relevant registers.



Fig. 2.10.3 Status transition diagram during power failure





Fig. 2.10.4 Setting of relevant registers



**Control procedure:** To prepare for a power failure, set the relevant registers in the order shown below.



Fig. 2.10.5 Control procedure



# 2.11 Standby function

The 3803 group (Spec. H) is provided with standby functions to stop the CPU by software and put the CPU into the low-power operation.

The following two types of standby functions are available.

- •Stop mode using STP instruction
- •Wait mode using WIT instruction

### 2.11.1 Stop mode

The stop mode is set by executing the STP instruction. In the stop mode, the oscillation of both clocks ( $X_{IN-}X_{COUT}$ ,  $X_{CIN-}X_{COUT}$ ) stop and the internal clock  $\phi$  stops at the "H" level. The CPU stops and peripheral units stop operating. As a result, power dissipation is reduced.

## (1) State in stop mode

Table 2.11.1 shows the state in the stop mode.

Table 2.11.1 State in stop mode

| Item                                  | State in stop mode                                           |
|---------------------------------------|--------------------------------------------------------------|
| Oscillation                           | Stopped.                                                     |
| CPU                                   | Stopped.                                                     |
| Internal clock $\phi$                 | Stopped at "H" level.                                        |
| I/O ports P0–P6                       | Retains the state at the STP instruction execution.          |
| Timer                                 | Stopped. (Timers 1, 2, X, Y, Z)                              |
|                                       | However, Timers X, Y, Z can be operated in the event counter |
|                                       | mode.                                                        |
| PWM                                   | Stopped.                                                     |
| Watchdog timer                        | Stopped.                                                     |
| Serial I/O1, Serial I/O2, Serial I/O3 | Stopped.                                                     |
|                                       | However, these can be operated only when an external clock   |
|                                       | is selected.                                                 |
| A-D converter                         | Stopped.                                                     |
| D-A converter                         | Retains output voltage.                                      |



### (2) Release of stop mode

The stop mode is released by a reset input or by the occurrence of an interrupt request. Note the differences in the restoration process according to reset input or interrupt request, as described below.

#### ■Restoration by reset input

The stop mode is released by holding the  $\overline{RESET}$  pin to the "L" input level during the stop mode. Oscillation is started when all ports are in the input state and the stop mode of the main clock (XINTOUT) is released.

Oscillation is unstable when restarted. For this reason, time for stabilizing of oscillation (oscillation stabilizing time) is required. The input of the  $\overline{\mathsf{RESET}}$  pin should be held at the "L" level until oscillation stabilizes

When the  $\overline{\text{RESET}}$  pin is held at the "L" level for 16 cycles or more of  $X_{IN}$  after the oscillation has stabilized, the microcomputer will go to the reset state. After the input level of the  $\overline{\text{RESET}}$  pin is returned to "H", the reset state is released in approximately 10.5 to 18.5 cycles of the  $X_{IN}$  input. Figure 2.11.1 shows the oscillation stabilizing time at restoration by reset input.

At release of the stop mode by reset input, the internal RAM retains its contents previous to the reset. However, the previous contents of the CPU register and SFR are not retained. For more details concerning reset, refer to "2.9 Reset".



Fig. 2.11.1 Oscillation stabilizing time at restoration by reset input



### ■Restoration by interrupt request

The occurrence of an interrupt request in the stop mode releases the stop mode. As a result, oscillation is resumed. The interrupts available for restoration are:

- •INT<sub>0</sub>-INT<sub>4</sub>
- •CNTR<sub>0</sub>, CNTR<sub>1</sub>, CNTR<sub>2</sub>
- •Serial I/O (1, 2, 3) using an external clock
- •Timer X, Y, Z using an external event count

However, when using any of these interrupt requests for restoration from the stop mode, <u>in order to enable the selected interrupt</u>, you must execute the STP instruction after setting the following conditions.

### [Necessary register setting]

- ① Interrupt disable flag I = "0" (interrupt enabled)
- ② Timer 1 interrupt enable bit = "0" (interrupt disabled)
- ③ Interrupt request bit of interrupt source to be used for restoration = "0" (no interrupt request issued)
- ④ Interrupt enable bit of interrupt source to be used for restoration = "1" (interrupts enabled)

For more details concerning interrupts, refer to "2.2 Interrupts".

Oscillation is unstable when restarted. For this reason, time for stabilizing of oscillation (oscillation stabilizing time) is required. For restoration by an interrupt request, waiting time prior to supplying internal clock  $\phi$  to the CPU is automatically generated\*2 by Prescaler 12 and Timer 1\*1. This waiting time is reserved as the oscillation stabilizing time on the system clock side. The supply of internal clock  $\phi$  to the CPU is started at the Timer 1 underflow.

Figure 2.11.2 shows an execution sequence example at restoration by the occurrence of an INTo interrupt request.

- \*1: If the STP instruction is executed when the oscillation stabilizing time set after STP instruction released bit is "0", "FF<sub>16</sub>" and "01<sub>16</sub>" are automatically set in the Prescaler 12 counter/latch and Timer 1 counter/latch, respectively. When the oscillation stabilizing time set after STP instruction released bit is "1", nothing is automatically set to either Prescaler 12 or Timer 1. For this reason, any suitable value can be set to Prescaler 12 and Timer 1 for the oscillation stabilizing time.
- \*2: Immediately after the oscillation is started, the count source is supplied to the prescaler 12 so that a count operation is started.





Fig. 2.11.2 Execution sequence example at restoration by occurrence of INTo interrupt request

## (3) Notes on using stop mode

#### ■Register setting

Since values of the prescaler 12 and Timer 1 are automatically reloaded when returning from the stop mode, set them again, respectively. (When the oscillation stabilizing time set after STP instruction released bit is "0")

#### **■Clock** restoration

After restoration from the stop mode to the normal mode by an interrupt request, the contents of the CPU mode register previous to the STP instruction execution are retained. Accordingly, if both main clock and sub clock were oscillating before execution of the STP instruction, the oscillation of both clocks is resumed at restoration.

In the above case, when the main clock side is set as a system clock, the oscillation stabilizing time until the timer 1 underflow is reserved at restoration from the stop mode.

When the oscillation stabilizing time set after STP instruction released bit is "0", the time for 512 counts of the count source become the oscillation stabilizing time. When the oscillation stabilizing time set after STP instruction released bit is "1", an arbitrarily count value set to the prescaler 12 and the timer 1 become the oscillation stabilizing time.

At this time, note that the oscillation on the sub clock side may not be stabilized even after the lapse of the oscillation stabilizing time of the main clock side.



### 2.11.2 Wait mode

The wait mode is set by execution of the WIT instruction. In the wait mode, oscillation continues, but the internal clock  $\phi$  stops at the "H" level.

The CPU stops, but most of the peripheral units continue operating.

### (1) State in wait mode

The continuation of oscillation permits clock supply to the peripheral units. Table 2.11.2 shows the state in the wait mode.

Table 2.11.2 State in wait mode

| Item                                  | State in wait mode                                  |
|---------------------------------------|-----------------------------------------------------|
| Oscillation                           | Operating.                                          |
| CPU                                   | Stopped.                                            |
| Internal clock $\phi$                 | Stopped at "H" level.                               |
| I/O ports P0–P6                       | Retains the state at the WIT instruction execution. |
| Timer                                 | Operating.                                          |
| PWM                                   | Operating.                                          |
| Watchdog timer                        | Operating.                                          |
| Serial I/O1, Serial I/O2, Serial I/O3 | Operating.                                          |
| A-D converter                         | Operating.                                          |
| D-A converter                         | Retains output voltage.                             |



#### (2) Release of wait mode

The wait mode is released by reset input or by the occurrence of an interrupt request. Note the differences in the restoration process according to reset input or interrupt request, as described below.

In the wait mode, oscillation is continued, so an instruction can be executed immediately after the wait mode is released.

### ■Restoration by reset input

The wait mode is released by holding the input level of the  $\overline{RESET}$  pin at "L" in the wait mode. Upon release of the wait mode, all ports are in the input state, and supply of the internal clock  $\phi$  to the CPU is started. To reset the microcomputer, the  $\overline{RESET}$  pin should be held at an "L" level for 16 cycles or more of  $X_{IN}$ . The reset state is released in approximately 10.5 cycles to 18.5 cycles of the  $X_{IN}$  input after the input of the  $\overline{RESET}$  pin is returned to the "H" level.

At release of wait mode, the internal RAM retains its contents previous to the reset. However, the previous contents of the CPU register and SFR are not retained.

Figure 2.11.3 shows the reset input time.

For more details concerning reset, refer to "2.9 Reset".



Fig. 2.11.3 Reset input time



### **■**Restoration by interrupt request

In the wait mode, the occurrence of an interrupt request releases the wait mode and supply of the internal clock  $\phi$  to the CPU is started. At the same time, the interrupt request used for restoration is accepted, so the interrupt processing routine is executed.

However, when using an interrupt request for restoration from the wait mode, in order to enable the selected interrupt, you must execute the STP instruction after setting the following conditions.

### [Necessary register setting]

- ① Interrupt disable flag I = "0" (interrupt enabled)
- ② Interrupt request bit of interrupt source to be used for restoration = "0" (no interrupt request issued)
- ③ Interrupt enable bit of interrupt source to be used for restoration = "1" (interrupts enabled)

For more details concerning interrupts, refer to "2.2 Interrupts".

#### (3) Notes on wait mode

#### **■Clock** restoration

If the wait mode is released by a reset when  $X_{CIN}$  is set as the system clock and  $X_{IN}$  oscillation is stopped during execution of the WIT instruction,  $X_{CIN}$  oscillation stops,  $X_{IN}$  oscillations starts, and  $X_{IN}$  is set as the system clock.

In the above case, the RESET pin should be held at "L" until the oscillation is stabilized.



# 2.12 Flash memory mode

This paragraph explains the registers setting method and the notes relevant to the flash memory mode of M38039FFHSP/FP/HP/KP.

### 2.12.1 Overview

The functions of the flash memory version are similar to those of the mask ROM version except that the flash memory is built-in and some of the SFR area differ from that of the mask ROM version (refer to "2.12.2 Memory map").

In the flash memory version, the built-in flash memory can be programmed or erased by using the following three modes.

- CPU rewrite mode
- Parallel I/O mode
- Standard serial I/O mode

### 2.12.2 Memory map

M38039FFHSP/FP/HP/KP have 60 Kbytes of built-in flash memory.

Figure 2.12.1 shows the memory map of the flash memory version.



Fig. 2.12.1 Memory map of M38039FFHSP/FP/HP/KP



### 2.12.3 Relevant registers



Fig. 2.12.2 Memory map of registers relevant to flash memory



Fig. 2.12.3 Structure of Flash memory control register 0





Fig. 2.12.4 Structure of Flash memory control register 1



Fig. 2.12.5 Structure of Flash memory control register 2



#### 2.12.4 Parallel I/O mode

In the parallel I/O mode, program/erase to the built-in flash memory can be performed by a flash memory programmer (EFP-I etc.).

The memory area of program/erase is from 0F000<sub>16</sub> to 0FFFF<sub>16</sub> (boot ROM area) or from 01000<sub>16</sub> to 0FFFF<sub>16</sub> (user ROM area). Be especially careful when erasing; if the memory area is not set correctly, the products will be damaged eternally.

Table 2.12.1 shows the parallel unit when programming by EFP-I in the parallel I/O mode.

•EFP-I provided by Suisei Electronics System Co., Ltd. (http://www.suisei.co.jp/index\_e.htm) (product available in Asia and Oceania only)

Table 2.12.1 Parallel unit when parallel programming (when using EFP-I provided by Suisei Electronics System Co., Ltd.)

| Products    | Parallel unit | Boot ROM area                              | User ROM area                              |
|-------------|---------------|--------------------------------------------|--------------------------------------------|
| M38039FFHSP | EF3803F-64S   |                                            |                                            |
| M38039FFHFP | EF3803F-64F   | 05000 to 0555                              | 04000 40 05555                             |
| M38039FFHHP | EF3803F-64H   | 0F000 <sub>16</sub> to 0FFFF <sub>16</sub> | 01000 <sub>16</sub> to 0FFFF <sub>16</sub> |
| M38039FFHKP | EF3803F-64U   |                                            |                                            |

#### 2.12.5 Standard serial I/O mode

Table 2.12.2 shows a pin connection example (4 wires) between the programmer (EFP-I; Serial unit EF1SRP-01U is required additionally) and the microcomputer when programming in the standard serial I/O mode 1.

•EFP-I provided by Suisei Electronics System Co., Ltd. (http://www.suisei.co.jp/index\_e.htm) (product available in Asia and Oceania only)

Table 2.12.2 Connection example to programmer when serial programming (4 wires)

|                      | EFP-I (EF1SRP-01U) |                       | Flash memory version |             |             |
|----------------------|--------------------|-----------------------|----------------------|-------------|-------------|
| Function             | Signal name        | EF1RP-01U side        | Pin name             | M38039FFHSP | M38039FFHSP |
|                      |                    | connector Line number |                      | pin number  | pin number  |
| Transfer clock input | T_SCLK             | 9                     | P46/Sclk1            | 21          | 13          |
| Serial data input    | T_TXD              | 10                    | P44/RxD1             | 23          | 15          |
| Serial data output   | T_RXD              | 11                    | P45/TxD1             | 22          | 14          |
| Transmit/Receive     | T_BUSY             | 12                    | P47/SRDY1/CNTR2      | 20          | 12          |
| enable output        |                    |                       |                      |             |             |
| "H" input            | T_VPP              | 3                     | CNVss                | 26          | 18          |
| Reset input          | T_RESET            | 14                    | RESET (Note 1)       | 27          | 19          |
| Target board power   | T_VDD (Note 2)     | 4                     | Vcc (Note 2)         | 1           | 57          |
| source monitor input |                    |                       |                      |             |             |
| GND                  | GND (Note 3)       | 1, 2, 15, 16          | Vss, AVss (Note 3)   | 32, 3       | 24, 59      |

**Notes 1:** Since reset release after write verification is not performed, when operating MCU after writing, separate a target connection cable.

- 2: Supply Vcc of EFP-I side from user side so that the power supply voltage of the output buffer used by the EFP-I side becomes the same as user side power supply voltage (Vcc).
- **3:** Four pins (No. 1, 2, 15, and 16) of the EF1SRP-01U side connector are prepared for GND signal. When connecting with a target board, although connection of only one pin does not have a problem, we recommend connecting with two or more pins.



#### 2.12.6 CPU rewrite mode

In the CPU rewrite mode, issuing software commands through the Central Processing Unit (CPU) can rewrite the built-in flash memory. Accordingly, the contents of the built-in flash memory can be rewritten with the microcomputer itself mounted on board, without using the programmer.

Store the rewrite control program to the built-in flash memory in advance. The built-in flash memory cannot be read in the CPU rewrite mode. Accordingly, after transferring the rewrite control program to RAM, execute it on the RAM.

The following commands can be used in the CPU rewrite mode: read array, read status register, clear status register, program, and block erase. For details concerning each command, refer to 3803 Group (Spec.H) Data Sheet "Flash memory mode (CPU rewrite mode)".

### (1) CPU rewrite mode beginning/release procedures

Operation procedure in the CPU rewrite mode for the built-in flash memory is described below.

#### [Beginning procedure]

- ① Apply "H" to the CNVss pin and P45/TxD1 pin (at selecting boot ROM area).
- 2 Release reset.
- ③ Set bits 6 and 7 (main clock division ratio selection bits) of the CPU mode register. (Make sure that system clock  $\phi$  is less than 4.0 MHz.)
- After CPU rewrite mode control program is transferred to internal RAM, jump to this control program on RAM. (The following operations are controlled by this control program).
- ⑤ Set "1" to the CPU rewrite mode select bit (bit 1 of address 0FFE<sub>16</sub>).

  For this bit to be set to "1", the user needs to write "0" and then "1" to it in succession.
- ® Set "1" to the all user block E/W enable bit (bit 4 of address 0FE2<sub>16</sub>). Set the 8 KB user block E/W enable bit. (Set to "0" when E/W is disabled, and set to "1" when E/W is enabled.)\*
  \* For these bits to be set to "1", the user needs to write "0" and then "1" to those in succession.
- Tlash memory operations are executed by using software commands.

**Note:** The following procedures are also necessary.

- Control for data which is input from the external (serial I/O etc.) and to be programmed to the flash memory.
- · Initial setting for ports, etc.
- Writing to the watchdog timer

#### [Release procedure]

- ① Execute the read array command.
- ② In order to disable E/W to the user ROM area (except for data block), set "0" to the all user block E/W enable bit (bit 4 of 0FE2<sub>16</sub>) and the 8 KB user block E/W enable bit (bit 2 of 0FE0<sub>16</sub>) (Note 2).
- 3 Set the CPU rewrite mode select bit (bit 1 of address 0FFE16) to "0".
- 4 Jump from the CPU rewriting control program on RAM to the user program on the flash memory.

**Note 2:** Although E/W inhibition is not indispensable, the safety of system improves by disabling E/W except the time of E/W execution.



Also, execute the following processing before the CPU reprogramming mode is selected so that interrupts will not occur during the CPU reprogramming mode.

• Set the interrupt disable flag (I) to "1"

When the watchdog timer has already started, write to the watchdog timer control register (address 1E<sub>16</sub>) periodically during the CPU reprogramming mode in order not to generate the reset by the underflow of the watchdog timer H.

During the program or erase execution, watchdog timer is automatically cleared. Accordingly, the inernal reset by underflow does not occur.

When the interrupt request or reset occurs in the CPU reprogramming mode, the microcomputer enters the following state;

Interrupt occurs

This may cause a program runaway because the read from the flash memory which has the interrupt vector area cannot be performed.

• Underflow of watchdog timer H, reset

This may cause a microcomputer reset; the built-in flash memory control circuit and the flash memory control register are reset. When reset state is released with CNVss = "H" and P45/TxD1 = "H", CPU starts in the boot mode.

Also, when the above interrupt and reset occur during program/erase, error data may still exist after reset release because the reprogramming of the flash memory is not completed, so that reprogramming of the flash memory in the parallel I/O mode or serial I/O mode is required.



## 2.12.7 Flash memory mode application examples

The control pin processing example on the system board in the standard serial I/O mode and the control example in the CPU rewrite mode are described below.

### (1) Control pin connection example on system board in standard serial I/O mode

As shown in Figure 2.12.4, in the standard serial I/O mode, the built-in flash memory can be rewritten with the microcomputer mounted on board. Connection examples of control pins (P44/RxD, P45/TxD, P46/Sclk1, P47/SRDY1/CNTR2, CNVss, and RESET pin) in the standard serial I/O mode are described below.



Fig. 2.12.6 Rewrite example of built-in flash memory in standard serial I/O mode



### ① When control signals are not affected to user system circuit

When the control signals in the standard serial I/O mode are not used or not affected to the user system circuit, they can be connected as shown in Figure 2.12.7.



Fig. 2.12.7 Connection example in standard serial I/O mode (1)

### 2 When control signals are affected to user system circuit-1

Figure 2.12.8 shows an example that the jumper switch cut-off the control signals not to supply to the user system circuit in the standard serial I/O mode.



Fig. 2.12.8 Connection example in standard serial I/O mode (2)



# 3 When control signals are affected to user system circuit-2

Figure 2.12.9 shows an example that the analog switch (74HC4066) cut-off the control signals not to supply to the user system circuit in the standard serial I/O mode.



Fig. 2.12.9 Connection example in standard serial I/O mode (3)



## (2) Control pin termination example in CPU rewrite mode

In this example, data is received by using serial I/O, and the data is programmed to the built-in flash memory in the CPU rewrite mode.

Figure 2.12.10 shows an example of the reprogramming system for the built-in flash memory in the CPU rewrite mode. For the CPU rewrite mode beginning/release method, refer to "2.12.6 CPU rewrite mode."



Fig. 2.12.10 Example of rewrite system for built-in flash memory in CPU rewrite mode (single-chip mode)



#### 2.12.8 Notes on CPU rewrite mode

## (1) Operation speed

During CPU rewrite mode, set the system clock  $\phi$  4.0 MHz or less using the main clock division ratio selection bits (bits 6 and 7 of address 003B<sub>16</sub>).

### (2) Instructions inhibited against use

The instructions which refer to the internal data of the flash memory cannot be used during the CPU rewrite mode.

### (3) Interrupts inhibited against use

The interrupts cannot be used during the CPU rewrite mode because they refer to the internal data of the flash memory.

### (4) Watchdog timer

In case of the watchdog timer has been running already, the internal reset generated by watchdog timer underflow does not happen, because of watchdog timer is always clearing during program or erase operation.

#### (5) Reset

Reset is always valid. In case of  $CNV_{SS}$  = "H" when reset is released, boot mode is active. So the program starts from the address contained in address FFFC<sub>16</sub> and FFFD<sub>16</sub> in boot ROM area.



# 3. Reference Program Example

Please find the reference program on the Renesas Technology website. Click the upper left menu of the screen "Application Notes" on the 740 family.

### 4. Reference

Data Sheet 3803 Group (Spec.H) Data Sheet

Technical News/Technical Update
Before using this material, please visit our website to verify that this is the most updated document available.

# 5. Website and Support

Renesas Technology Corporation Semiconductor Home Page http://www.renesas.com

E-mail Support

E-mail: csc@renesas.com



| REVISION HISTORY | 3803 Group (Spec.H) Peripheral Function Application |
|------------------|-----------------------------------------------------|
|------------------|-----------------------------------------------------|

| Day Data |                   |      | Description                                                                  |
|----------|-------------------|------|------------------------------------------------------------------------------|
| Rev.     | Date              | Page | Summary                                                                      |
| 1.00     | 1.00 Nov 14, 2005 |      | This application note is issued using the information of "Chapter 2          |
|          |                   |      | APPLICATION" in the 3803 Group (Spec.H) User's Manual Rev.2.02.              |
|          |                   | 34   | Fig.2.3.17 Control procedure is partly revised                               |
|          |                   | 62   | Fig.2.4.21 Registers setting relevant to transmitting side is partly revised |
|          |                   | 64   | Fig.2.4.23 Control procedure of transmitting side is partly revised          |
|          |                   | 68   | Fig.2.4.29 Control procedure of serial I/O1 is partly revised                |
|          |                   | 71   | Fig.2.4.33 Connection diagram is partly revised                              |
|          |                   |      | Specifications, Limitations of specifications are revised                    |
|          |                   | 72   | Fig.2.4.34 Timing chart is revised                                           |
|          |                   |      | Fig.2.4.35 Relevant registers setting is partly revised                      |
|          |                   |      | ●Control in the master unit is revised                                       |
|          |                   |      | Fig.2.4.36 Control procedure of master unit is revised                       |
|          |                   | 74   | ●Control in the slave unit is revised                                        |
|          |                   |      | Fig.2.4.37 Control procedure of slave unit is revised                        |
|          |                   | 79   | Fig.2.4.42 Control procedure of transmitting side is partly revised          |
|          |                   | 80   | Fig.2.4.43 Control procedure of receiving side is partly revised             |



### Keep safety first in your circuit designs!

1. 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

- 1. 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.
- 2. 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.
- 3. 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).
- 4. 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.
- 5. 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.
- 6. The prior written approval of Renesas Technology Corporation is necessary to reprint or reproduce in whole or in part these materials.
- 7. 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.
- 8. Please contact Renesas Technology Corporation for further details on these materials or the products contained therein.